/* Print Haven Ventures — POS theme
   Concept: paper & ink. Warm off-white "paper", deep ink sidebar,
   CMYK-inspired accents for service categories. */

:root{
  --paper:#f4f2ec;
  --paper-2:#fbfaf6;
  --ink:#16161d;
  --ink-soft:#2a2a36;
  --line:#e3e0d6;
  --muted:#8a877d;
  --text:#26262e;
  --brand:#1d2b64;      /* deep ink blue */
  --brand-2:#2f4bd6;
  --accent:#e5006d;     /* press magenta */
  --cyan:#00a7c4;
  --yellow:#f2b705;
  --green:#0f9d58;
  --red:#d6324a;
  --radius:14px;
  --shadow:0 8px 30px rgba(20,20,30,.07);
  --shadow-sm:0 2px 8px rgba(20,20,30,.06);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Hanken Grotesk",system-ui,Segoe UI,sans-serif;
  background:var(--paper);
  color:var(--text);
  font-size:15px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--brand-2);text-decoration:none}
h1,h2,h3{font-family:"Hanken Grotesk",sans-serif;font-weight:700;color:var(--ink)}
.brandfont{font-family:"Fraunces",Georgia,serif}

/* ---------- Layout shell ---------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:248px;background:var(--ink);color:#cfcfda;flex-shrink:0;
  display:flex;flex-direction:column;padding:22px 14px;position:sticky;top:0;height:100vh;
}
.logo{display:flex;align-items:center;gap:10px;padding:4px 10px 22px;}
.logo .mark{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--brand-2));
  display:grid;place-items:center;color:#fff;font-weight:800;font-family:"Fraunces",serif;font-size:20px;flex-shrink:0}
.logo .name{line-height:1.1}
.logo .name b{color:#fff;font-family:"Fraunces",serif;font-size:17px;display:block}
.logo .name span{font-size:11px;color:#7f7f93;letter-spacing:.08em;text-transform:uppercase}

.nav{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.nav a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;color:#b7b7c6;
  font-weight:500;transition:.15s}
.nav a svg{width:19px;height:19px;flex-shrink:0;opacity:.85}
.nav a:hover{background:#22222e;color:#fff}
.nav a.active{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff}
.nav a.active svg{opacity:1}
.nav .sep{height:1px;background:#2c2c3a;margin:12px 8px}

.side-foot{margin-top:auto;padding:14px 12px;border-top:1px solid #2c2c3a}
.side-foot .who{font-size:13px;color:#fff;font-weight:600}
.side-foot .role{font-size:11px;color:#7f7f93;text-transform:uppercase;letter-spacing:.06em}
.side-foot a{display:inline-block;margin-top:10px;font-size:13px;color:#ff9fbf}

.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;border-bottom:1px solid var(--line)}
.topbar h1{margin:0;font-size:22px}
.content{padding:28px 32px;flex:1}

/* ---------- Cards / generic ---------- */
.card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card-pad{padding:22px}
.grid{display:grid;gap:18px}
.stat{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}
.stat .label{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:600}
.stat .value{font-size:28px;font-weight:800;color:var(--ink);margin-top:6px;font-family:"Fraunces",serif}
.stat .value.sm{font-size:22px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;font:inherit;font-weight:600;
  padding:11px 18px;border-radius:10px;background:#e9e7df;color:var(--ink);transition:.15s}
.btn:hover{filter:brightness(.97)}
.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff}
.btn-accent{background:var(--accent);color:#fff}
.btn-green{background:var(--green);color:#fff}
.btn-danger{background:var(--red);color:#fff}
.btn-ghost{background:transparent;border:1px solid var(--line)}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:8px}
.btn-block{width:100%;justify-content:center}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---------- Forms ---------- */
label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
input,select,textarea{width:100%;font:inherit;padding:11px 13px;border:1px solid var(--line);border-radius:10px;
  background:#fff;color:var(--text)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand-2);box-shadow:0 0 0 3px rgba(47,75,214,.12)}
.field{margin-bottom:16px}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row>*{flex:1;min-width:140px}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);
  padding:12px 14px;border-bottom:2px solid var(--line)}
td{padding:13px 14px;border-bottom:1px solid var(--line);font-size:14px}
tr:hover td{background:rgba(0,0,0,.015)}
.right{text-align:right}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}
.badge-paid{background:#e3f6ea;color:#0f7a40}
.badge-pending{background:#fdf3d6;color:#9a6a00}
.badge-cat{background:#eef0fb;color:var(--brand)}
.chip-c{background:#e2f6fa;color:#0a7385}
.chip-m{background:#fde4ef;color:#b3045a}
.chip-y{background:#fdf2cf;color:#8a6a00}
.chip-k{background:#e7e7ec;color:#2a2a36}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;
  background:radial-gradient(1200px 500px at 70% -10%, #21306e22, transparent),var(--paper)}
.login-card{width:380px;max-width:92vw;background:var(--paper-2);border:1px solid var(--line);
  border-radius:20px;padding:34px;box-shadow:var(--shadow)}
.login-card .mark{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--brand-2));
  display:grid;place-items:center;color:#fff;font-weight:800;font-family:"Fraunces",serif;font-size:26px;margin-bottom:18px}
.alert{background:#fde8e8;border:1px solid #f3b5b5;color:#a11;padding:11px 14px;border-radius:10px;margin-bottom:16px;font-size:14px}
.flash{background:#e3f6ea;border:1px solid #aadcbf;color:#0f7a40;padding:11px 14px;border-radius:10px;margin-bottom:16px;font-size:14px}

/* ---------- POS specific ---------- */
.pos{display:grid;grid-template-columns:1fr 400px;gap:20px;align-items:start}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.svc{background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:14px;cursor:pointer;
  text-align:left;transition:.12s;position:relative;overflow:hidden}
.svc:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--brand-2)}
.svc .bar{position:absolute;left:0;top:0;bottom:0;width:4px}
.svc .nm{font-weight:700;color:var(--ink);font-size:14px;padding-left:6px}
.svc .pr{color:var(--muted);font-size:13px;margin-top:4px;padding-left:6px}
.cart{position:sticky;top:24px}
.cart-head{padding:16px 18px;border-bottom:1px solid var(--line);font-weight:700;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center}
.cart-items{max-height:42vh;overflow:auto}
.ci{display:flex;gap:8px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line)}
.ci .ci-name{flex:1;font-weight:600;font-size:14px}
.ci .ci-unit{color:var(--muted);font-size:12px}
.ci input{width:54px;padding:6px;text-align:center;border-radius:8px}
.ci .price-in{width:78px}
.ci .x{background:none;border:none;color:var(--red);cursor:pointer;font-size:18px;line-height:1}
.cart-empty{padding:40px 16px;text-align:center;color:var(--muted)}
.cart-foot{padding:16px 18px}
.totline{display:flex;justify-content:space-between;margin:7px 0;font-size:14px}
.totline.big{font-size:20px;font-weight:800;color:var(--ink);border-top:1px dashed var(--line);padding-top:12px;margin-top:12px}
.payopts{display:flex;gap:8px;margin:12px 0}
.payopts label{flex:1;margin:0}
.payopts input{display:none}
.payopts span{display:block;text-align:center;padding:10px;border:1px solid var(--line);border-radius:10px;
  cursor:pointer;font-weight:600;font-size:13px;background:#fff}
.payopts input:checked + span{background:var(--brand);color:#fff;border-color:var(--brand)}

.empty{text-align:center;padding:60px 20px;color:var(--muted)}

/* ---------- Receipt (print) ---------- */
.receipt{max-width:340px;margin:30px auto;background:#fff;padding:26px;font-family:"Hanken Grotesk",monospace;
  border:1px solid var(--line);border-radius:8px}
.receipt h2{text-align:center;margin:0 0 2px;font-family:"Fraunces",serif}
.receipt .meta{text-align:center;color:#555;font-size:12px;margin-bottom:14px}
.receipt table{font-size:13px}
.receipt td{padding:5px 0;border:none}
.receipt .rtot{border-top:1px dashed #aaa;margin-top:10px;padding-top:8px}
.receipt .thanks{text-align:center;margin-top:16px;font-size:12px;color:#555}
.print-actions{text-align:center;margin:16px}

@media print{
  body{background:#fff}
  .no-print{display:none !important}
  .receipt{border:none;margin:0;box-shadow:none}
}

@media(max-width:900px){
  .pos{grid-template-columns:1fr}
  .sidebar{display:none}
}
