/* ═══════════════════════════════════════════════════════════════
   SpiceBill Web — style.css
   ═══════════════════════════════════════════════════════════════ */

:root{
  --bg:#f5f0e8;--bg2:#ece4d4;--card:#fff;--ink:#1a1410;--ink2:#3d3225;
  --muted:#8a7b68;--line:#e0d5c4;--line2:#cfc2ac;
  --accent:#b64418;--accent2:#8b3210;--accent-soft:#fde8d8;
  --green:#15803d;--green-soft:#dcfce7;--red:#b91c1c;--red-soft:#fde8e8;
  --gold:#a16207;--gold-soft:#fef3c7;
  --r:10px;--r2:14px;--r3:20px;
  --shadow:0 2px 12px rgba(26,20,16,.07);
  --shadow2:0 8px 30px rgba(26,20,16,.12);
  --font:'DM Sans',system-ui,sans-serif;
  --serif:'DM Serif Display',serif;
  --mono:'JetBrains Mono',monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{font-family:var(--font);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer;border:0;background:transparent;color:inherit;font-size:inherit}
input,select,textarea{font-family:inherit;font-size:inherit;color:var(--ink);background:var(--card);border:1.5px solid var(--line);border-radius:var(--r);padding:10px 14px;outline:0;width:100%;transition:border .2s}
input:focus,select:focus,textarea:focus{border-color:var(--accent)}
select{cursor:pointer}
a{color:var(--accent);text-decoration:none}
.serif{font-family:var(--serif)}
.mono{font-family:var(--mono)}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line2);border-radius:3px}

/* ── LAYOUT ── */
.app-wrap{display:flex;height:100vh;overflow:hidden}
.sidebar{width:240px;background:var(--ink);color:#fff;display:flex;flex-direction:column;flex-shrink:0;transition:transform .3s}
.sidebar-logo{padding:24px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08)}
.sidebar-logo h1{font-family:var(--serif);font-size:22px;font-weight:400;color:#fff;letter-spacing:-.5px}
.sidebar-logo .sub{font-size:11px;color:rgba(255,255,255,.45);margin-top:2px}
.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 20px;color:rgba(255,255,255,.6);font-size:13.5px;font-weight:500;cursor:pointer;transition:all .15s;border-left:3px solid transparent}
.nav-item:hover{color:rgba(255,255,255,.85);background:rgba(255,255,255,.04)}
.nav-item.active{color:#fff;background:rgba(255,255,255,.08);border-left-color:var(--accent)}
.nav-item svg{width:18px;height:18px;opacity:.7;flex-shrink:0}
.nav-item.active svg{opacity:1}
.sidebar-foot{padding:16px 20px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:rgba(255,255,255,.35)}
.sidebar-foot .plan-badge{display:inline-block;padding:3px 10px;border-radius:20px;background:var(--accent);color:#fff;font-size:11px;font-weight:600;margin-bottom:4px}
.sidebar-foot .days{color:rgba(255,255,255,.5)}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;background:var(--card);border-bottom:1px solid var(--line);flex-shrink:0;min-height:56px}
.topbar h2{font-family:var(--serif);font-size:20px;font-weight:400}
.topbar-right{display:flex;align-items:center;gap:12px}
.topbar-user{font-size:13px;color:var(--muted)}
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--r);font-weight:600;font-size:13px;transition:all .15s}
.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent2)}
.btn-outline{border:1.5px solid var(--line);color:var(--ink2)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-danger{background:var(--red);color:#fff}
.btn-success{background:var(--green);color:#fff}
.content{flex:1;overflow-y:auto;padding:28px}

/* ── Cards ── */
.card{background:var(--card);border-radius:var(--r2);box-shadow:var(--shadow);padding:24px}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-header h3{font-family:var(--serif);font-size:17px;font-weight:400}

/* ── Stats ── */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.stat-card{background:var(--card);border-radius:var(--r2);padding:20px 24px;box-shadow:var(--shadow)}
.stat-card .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.stat-card .value{font-family:var(--serif);font-size:28px;margin-top:4px}
.stat-card .sub{font-size:12px;color:var(--muted);margin-top:2px}

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

/* ── Form Grid ── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:4px}
.form-group label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}
.form-group.full{grid-column:1/-1}

/* ── Toast ── */
.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 20px;border-radius:var(--r);font-size:13px;font-weight:500;color:#fff;animation:slideIn .3s ease;box-shadow:var(--shadow2)}
.toast.success{background:#15803d}.toast.error{background:#b91c1c}.toast.info{background:var(--accent)}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ── POS ── */
.pos-wrap{display:grid;grid-template-columns:1fr 380px;gap:0;height:100%;overflow:hidden}
.pos-menu{overflow-y:auto;padding:24px}
.pos-cart{background:var(--card);border-left:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}
.pos-cats{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.cat-pill{padding:6px 14px;border-radius:20px;font-size:12.5px;font-weight:600;background:var(--bg2);color:var(--muted);cursor:pointer;transition:all .15s;white-space:nowrap}
.cat-pill.active,.cat-pill:hover{background:var(--accent);color:#fff}
.pos-search{margin-bottom:16px}
.pos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.pos-item{background:var(--card);border:1.5px solid var(--line);border-radius:var(--r);padding:14px;cursor:pointer;transition:all .15s;text-align:left}
.pos-item:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.pos-item .name{font-weight:600;font-size:13px;margin-bottom:4px;line-height:1.3}
.pos-item .price{font-family:var(--mono);font-size:14px;color:var(--accent);font-weight:500}
.pos-item .gst-tag{font-size:10px;background:var(--gold-soft);color:var(--gold);padding:1px 6px;border-radius:4px;font-weight:600;margin-left:4px}
.cart-header{padding:16px 20px;border-bottom:1px solid var(--line);font-family:var(--serif);font-size:17px}
.cart-items{flex:1;overflow-y:auto;padding:8px 0}
.cart-item{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:8px;padding:10px 20px;border-bottom:1px solid var(--line)}
.cart-item .ci-name{font-size:13px;font-weight:500}
.cart-item .ci-price{font-family:var(--mono);font-size:12px;color:var(--muted)}
.cart-item .ci-qty{display:flex;align-items:center;gap:6px}
.cart-item .ci-qty button{width:26px;height:26px;border-radius:6px;background:var(--bg2);font-size:15px;display:flex;align-items:center;justify-content:center;font-weight:700}
.cart-item .ci-qty button:hover{background:var(--accent-soft);color:var(--accent)}
.cart-item .ci-qty span{font-family:var(--mono);font-size:13px;min-width:20px;text-align:center}
.cart-item .ci-total{font-family:var(--mono);font-size:13px;font-weight:600;text-align:right;min-width:70px}
.cart-empty{text-align:center;padding:40px 20px;color:var(--muted);font-size:13px}
.cart-footer{padding:16px 20px;border-top:2px solid var(--line);background:var(--bg)}
.cart-row{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}
.cart-row.total{font-size:18px;font-weight:700;font-family:var(--serif);margin-top:8px;padding-top:8px;border-top:2px solid var(--line2)}
.cart-discount{display:flex;gap:6px;margin:10px 0}
.cart-discount input{width:80px;padding:6px 10px;font-size:12px}
.cart-discount select{width:90px;padding:6px 8px;font-size:12px}
.cart-actions{display:flex;gap:8px;margin-top:12px}
.cart-actions .btn{flex:1;justify-content:center;padding:12px}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--card);border-radius:var(--r3);box-shadow:var(--shadow2);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;padding:28px}
.modal h3{font-family:var(--serif);font-size:20px;margin-bottom:16px}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}

/* ── Login ── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1410,#3d2817 50%,#7c2d12);padding:20px}
.login-box{background:var(--card);border-radius:var(--r3);box-shadow:var(--shadow2);width:100%;max-width:420px;padding:40px}
.login-box h1{font-family:var(--serif);font-size:28px;text-align:center;margin-bottom:4px}
.login-box .sub{text-align:center;color:var(--muted);font-size:13px;margin-bottom:28px}
.login-box .form-group{margin-bottom:16px}
.login-box .btn{width:100%;justify-content:center;padding:13px;font-size:15px;margin-top:8px}
.login-tabs{display:flex;border-bottom:2px solid var(--line);margin-bottom:24px}
.login-tab{flex:1;text-align:center;padding:10px;font-weight:600;font-size:13px;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}
.login-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.login-extra{text-align:center;margin-top:16px;font-size:13px;color:var(--muted)}

/* ── Badge ── */
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.badge-green{background:var(--green-soft);color:var(--green)}
.badge-red{background:var(--red-soft);color:var(--red)}
.badge-gold{background:var(--gold-soft);color:var(--gold)}

/* ── Mobile ── */
.mobile-toggle{display:none;background:var(--ink);color:#fff;width:40px;height:40px;border-radius:var(--r);align-items:center;justify-content:center;font-size:20px}
@media(max-width:900px){
  .sidebar{position:fixed;left:0;top:0;bottom:0;z-index:100;transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .mobile-toggle{display:flex}
  .pos-wrap{grid-template-columns:1fr}
  .pos-cart{position:fixed;right:0;top:0;bottom:0;width:360px;z-index:90;transform:translateX(100%);transition:transform .3s;box-shadow:var(--shadow2)}
  .pos-cart.open{transform:translateX(0)}
  .form-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .content{padding:16px}
  .pos-menu{padding:16px}
  .pos-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}
  .pos-cart{width:100%}
  .stats-row{grid-template-columns:1fr 1fr}
}

/* ── Site Footer ── */
.site-footer{
  text-align:center;padding:10px 20px;font-size:11.5px;color:var(--muted);
  border-top:1px solid var(--line);background:var(--card);flex-shrink:0;
  letter-spacing:.2px;
}
.site-footer a{color:var(--accent);font-weight:600}
.site-footer .sep{margin:0 6px;opacity:.4}
.login-footer{
  position:fixed;bottom:0;left:0;right:0;
  text-align:center;padding:12px 20px;font-size:11.5px;color:rgba(255,255,255,.5);
  letter-spacing:.2px;background:rgba(0,0,0,.15);
}
.login-footer a{color:rgba(255,255,255,.75);text-decoration:none;font-weight:600}

/* ══════════════════════════════════════════════════════════════════
   PRINT STYLES — Thermal Receipt (80mm)
   KEY FIX: Hide SPECIFIC containers, NOT body *
   ══════════════════════════════════════════════════════════════════ */
.bill-print{display:none}

@media print{
  @page{margin:0;size:80mm auto}

  /* Hide the app UI — target each container by ID/class */
  #authPage,
  #appWrap,
  #menuModal,
  #billModal,
  #toastContainer,
  .login-footer{
    display:none!important;
  }

  /* Show the receipt */
  .bill-print{
    display:block!important;
    position:absolute;top:0;left:0;
    background:#fff;
    padding:3mm 4mm 6mm;
    font-family:'Courier New','Lucida Console',monospace;
    font-size:13px;line-height:1.5;color:#000;
    font-weight:700;
    width:80mm;
  }

  /* Receipt table cells */
  .bill-print table{width:100%;border-collapse:collapse}
  .bill-print td{
    padding:2px 0;
    vertical-align:top;
    font-size:13px;
    font-weight:700;
    color:#000;
    border:none;
  }

  /* Utility classes */
  .bill-print .td-r{text-align:right}

  /* Header */
  .bill-print .bp-name{font-size:16px;font-weight:900;text-align:center;margin-bottom:2px}
  .bill-print .bp-addr{text-align:center;font-size:12px;line-height:1.35;font-weight:700}

  /* Lines */
  .bill-print .bp-dash{border:none;border-top:1px dashed #000;margin:5px 0}
  .bill-print .bp-thick{border:none;border-top:2.5px solid #000;margin:6px 0}

  /* Item detail */
  .bill-print .bp-item-q{font-size:12px;font-weight:600;padding-left:4px}

  /* Totals */
  .bill-print .bp-total{font-size:18px;font-weight:900;text-align:center;padding:5px 0 2px}
  .bill-print .bp-paid{text-align:center;font-size:13px;font-weight:700;padding:2px 0}

  /* Footer */
  .bill-print .bp-footer{text-align:center;font-size:12px;font-weight:700;margin-top:3px}
  .bill-print .bp-support{text-align:center;font-size:10px;font-weight:600;margin-top:4px}
}
