/* ====================================================================
   Vasantham Catering — Admin panel (Finexy-inspired, green brand)
   ==================================================================== */
:root{
  --bg:#eef0ec;
  --surface:#ffffff;
  --surface-2:#f6f8f4;
  --ink:#16241c;
  --ink-2:#5c6b60;
  --ink-3:#8a988d;
  --line:#e4e8e0;
  --brand:#16402c;          /* deep catering green */
  --brand-700:#1d5238;
  --accent:#a7e635;         /* lime */
  --accent-600:#8fce1e;
  --pos:#1f9d57;
  --neg:#e0533d;
  --warn:#e8a33d;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 1px 2px rgba(20,40,28,.04), 0 8px 24px rgba(20,40,28,.05);
  --sidebar-w:248px;
  font-family:'Manrope',-apple-system,BlinkMacSystemFont,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{background:var(--bg);color:var(--ink);font-family:'Manrope',sans-serif;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.boot{display:grid;place-items:center;height:100vh;color:var(--ink-3)}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;background:
  radial-gradient(900px 500px at 80% -10%, #1d5238 0%, transparent 60%),
  radial-gradient(700px 500px at -10% 110%, #16402c 0%, transparent 55%), #0f2018;padding:24px}
.login-card{width:100%;max-width:400px;background:var(--surface);border-radius:24px;padding:34px 30px;box-shadow:0 30px 80px rgba(0,0,0,.35)}
.login-card .brand{display:flex;align-items:center;gap:12px;margin-bottom:26px}
.brand-logo{width:46px;height:46px;border-radius:13px;background:var(--accent);display:grid;place-items:center;color:var(--brand);font-weight:800}
.brand-name{font-weight:800;font-size:19px;line-height:1.05}
.brand-sub{font-size:12px;color:var(--ink-3);font-weight:600}
.login-card h1{font-size:24px;margin-bottom:4px}
.login-card .muted{color:var(--ink-3);font-size:14px;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-weight:700;margin-bottom:7px}
.input{width:100%;height:50px;border:1.5px solid var(--line);background:var(--surface-2);border-radius:13px;padding:0 16px;font-size:15px;font-family:inherit;color:var(--ink);transition:border-color .15s}
.input:focus{outline:none;border-color:var(--brand-700)}
.btn{height:50px;width:100%;border-radius:13px;font-weight:700;font-size:15px;background:var(--brand);color:#fff;transition:transform .05s,background .15s;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn:hover{background:var(--brand-700)}
.btn:active{transform:translateY(1px)}
.btn.accent{background:var(--accent);color:var(--brand)}
.btn.accent:hover{background:var(--accent-600)}
.btn.ghost{background:var(--surface-2);color:var(--ink);border:1.5px solid var(--line)}
.btn.sm{height:38px;width:auto;padding:0 16px;font-size:13px;border-radius:10px}
.demo-hint{margin-top:18px;background:var(--surface-2);border:1px solid var(--line);border-radius:13px;padding:12px 14px;font-size:12.5px;color:var(--ink-2);line-height:1.6}
.demo-hint b{color:var(--ink)}
.form-error{color:var(--neg);font-size:13px;font-weight:600;min-height:18px;margin-bottom:4px}

/* ---------- App shell ---------- */
.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.sidebar{background:var(--brand);color:#cfe0d4;padding:22px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sidebar .brand{display:flex;align-items:center;gap:11px;padding:6px 8px 22px}
.sidebar .brand-name{color:#fff}
.sidebar .brand-sub{color:#7fa088}
.nav-group{margin-top:14px}
.nav-group .label{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#6f9079;padding:0 12px;margin-bottom:8px;font-weight:700}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:12px;color:#bcd1c2;font-weight:600;font-size:14.5px;margin-bottom:3px;transition:.15s}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:var(--accent);color:var(--brand)}
.nav-item .ico{width:19px;height:19px;display:grid;place-items:center}
.nav-item .badge{margin-left:auto;background:rgba(255,255,255,.16);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px}
.nav-item.active .badge{background:var(--brand);color:#fff}
.sidebar .spacer{flex:1}
.sidebar .signout{color:#f0b6a8}

.main{padding:24px 30px 48px;min-width:0}
.topbar{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.topbar h1{font-size:26px;font-weight:800}
.topbar .sub{color:var(--ink-3);font-size:13px;font-weight:600;margin-top:2px}
.topbar .right{margin-left:auto;display:flex;align-items:center;gap:12px}
.daterange{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:9px 14px;font-size:13px;font-weight:700;color:var(--ink-2);display:flex;align-items:center;gap:8px;box-shadow:var(--shadow)}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--brand);color:var(--accent);display:grid;place-items:center;font-weight:800}
.who{font-size:13px;font-weight:700;line-height:1.1}
.who small{color:var(--ink-3);font-weight:600}

/* ---------- Cards / grid ---------- */
.grid{display:grid;gap:18px}
.kpis{grid-template-columns:repeat(4,1fr)}
.cols-2{grid-template-columns:1.55fr 1fr}
.cols-2b{grid-template-columns:1fr 1fr}
.card{background:var(--surface);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.card.pad-lg{padding:24px}
.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-h h3{font-size:16px;font-weight:800}
.card-h .muted{font-size:12.5px;color:var(--ink-3);font-weight:600}

.kpi .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.kpi .title{font-size:13px;color:var(--ink-2);font-weight:700}
.kpi .ico{width:38px;height:38px;border-radius:11px;background:var(--surface-2);display:grid;place-items:center;color:var(--brand)}
.kpi .val{font-size:30px;font-weight:800;letter-spacing:-.02em;display:flex;align-items:baseline;gap:10px}
.delta{font-size:12px;font-weight:800;padding:3px 8px;border-radius:20px}
.delta.up{background:#e7f6ec;color:var(--pos)}
.delta.down{background:#fcebe7;color:var(--neg)}
.kpi .foot{margin-top:10px;font-size:12.5px;color:var(--ink-3);font-weight:600}

.seg{display:inline-flex;background:var(--surface-2);border-radius:10px;padding:3px}
.seg button{padding:6px 13px;border-radius:8px;font-size:12.5px;font-weight:700;color:var(--ink-2)}
.seg button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}

.legend{display:flex;gap:16px;align-items:center}
.legend span{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--ink-2)}
.dot{width:10px;height:10px;border-radius:50%}

.split-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px dashed var(--line)}
.split-row:last-child{border-bottom:none}
.split-row .l{font-size:13.5px;color:var(--ink-2);font-weight:600}
.split-row .v{font-weight:800}

/* ---------- Table ---------- */
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);font-weight:700;padding:10px 12px;border-bottom:1px solid var(--line)}
.table td{padding:13px 12px;border-bottom:1px solid var(--line);font-size:14px;font-weight:600}
.table tr:last-child td{border-bottom:none}
.table tr:hover td{background:var(--surface-2)}
.tcell-strong{font-weight:800}
.muted-cell{color:var(--ink-3);font-weight:600;font-size:12.5px}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:4px 11px;border-radius:20px}
.pill.green{background:#e7f6ec;color:var(--pos)}
.pill.amber{background:#fbf0dc;color:#b8791c}
.pill.red{background:#fcebe7;color:var(--neg)}
.pill.grey{background:var(--surface-2);color:var(--ink-2)}

/* ---------- Toolbar / search ---------- */
.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.search{flex:1;min-width:220px;max-width:420px;height:44px;border:1px solid var(--line);background:var(--surface);border-radius:12px;padding:0 14px;font-size:14px;font-family:inherit;box-shadow:var(--shadow)}
.select{height:44px;border:1px solid var(--line);background:var(--surface);border-radius:12px;padding:0 12px;font-size:14px;font-weight:600;font-family:inherit;color:var(--ink);box-shadow:var(--shadow)}

/* ---------- Searchable product picker ---------- */
.picker{position:relative}
.picker-menu{display:none;position:absolute;left:0;right:0;top:calc(100% + 4px);background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 30px rgba(20,40,28,.14);max-height:220px;overflow-y:auto;z-index:60}
.picker-item{padding:10px 14px;font-size:14px;font-weight:600;color:var(--ink);cursor:pointer}
.picker-item:hover{background:var(--surface-2)}
.picker-empty{padding:12px 14px;color:var(--ink-3);font-size:13px;font-weight:600}

/* ---------- Modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(15,32,24,.45);display:grid;place-items:center;z-index:50;padding:20px;overflow-y:auto}
.modal{background:var(--surface);border-radius:20px;width:100%;max-width:460px;padding:26px;box-shadow:0 30px 80px rgba(0,0,0,.3);max-height:calc(100vh - 40px);overflow-y:auto}
.modal h2{font-size:20px;margin-bottom:18px}
.modal .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal .actions{display:flex;gap:10px;margin-top:22px;position:sticky;bottom:-26px;background:var(--surface);padding:12px 0 4px}
.modal .actions .btn{flex:1}

/* ---------- Toast ---------- */
#toasts{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:10px;z-index:80}
.toast{background:var(--brand);color:#fff;padding:13px 17px;border-radius:12px;font-size:13.5px;font-weight:700;box-shadow:0 10px 30px rgba(0,0,0,.25);animation:slidein .2s ease}
.toast.err{background:var(--neg)}
@keyframes slidein{from{transform:translateY(10px);opacity:0}to{transform:none;opacity:1}}

.empty{text-align:center;color:var(--ink-3);padding:40px;font-weight:600}
.section-gap{margin-top:18px}
@media(max-width:1100px){.kpis{grid-template-columns:repeat(2,1fr)}.cols-2,.cols-2b{grid-template-columns:1fr}}
@media(max-width:860px){.shell{grid-template-columns:1fr}.sidebar{position:fixed;z-index:40;transform:translateX(-100%);transition:.2s;width:240px}.sidebar.open{transform:none}.main{padding:18px}}
