/* BookLoop — component library. Consumes tokens.css + themes.css only. */

/* ===== App shell (desktop: instructor/admin) ===== */
.shell{display:flex; min-height:100vh; align-items:stretch;}
.sidebar{
  width:248px; flex-shrink:0; display:flex; flex-direction:column; gap:var(--space-1);
  padding:var(--space-3); border-right:1px solid var(--border);
  background:var(--glass-1); backdrop-filter:blur(var(--blur-glass)) saturate(140%); -webkit-backdrop-filter:blur(var(--blur-glass)) saturate(140%);
  position:sticky; top:0; height:100vh; overflow-y:auto;
}
.sidebar.collapsed{width:64px;}
.sidebar.collapsed .navItem span, .sidebar.collapsed .navsep, .sidebar.collapsed .switcher .meta{display:none;}

.brand{display:flex; align-items:center; gap:var(--space-2); padding:var(--space-2); margin-bottom:var(--space-1);}
.brand .logo{width:34px;height:34px;border-radius:var(--radius-md);display:grid;place-items:center;font-size:18px;
  background:linear-gradient(140deg,var(--accent),var(--accent-press)); color:var(--accent-fg); flex-shrink:0;}
.brand b{font-size:var(--text-lg);} .brand small{display:block;color:var(--fg-subtle);font-size:var(--text-2xs);}

/* school/role switcher */
.switcher{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-md);
  border:1px solid var(--border); background:var(--surface-1); cursor:pointer; margin-bottom:var(--space-2);}
.switcher:hover{background:var(--surface-3);}
.switcher .dot{width:9px;height:9px;border-radius:999px;background:var(--accent);flex-shrink:0;}
.switcher .meta{flex:1;min-width:0;} .switcher .meta b{font-size:var(--text-sm);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.switcher .meta small{font-size:var(--text-2xs);color:var(--fg-subtle);}
.switcher .chev{color:var(--fg-subtle);}

.navsep{font-size:var(--text-2xs);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-subtle);padding:var(--space-3) var(--space-2) var(--space-1);font-weight:var(--w-medium);}
.navItem{display:flex;align-items:center;gap:var(--space-3);width:100%;height:36px;padding:0 var(--space-3);border-radius:var(--radius-md);
  appearance:none;-webkit-appearance:none;border:0;background:transparent;text-align:left;font-family:inherit;
  color:var(--fg-muted);cursor:pointer;position:relative;transition:background var(--dur) var(--ease),color var(--dur) var(--ease);font-size:var(--text-sm);font-weight:var(--w-medium);}
.navItem .ic{font-size:16px;width:20px;text-align:center;flex-shrink:0;}
.navItem:hover{background:var(--surface-4);color:var(--fg);}
.navItem.active{background:var(--accent-ghost);color:var(--fg);}
.navItem.active::before{content:"";position:absolute;left:0;top:7px;bottom:7px;width:3px;border-radius:999px;background:var(--accent);}
.navItem .badge{margin-left:auto;font-size:var(--text-2xs);font-weight:var(--w-bold);padding:1px 7px;border-radius:999px;background:var(--pending-ghost);color:var(--pending);}
.navItem .badge.warn{background:var(--warn-ghost);color:var(--warn);}
.me{display:flex;align-items:center;gap:var(--space-2);margin-top:auto;padding:var(--space-2);border-top:1px solid var(--border);}

/* main column */
.main{flex:1;min-width:0;display:flex;flex-direction:column;}
.topbar{height:56px;display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-5);position:sticky;top:0;z-index:20;
  border-bottom:1px solid var(--border); background:var(--glass-1); backdrop-filter:blur(var(--blur-heavy)) saturate(140%); -webkit-backdrop-filter:blur(var(--blur-heavy)) saturate(140%);}
.topbar h1{font-size:var(--text-lg);font-weight:var(--w-bold);}
.topbar .spacer{flex:1;}
.cmd{display:flex;align-items:center;gap:var(--space-2);height:34px;max-width:420px;flex:1;padding:0 var(--space-3);border-radius:var(--radius-sm);
  border:1px solid var(--border);background:var(--surface-1);color:var(--fg-subtle);cursor:text;font-size:var(--text-sm);}
.cmd .kbd{margin-left:auto;font-size:var(--text-2xs);padding:1px 6px;border-radius:4px;border:1px solid var(--border);color:var(--fg-subtle);}
.iconbtn{width:34px;height:34px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-1);color:var(--fg-muted);
  display:grid;place-items:center;cursor:pointer;position:relative;font-size:15px;}
.iconbtn:hover{background:var(--surface-3);color:var(--fg);}
.iconbtn .dot{position:absolute;top:6px;right:7px;width:7px;height:7px;border-radius:999px;background:var(--danger);border:1.5px solid var(--surface-1);}
.content{flex:1;padding:var(--space-6);max-width:1340px;width:100%;margin:0 auto;}
.layout-rail{display:grid;grid-template-columns:1fr 312px;gap:var(--space-5);align-items:start;}
@media(max-width:1200px){.layout-rail{grid-template-columns:1fr;}}

/* hamburger — only shown on narrow desktop viewports */
.hamburger{display:none;}
.sidebar-scrim{display:none;position:fixed;inset:0;z-index:24;background:rgba(0,0,0,.45);}
.sidebar-scrim.open{display:block;}
@media(max-width:768px){
  .sidebar{position:fixed;left:0;top:0;z-index:30;transform:translateX(-100%);transition:transform var(--dur) var(--ease);}
  .shell.nav-open .sidebar{transform:none;}
  .hamburger{display:grid;}
}

/* page head */
.pagehead{display:flex;align-items:flex-end;gap:var(--space-4);margin-bottom:var(--space-5);flex-wrap:wrap;}
.pagehead h2{font-size:var(--text-2xl);}
.pagehead .sub{color:var(--fg-muted);font-size:var(--text-sm);margin-top:2px;}
.pagehead .spacer{flex:1;}

/* ===== Cards & stat tiles ===== */
.card{background:var(--glass-2);backdrop-filter:blur(var(--blur-glass)) saturate(140%);-webkit-backdrop-filter:blur(var(--blur-glass)) saturate(140%);
  border:1px solid var(--border);box-shadow:var(--shadow-2);border-radius:var(--radius-lg);padding:var(--space-5);}
.card.tight{padding:var(--space-3) var(--space-4);}
.card-title{font-size:var(--text-lg);font-weight:var(--w-medium);display:flex;align-items:center;gap:var(--space-2);}
.card-head{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);}
.label{font-size:var(--text-2xs);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-subtle);font-weight:var(--w-medium);margin-bottom:var(--space-3);}
.grid{display:grid;gap:var(--space-4);}
.g2{grid-template-columns:repeat(2,1fr);} .g3{grid-template-columns:repeat(3,1fr);} .g4{grid-template-columns:repeat(4,1fr);}
.g-2-1{grid-template-columns:1.7fr 1fr;}
@media(max-width:1000px){.g4{grid-template-columns:repeat(2,1fr);} .g3,.g2,.g-2-1{grid-template-columns:1fr;}}

.stat .lbl{font-size:var(--text-2xs);letter-spacing:.06em;text-transform:uppercase;color:var(--fg-subtle);}
.stat .val{font-size:var(--text-3xl);font-weight:var(--w-bold);font-family:var(--font-mono);font-variant-numeric:tabular-nums;margin:var(--space-2) 0 var(--space-1);letter-spacing:-.02em;}
.stat .val.sm{font-size:var(--text-2xl);}
.trend{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-xs);padding:2px 7px;border-radius:999px;}
.trend.up{background:var(--ok-ghost);color:var(--ok);} .trend.down{background:var(--danger-ghost);color:var(--danger);} .trend.flat{color:var(--fg-subtle);}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:var(--control-h);padding:0 14px;border-radius:var(--radius-md);
  border:1px solid transparent;font-size:var(--text-sm);font-weight:var(--w-medium);cursor:pointer;white-space:nowrap;transition:all var(--dur) var(--ease);
  background:var(--accent);color:var(--accent-fg);}
.btn:hover{background:var(--accent-hover);} .btn:active{background:var(--accent-press);transform:scale(.98);}
.btn.secondary{background:var(--surface-3);border-color:var(--border-strong);color:var(--fg);}
.btn.secondary:hover{background:var(--surface-4);}
.btn.ghost{background:transparent;color:var(--fg-muted);} .btn.ghost:hover{background:var(--surface-4);color:var(--fg);}
.btn.danger{background:var(--danger-ghost);border-color:var(--danger);color:var(--danger);}
.btn.danger:hover{background:color-mix(in srgb,var(--danger) 22%,transparent);}
.btn.success{background:var(--ok-ghost);border-color:var(--ok);color:var(--ok);}
.btn.success:hover{background:color-mix(in srgb,var(--ok) 22%,transparent);}
.btn.sm{height:28px;padding:0 10px;font-size:var(--text-xs);}
.btn.block{width:100%;}
.btn:disabled{background:var(--surface-2);color:var(--fg-disabled);cursor:not-allowed;border-color:var(--border);}
.btn .ic{font-size:14px;}

/* ===== Pills / badges / chips ===== */
.pill{display:inline-flex;align-items:center;gap:5px;font-size:var(--text-xs);font-weight:var(--w-medium);padding:3px 9px;border-radius:999px;white-space:nowrap;border:1px solid transparent;}
.pill::before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor;flex-shrink:0;}
.pill.nodot::before{display:none;}
.pill.ok{background:var(--ok-ghost);color:var(--ok);border-color:color-mix(in srgb,var(--ok) 35%,transparent);}
.pill.warn{background:var(--warn-ghost);color:var(--warn);border-color:color-mix(in srgb,var(--warn) 35%,transparent);}
.pill.danger{background:var(--danger-ghost);color:var(--danger);border-color:color-mix(in srgb,var(--danger) 35%,transparent);}
.pill.info{background:var(--info-ghost);color:var(--info);border-color:color-mix(in srgb,var(--info) 35%,transparent);}
.pill.pending{background:var(--pending-ghost);color:var(--pending);border-color:color-mix(in srgb,var(--pending) 35%,transparent);}
.pill.accent{background:var(--accent-ghost);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 35%,transparent);}
.pill.muted{background:var(--surface-3);color:var(--fg-muted);border-color:var(--border);}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-xs);padding:5px 11px;border-radius:999px;border:1px solid var(--border);background:var(--surface-1);color:var(--fg-muted);cursor:pointer;}
.chip:hover{background:var(--surface-3);color:var(--fg);}
.chip.on{background:var(--accent-ghost);border-color:color-mix(in srgb,var(--accent) 40%,transparent);color:var(--fg);}

/* ===== Avatars / rows ===== */
.av{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-weight:var(--w-bold);font-size:var(--text-xs);flex-shrink:0;
  background:linear-gradient(140deg,var(--accent),var(--accent-press));color:var(--accent-fg);}
.av.sm{width:28px;height:28px;font-size:11px;border-radius:8px;}
.av.lg{width:44px;height:44px;font-size:var(--text-md);}
.row{display:flex;align-items:center;gap:var(--space-3);} .grow{flex:1;min-width:0;}
.muted{color:var(--fg-muted);} .subtle{color:var(--fg-subtle);} .tiny{font-size:var(--text-xs);} .nowrap{white-space:nowrap;}
.bar{height:6px;border-radius:999px;background:var(--surface-1);overflow:hidden;min-width:80px;}
.bar > i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent-hover));}

/* ===== Tables ===== */
.tablewrap{overflow-x:auto;}
table.tbl{width:100%;border-collapse:collapse;font-size:var(--font-body);}
table.tbl th{text-align:left;font-size:var(--text-2xs);letter-spacing:.06em;text-transform:uppercase;color:var(--fg-subtle);font-weight:var(--w-medium);
  padding:0 var(--space-3) var(--space-3);position:sticky;top:0;}
table.tbl td{padding:0 var(--space-3);height:var(--row-h);border-top:1px solid var(--border);vertical-align:middle;}
table.tbl tr:hover td{background:var(--surface-4);}
table.tbl td.num,table.tbl th.num{text-align:right;font-family:var(--font-mono);font-variant-numeric:tabular-nums;}

/* ===== Inputs ===== */
.input,select.input,textarea.input{width:100%;height:var(--control-h);background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--fg);font-size:var(--font-body);font-family:inherit;padding:0 var(--space-3);transition:border var(--dur) var(--ease);}
textarea.input{height:auto;min-height:80px;padding:var(--space-3);resize:vertical;line-height:1.5;}
.input:focus{border-color:var(--accent);}
.input:focus-visible{outline:var(--ring-w) solid var(--ring);outline-offset:2px;}
.input::placeholder{color:var(--fg-subtle);}
.field{margin-bottom:var(--space-4);} .field > label{display:block;font-size:var(--text-xs);color:var(--fg-muted);margin-bottom:var(--space-2);font-weight:var(--w-medium);}
.seg{display:inline-flex;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);padding:3px;gap:3px;}
.seg button{border:0;background:transparent;color:var(--fg-muted);font-size:var(--text-xs);font-weight:var(--w-medium);padding:5px 12px;border-radius:7px;cursor:pointer;}
.seg button.on{background:var(--surface-4);color:var(--fg);}
.toggle{appearance:none;-webkit-appearance:none;padding:0;width:38px;height:22px;border-radius:999px;background:var(--surface-4);border:1px solid var(--border);position:relative;cursor:pointer;flex-shrink:0;transition:background var(--dur) var(--ease);}
.toggle::after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:999px;background:var(--fg-muted);transition:all var(--dur) var(--ease);}
.toggle.on{background:var(--accent);} .toggle.on::after{left:18px;background:#fff;}

/* ===== Views (routing) ===== */
.view{display:none;} .view.active{display:block; animation:fade var(--dur-slow) var(--ease);}
@keyframes fade{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:none;}}

/* ===== Toasts ===== */
.toaster{position:fixed;z-index:90;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;pointer-events:none;}
.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:10px;min-width:300px;max-width:380px;padding:13px 15px;border-radius:var(--radius-lg);
  background:var(--glass-3);backdrop-filter:blur(var(--blur-heavy));-webkit-backdrop-filter:blur(var(--blur-heavy));box-shadow:var(--shadow-pop);
  border:1px solid var(--border-strong);position:relative;overflow:hidden;animation:toastin var(--dur-slow) var(--ease);}
.toast::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ok);}
.toast.warn::before{background:var(--warn);} .toast.danger::before{background:var(--danger);} .toast.info::before{background:var(--info);} .toast.accent::before{background:var(--accent);}
.toast .tmsg{flex:1;font-size:var(--text-sm);font-weight:var(--w-medium);} .toast .tsub{font-size:var(--text-xs);color:var(--fg-muted);font-weight:var(--w-regular);margin-top:2px;}
.toast .undo{background:transparent;border:0;color:var(--accent);font-weight:var(--w-medium);font-size:var(--text-xs);cursor:pointer;}
@keyframes toastin{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}

/* ===== Modal / sheet ===== */
.scrim{position:fixed;inset:0;z-index:80;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);display:none;align-items:center;justify-content:center;padding:var(--space-5);}
.scrim.open{display:flex;animation:fade var(--dur) var(--ease);}
.modal{width:520px;max-width:100%;max-height:88vh;overflow:auto;background:var(--glass-3);backdrop-filter:blur(var(--blur-heavy));-webkit-backdrop-filter:blur(var(--blur-heavy));
  border:1px solid var(--border-strong);border-radius:var(--radius-xl);box-shadow:var(--shadow-pop);animation:pop var(--dur-slow) var(--ease);}
.modal .mhead{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-5) var(--space-3);}
.modal .mhead h3{font-size:var(--text-xl);} .modal .mbody{padding:0 var(--space-5) var(--space-4);} .modal .mfoot{display:flex;gap:var(--space-2);justify-content:flex-end;padding:var(--space-3) var(--space-5) var(--space-5);}
@keyframes pop{from{opacity:0;transform:scale(.97) translateY(8px);}to{opacity:1;transform:none;}}

/* command palette */
.cmdk{align-items:flex-start;}
.cmdk .modal{width:560px;margin-top:10vh;}
.cmdk .ci{display:flex;align-items:center;gap:10px;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);}
.cmdk .ci input{flex:1;background:transparent;border:0;color:var(--fg);font-size:var(--text-lg);}
.cmdk .ci input:focus-visible{outline:var(--ring-w) solid var(--ring);outline-offset:2px;border-radius:4px;}
.cmdk .cres{padding:var(--space-2);max-height:50vh;overflow:auto;}
.cmdk .cgrp{font-size:var(--text-2xs);text-transform:uppercase;letter-spacing:.08em;color:var(--fg-subtle);padding:var(--space-3) var(--space-3) var(--space-1);}
.cmdk .citem{display:flex;align-items:center;gap:10px;padding:9px var(--space-3);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);}
.cmdk .citem:hover,.cmdk .citem.sel{background:var(--accent-ghost);}
.cmdk .cfoot{display:flex;gap:14px;padding:var(--space-3) var(--space-5);border-top:1px solid var(--border);font-size:var(--text-2xs);color:var(--fg-subtle);}

/* ===== Lesson list rows / agenda ===== */
.lrow{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) 0;border-top:1px solid var(--border);}
.lrow:first-child{border-top:0;}
.lrow .tm{width:64px;font-family:var(--font-mono);font-weight:var(--w-bold);font-size:var(--text-sm);}
.lrow .tm small{display:block;color:var(--fg-subtle);font-weight:var(--w-regular);font-size:var(--text-2xs);}

/* ===== Calendar / resource grid ===== */
.cal{display:grid;gap:5px;}
.cal .chead{font-size:var(--text-xs);font-weight:var(--w-medium);text-align:center;padding:6px 0;color:var(--fg-muted);}
.cal .tlab{font-size:var(--text-2xs);color:var(--fg-subtle);text-align:right;padding-right:8px;align-self:center;font-family:var(--font-mono);}
.cell{min-height:34px;border-radius:7px;background:var(--surface-1);border:1px solid var(--border);cursor:pointer;transition:border var(--dur) var(--ease);
  font-size:var(--text-2xs);display:flex;flex-direction:column;justify-content:center;padding:3px 6px;gap:1px;overflow:hidden;}
.cell:hover{border-color:var(--accent);}
.cell.busy{background:var(--accent-ghost);border-color:color-mix(in srgb,var(--accent) 45%,transparent);color:var(--fg);cursor:default;}
.cell.pending{background:var(--pending-ghost);border-color:color-mix(in srgb,var(--pending) 45%,transparent);}
.cell.maint{background:var(--warn-ghost);border-color:color-mix(in srgb,var(--warn) 40%,transparent);
  background-image:repeating-linear-gradient(45deg,transparent,transparent 5px,rgba(245,177,75,.10) 5px,rgba(245,177,75,.10) 10px);cursor:not-allowed;}
.cell.open{background:var(--ok-ghost);border-color:color-mix(in srgb,var(--ok) 35%,transparent);}
.cell.off{background:var(--danger-ghost);border-color:color-mix(in srgb,var(--danger) 22%,transparent);opacity:.6;cursor:not-allowed;}
.cell.buffer{background:repeating-linear-gradient(45deg,transparent,transparent 4px,var(--border) 4px,var(--border) 5px);cursor:not-allowed;opacity:.5;}
.cell b{font-weight:var(--w-medium);}

/* slot chips (booking) */
.slots{display:flex;flex-direction:column;gap:8px;}
.slot{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:var(--radius-md);background:var(--surface-1);border:1px solid var(--border);cursor:pointer;transition:all var(--dur) var(--ease);}
.slot:hover{background:var(--surface-3);border-color:var(--border-strong);}
.slot.sel{border-color:var(--accent);background:var(--accent-ghost);box-shadow:0 0 0 1px var(--accent);}
.slot.off{opacity:.4;cursor:not-allowed;}
.slot .sdot{width:8px;height:8px;border-radius:999px;background:var(--ok);flex-shrink:0;} .slot.off .sdot{background:var(--danger);}

/* cost gate banner */
.gate{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--radius-md);font-size:var(--text-sm);line-height:1.45;}
.gate.free{background:var(--ok-ghost);border:1px solid color-mix(in srgb,var(--ok) 30%,transparent);}
.gate.pay{background:var(--warn-ghost);border:1px solid color-mix(in srgb,var(--warn) 30%,transparent);}
.gate.maint{background:var(--info-ghost);border:1px solid color-mix(in srgb,var(--info) 30%,transparent);}

/* ===== Mobile (student) ===== */
.phone{width:390px;max-width:100%;height:844px;max-height:92vh;border-radius:44px;position:relative;overflow:hidden;margin:0 auto;
  background:var(--canvas);border:1px solid var(--border-strong);box-shadow:var(--shadow-pop);}
.phone .notch{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:120px;height:28px;background:#000;border-radius:999px;z-index:40;}
.appscreen{position:absolute;inset:0;display:none;flex-direction:column;}
.appscreen.active{display:flex;animation:fade var(--dur-slow) var(--ease);}
.statusbar{height:46px;display:flex;align-items:flex-end;justify-content:space-between;padding:0 26px 6px;font-size:var(--text-xs);color:var(--fg-muted);flex-shrink:0;}
.mscroll{flex:1;overflow-y:auto;padding:var(--space-4) var(--space-4) 90px;}
.mscroll::-webkit-scrollbar{display:none;}
.mhead{font-size:var(--text-2xl);font-weight:var(--w-bold);margin:var(--space-2) 0;}
.tabbar{position:absolute;bottom:0;left:0;right:0;height:78px;display:flex;align-items:flex-start;padding:8px 6px 0;z-index:30;
  border-top:1px solid var(--border);background:var(--glass-1);backdrop-filter:blur(var(--blur-heavy));-webkit-backdrop-filter:blur(var(--blur-heavy));}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--fg-subtle);cursor:pointer;font-size:var(--text-2xs);padding-top:4px;
  appearance:none;-webkit-appearance:none;border:0;background:transparent;font-family:inherit;}
.tab .ic{font-size:20px;} .tab.active{color:var(--accent);}
.tab.fab{margin-top:-18px;}
.tab.fab .ic{width:48px;height:48px;border-radius:16px;background:linear-gradient(140deg,var(--accent),var(--accent-press));color:var(--accent-fg);display:grid;place-items:center;box-shadow:var(--shadow-3);font-size:22px;}
.mcard{background:var(--glass-2);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);padding:var(--space-4);margin-bottom:var(--space-3);}
button.mcard{appearance:none;-webkit-appearance:none;font-family:inherit;color:inherit;text-align:left;width:100%;display:block;}
.hero{background:linear-gradient(140deg,color-mix(in srgb,var(--accent) 26%,var(--surface-2)),var(--surface-2));}
.sheet{position:absolute;left:0;right:0;bottom:0;z-index:50;background:var(--glass-3);backdrop-filter:blur(var(--blur-heavy));-webkit-backdrop-filter:blur(var(--blur-heavy));
  border-top:1px solid var(--border-strong);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:var(--shadow-pop);
  transform:translateY(100%);transition:transform var(--dur-slow) var(--ease);max-height:86%;display:flex;flex-direction:column;}
.sheet.open{transform:none;}
.sheet .grab{width:38px;height:4px;border-radius:999px;background:var(--border-strong);margin:10px auto 4px;flex-shrink:0;}
.sheet .shead{padding:var(--space-2) var(--space-5) var(--space-3);} .sheet .sbody{padding:0 var(--space-5) var(--space-5);overflow:auto;}
.msheetscrim{position:absolute;inset:0;background:rgba(0,0,0,.5);z-index:45;display:none;}
.msheetscrim.open{display:block;}

/* notif */
.notif{display:flex;gap:11px;padding:12px;border-radius:var(--radius-md);margin-bottom:10px;background:var(--surface-1);border:1px solid var(--border);}
.notif .nic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:16px;flex-shrink:0;background:var(--accent-ghost);}
.notif.warn .nic{background:var(--warn-ghost);} .notif.info .nic{background:var(--info-ghost);} .notif.ok .nic{background:var(--ok-ghost);}
.notif .nt{font-size:var(--text-sm);font-weight:var(--w-medium);} .notif .nm{font-size:var(--text-xs);color:var(--fg-muted);margin-top:3px;line-height:1.45;} .notif .nw{font-size:var(--text-2xs);color:var(--fg-subtle);margin-top:5px;}
.unread{width:7px;height:7px;border-radius:999px;background:var(--accent);flex-shrink:0;margin-top:5px;}

/* daystrip */
.daystrip{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;}
.daystrip::-webkit-scrollbar{display:none;}
.day{min-width:48px;text-align:center;padding:9px 0;border-radius:var(--radius-md);background:var(--surface-1);border:1px solid var(--border);cursor:pointer;flex-shrink:0;
  appearance:none;-webkit-appearance:none;font-family:inherit;color:inherit;}
.day.on{background:linear-gradient(140deg,var(--accent),var(--accent-press));border-color:transparent;color:var(--accent-fg);}
.day .dn{font-size:var(--text-2xs);color:var(--fg-subtle);} .day.on .dn{color:rgba(255,255,255,.8);}
.day .dd{font-size:var(--text-lg);font-weight:var(--w-bold);font-family:var(--font-mono);}
.day .ddot{width:5px;height:5px;border-radius:999px;background:var(--accent);margin:3px auto 0;} .day.on .ddot{background:#fff;}

.divider{height:1px;background:var(--border);margin:var(--space-4) 0;}
.empty{text-align:center;padding:var(--space-10) var(--space-5);color:var(--fg-subtle);}
.empty .ei{font-size:40px;margin-bottom:var(--space-3);display:inline-flex;color:var(--fg-subtle);}
.empty .et{font-size:var(--text-sm);font-weight:var(--w-medium);color:var(--fg-muted);}
.empty .es{font-size:var(--text-xs);color:var(--fg-subtle);margin-top:4px;}
.empty.err .ei{color:var(--danger);}
.empty.err .et{color:var(--fg);}

/* ===== Live-data states: skeleton · spinner · empty · error ===== */
/* Shimmering skeleton blocks (used while VcmApi.boot is fetching). */
.skel{display:block;border-radius:var(--radius-sm);background:var(--surface-3);position:relative;overflow:hidden;}
.skel::after{content:"";position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--fg) 8%,transparent),transparent);
  animation:skel 1.25s var(--ease) infinite;}
@keyframes skel{100%{transform:translateX(100%);}}
.skel-line{height:10px;margin:6px 0;}
.skel-pill{height:18px;width:64px;border-radius:999px;}
.skel-av{width:28px;height:28px;border-radius:8px;flex-shrink:0;}
.skel-num{height:30px;width:52px;border-radius:var(--radius-sm);}
/* skeleton table row: keep table rhythm while loading */
table.tbl td .skel-line{margin:0;}

/* Inline spinner for headers / buttons (ringed accent, respects reduced-motion) */
.spinner{display:inline-block;width:16px;height:16px;border-radius:999px;flex-shrink:0;
  border:2px solid var(--border-strong);border-top-color:var(--accent);animation:spin .7s linear infinite;}
.spinner.sm{width:13px;height:13px;border-width:2px;}
@keyframes spin{to{transform:rotate(360deg);}}
.loadrow{display:flex;align-items:center;justify-content:center;gap:var(--space-2);
  padding:var(--space-6) var(--space-5);color:var(--fg-subtle);font-size:var(--text-sm);}

/* live-status pip in the topbar (driven by data-vcm-live on <html>) */
.livedot{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-2xs);color:var(--fg-subtle);
  font-weight:var(--w-medium);letter-spacing:.04em;text-transform:uppercase;}
.livedot::before{content:"";width:7px;height:7px;border-radius:999px;background:var(--fg-disabled);flex-shrink:0;
  box-shadow:0 0 0 0 transparent;transition:background var(--dur) var(--ease);}
[data-vcm-live="1"] .livedot::before{background:var(--ok);box-shadow:0 0 0 3px var(--ok-ghost);}
[data-vcm-live="error"] .livedot::before{background:var(--danger);box-shadow:0 0 0 3px var(--danger-ghost);}
[data-vcm-live="1"] .livedot .lvt::after{content:"Live";}
[data-vcm-live="error"] .livedot .lvt::after{content:"Offline";}
.livedot .lvt::after{content:"Connecting";}

@media (prefers-reduced-motion: reduce){
  .skel::after{animation:none;} .spinner{animation:none;border-top-color:var(--accent);}
}
