/* MeetLoop admin design system */
:root{
  --bg:#F4F5FB; --card:#FFFFFF; --ink:#141627; --mut:#6B7280; --line:#E7E8F2;
  --brand:#4F46E5; --brand2:#6C63FF; --ok:#16A34A; --warn:#D97706; --bad:#DC2626;
  --side:#141627; --side-ink:#C7CAE0; --r:14px; --sh:0 4px 22px rgba(20,22,60,.07);
}
@media (prefers-color-scheme: dark){
  :root{ --bg:#0F1120; --card:#181A2E; --ink:#EDEEFC; --mut:#9AA0BF; --line:#272A45; --side:#0B0D1A; --sh:0 4px 22px rgba(0,0,0,.4); }
}
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{font-family:'Inter',-apple-system,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--ink);font-size:14.5px;-webkit-font-smoothing:antialiased}
a{color:var(--brand);text-decoration:none}
.layout{display:flex;min-height:100vh}
/* sidebar */
.side{width:232px;background:var(--side);color:var(--side-ink);padding:22px 14px;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;z-index:40}
.side .logo{color:#fff;font-weight:800;font-size:19px;letter-spacing:.2px;padding:0 10px 22px;display:flex;align-items:center;gap:9px}
.side .logo .dot{width:10px;height:10px;border-radius:3px;background:linear-gradient(135deg,var(--brand),#9333EA)}
.side nav a{display:flex;align-items:center;gap:11px;color:var(--side-ink);padding:10px 12px;border-radius:10px;margin-bottom:3px;font-weight:500;font-size:14px;transition:.15s}
.side nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.side nav a.on{background:var(--brand);color:#fff}
.side .foot{margin-top:auto;padding:10px 12px;font-size:12px;color:#5B5F7E}
.main{flex:1;margin-left:232px;padding:26px 30px 60px;max-width:1160px}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.topbar h1{font-size:21px;margin:0;font-weight:700}
.userchip{display:flex;align-items:center;gap:9px;color:var(--mut);font-size:13px}
.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#9333EA);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
/* cards, grid */
.card{background:var(--card);border-radius:var(--r);box-shadow:var(--sh);padding:20px 22px;border:1px solid var(--line)}
.grid{display:grid;gap:16px}
.g4{grid-template-columns:repeat(4,1fr)} .g3{grid-template-columns:repeat(3,1fr)} .g2{grid-template-columns:repeat(2,1fr)}
@media(max-width:1000px){.g4,.g3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:700px){.g4,.g3,.g2{grid-template-columns:1fr}.main{margin-left:0;padding:18px}.side{display:none}}
.kpi .num{font-size:26px;font-weight:800;margin-top:4px}
.kpi .lbl{color:var(--mut);font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.kpi .sub{color:var(--mut);font-size:12px;margin-top:5px}
/* table */
table.tbl{width:100%;border-collapse:collapse}
.tbl th{font-size:11.5px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px;text-align:left;padding:9px 12px;border-bottom:1px solid var(--line)}
.tbl td{padding:12px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tr:hover td{background:rgba(79,70,229,.035)}
.tbl tr:last-child td{border-bottom:none}
/* badges + buttons */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}
.b-booked{background:rgba(79,70,229,.12);color:var(--brand)} .b-completed{background:rgba(22,163,74,.13);color:var(--ok)}
.b-cancelled{background:rgba(107,114,128,.14);color:var(--mut)} .b-noshow{background:rgba(220,38,38,.12);color:var(--bad)}
.b-hot{background:rgba(220,38,38,.12);color:var(--bad)} .b-warm{background:rgba(217,119,6,.13);color:var(--warn)} .b-cold{background:rgba(59,130,246,.12);color:#2563EB}
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--brand);color:#fff;border:none;border-radius:10px;padding:9px 16px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:.15s}
.btn:hover{filter:brightness(1.08)} .btn:disabled{opacity:.5;cursor:default}
.btn.sec{background:transparent;color:var(--ink);border:1px solid var(--line)} .btn.sec:hover{border-color:var(--brand);color:var(--brand);filter:none}
.btn.danger{background:var(--bad)} .btn.sm{padding:6px 12px;font-size:13px;border-radius:8px}
/* kebab menu */
.kebab{position:relative;display:inline-block}
.kebab>button{background:none;border:none;cursor:pointer;color:var(--mut);font-size:18px;padding:4px 8px;border-radius:8px;opacity:0;transition:.12s}
tr:hover .kebab>button,.kebab>button:focus,.kebab.open>button{opacity:1}
.kebab>button:hover{background:var(--line)}
.kebab .menu{position:absolute;right:0;top:100%;background:var(--card);border:1px solid var(--line);border-radius:10px;box-shadow:var(--sh);min-width:170px;z-index:60;display:none;padding:5px;overflow:hidden}
.kebab.open .menu{display:block}
.kebab .menu button{display:block;width:100%;text-align:left;background:none;border:none;padding:9px 12px;font-size:13.5px;color:var(--ink);cursor:pointer;border-radius:7px;font-family:inherit}
.kebab .menu button:hover{background:rgba(79,70,229,.08)}
.kebab .menu button.red{color:var(--bad)}
/* forms */
label.f{display:block;font-size:12.5px;font-weight:600;color:var(--mut);margin:14px 0 6px}
input.i,select.i,textarea.i{width:100%;background:var(--bg);border:1.5px solid var(--line);border-radius:10px;padding:10px 12px;font-size:14px;color:var(--ink);font-family:inherit;outline:none;transition:.15s}
input.i:focus,select.i:focus,textarea.i:focus{border-color:var(--brand)}
textarea.i{min-height:80px;resize:vertical}
.row{display:flex;gap:12px}.row>*{flex:1}
.switch{position:relative;width:40px;height:22px;flex:none}
.switch input{opacity:0;width:0;height:0}
.switch span{position:absolute;inset:0;background:var(--line);border-radius:999px;transition:.2s;cursor:pointer}
.switch span:before{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:3px;left:3px;transition:.2s;box-shadow:0 1px 4px rgba(0,0,0,.25)}
.switch input:checked+span{background:var(--brand)} .switch input:checked+span:before{transform:translateX(18px)}
/* drawer */
.drawer-bg{position:fixed;inset:0;background:rgba(10,12,30,.45);z-index:70;opacity:0;pointer-events:none;transition:.2s}
.drawer{position:fixed;top:0;right:-560px;width:540px;max-width:96vw;height:100vh;background:var(--card);z-index:71;box-shadow:-8px 0 40px rgba(0,0,0,.18);transition:right .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.drawer.open{right:0} .drawer-bg.show{opacity:1;pointer-events:auto}
.drawer .dh{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--line)}
.drawer .dh h3{margin:0;font-size:17px}
.drawer .db{padding:20px 24px;overflow-y:auto;flex:1}
.drawer .df{padding:15px 24px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}
.x{background:none;border:none;font-size:21px;color:var(--mut);cursor:pointer;padding:4px 8px;border-radius:8px} .x:hover{background:var(--line)}
/* modal (premium — never native popups) */
.modal-bg{position:fixed;inset:0;background:rgba(10,12,30,.5);z-index:90;display:none;align-items:center;justify-content:center;padding:20px}
.modal-bg.show{display:flex}
.modal{background:var(--card);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);max-width:430px;width:100%;padding:26px;animation:pop .18s ease}
@keyframes pop{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
.modal h3{margin:0 0 8px;font-size:17px} .modal p{color:var(--mut);margin:0 0 20px;line-height:1.55}
.modal .acts{display:flex;gap:10px;justify-content:flex-end}
/* toast */
#toasts{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:120;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:var(--ink);color:var(--bg);padding:11px 20px;border-radius:12px;font-size:13.5px;font-weight:600;box-shadow:0 8px 30px rgba(0,0,0,.25);animation:pop .2s ease}
.toast.err{background:var(--bad);color:#fff}
/* rev pill */
#revpill{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--brand);color:#fff;padding:10px 18px;border-radius:999px;font-size:13.5px;font-weight:700;box-shadow:0 10px 30px rgba(79,70,229,.4);cursor:pointer;z-index:110;transition:.25s;display:flex;gap:9px;align-items:center}
#revpill.show{transform:translateX(-50%) translateY(0)}
/* misc */
.mut{color:var(--mut)} .sp{height:16px} .flex{display:flex;align-items:center;gap:10px}
.chip{display:inline-block;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:4px 10px;font-size:12.5px;margin:2px}
.empty{text-align:center;color:var(--mut);padding:44px 0;font-size:14px}
.empty .big{font-size:34px;margin-bottom:10px}
code.k{background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:2px 7px;font-size:12.5px}
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:20px;flex-wrap:wrap}
.tabs button{background:none;border:none;padding:10px 15px;font-size:14px;font-weight:600;color:var(--mut);cursor:pointer;border-bottom:2.5px solid transparent;font-family:inherit;margin-bottom:-1px}
.tabs button.on{color:var(--brand);border-bottom-color:var(--brand)}
.copybtn{cursor:pointer}
