:root{
  --bg:#0b0b0d; --panel:#141417; --panel-2:#17171b; --line:#26262b;
  --text:#ededf0; --muted:#8a8a93; --muted-2:#6a6a72;
  --accent:#6d5efc; --accent-soft:#6d5efc22; --danger:#ff6b6b; --ok:#37d399;
  --radius:12px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:var(--bg); color:var(--text);
  font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,sans-serif;
  -webkit-font-smoothing:antialiased; display:flex; height:100vh; overflow:hidden;
}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted)}

/* sidebar — fixed; only main scrolls */
.side{width:236px;height:100vh;flex:0 0 auto;background:#0d0d10;border-right:1px solid var(--line);
  padding:18px 12px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}
.brand{display:flex;align-items:center;gap:9px;padding:6px 8px 18px;font-weight:600;font-size:15px}
.dot{width:24px;height:24px;border-radius:7px;color:#fff;
  background:linear-gradient(135deg,var(--accent),#9b8cff);display:grid;place-items:center;flex:0 0 auto}
.dot .ic-svg{width:14px;height:14px}
.nav{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;
  color:var(--muted);cursor:pointer;font-weight:500;transition:.12s}
.nav:hover{background:#161619;color:var(--text)}
.nav.active{background:var(--accent-soft);color:#fff}
.nav .ic{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;opacity:.85;flex:0 0 auto}
.nav.active .ic,.nav:hover .ic{opacity:1}
.ic-svg{width:18px;height:18px;display:block}
.side .spacer{flex:1}
.side .foot{color:var(--muted-2);font-size:12px;padding:8px}
.logout{background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;padding:8px;text-align:left}
.logout:hover{color:var(--text)}

/* mobile top bar + drawer backdrop — hidden on desktop, shown under 760px */
.topbar{display:none}
.backdrop{display:none}

/* main */
.main{flex:1;height:100vh;overflow-y:auto;padding:34px 40px}
.wrap{max-width:880px}
.head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:16px}
h1{font-size:24px;font-weight:650;margin:0}
.sub{color:var(--muted);margin-top:4px;font-size:13px}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:6px}
.card.pad{padding:20px}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-weight:500;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:12px 14px}
td{padding:13px 14px;border-top:1px solid var(--line)}
tr:first-child td{border-top:none}
.ref{color:var(--muted);font-variant-numeric:tabular-nums}
.empty{padding:48px;text-align:center;color:var(--muted)}
.table-wrap{overflow-x:auto}

button{font:inherit;cursor:pointer;border-radius:8px;border:1px solid transparent;padding:8px 14px;font-weight:550}
.btn{background:var(--accent);color:#fff}
.btn:hover{filter:brightness(1.08)}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--text)}
.btn.ghost:hover{background:#161619}
.btn.sm{padding:6px 10px;font-size:13px}
.link-danger{color:var(--danger);background:none;border:none;cursor:pointer;font-weight:550}
.lnk{color:var(--muted);background:none;border:none;cursor:pointer;font-weight:550;padding:2px 4px}
.lnk:hover{color:var(--text)}
.lnk.ok{color:var(--ok)}
.bk-actions{text-align:right;white-space:nowrap}
.bk-actions .lnk,.bk-actions .link-danger{margin-left:8px}
.bk-edit-row td{background:#0f0f12}
input,select,textarea{font:inherit;background:#0f0f12;border:1px solid var(--line);color:var(--text);
  border-radius:8px;padding:8px 11px;outline:none;min-width:0}
textarea{width:100%;resize:vertical;line-height:1.5}
input:focus,select:focus,textarea:focus{border-color:var(--accent)}
.req-detail{display:flex;flex-direction:column;gap:6px;font-size:13.5px;
  border-top:1px solid var(--line);padding-top:12px}
.req-detail > div{display:flex;gap:10px}
.req-detail > div .muted{min-width:110px;flex:0 0 auto}
input[type=time],input[type=date]{color-scheme:dark}
label{display:block;color:var(--muted);font-size:12px;margin:0 0 6px 2px}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.seg{display:inline-flex;background:#0f0f12;border:1px solid var(--line);border-radius:9px;padding:3px}
.seg a{color:var(--muted);padding:5px 12px;border-radius:7px;font-size:13px}
.seg a.on{background:var(--accent-soft);color:#fff}
.pill{font-size:11px;padding:3px 9px;border-radius:999px;background:#1c1c22;color:var(--muted)}
.pill.ok{background:#103a2c;color:var(--ok)} .pill.bad{background:#3a1414;color:var(--danger)}
.pill.warn{background:#3a2e10;color:#f2b53b}
tr.due td{background:#241515}
.flash{color:var(--ok);font-size:13px;margin-left:4px}
.ro-field{background:#0c0c0f;border:1px dashed var(--line);color:var(--muted);border-radius:8px;
  padding:8px 11px;font-size:13px}
a.link{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.err{color:var(--danger);font-size:13px;min-height:18px}

/* hours / capacity rows + interval chips + toggle */
.day-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px 14px;padding:10px 2px;border-top:1px solid var(--line)}
.day-row:first-child{border-top:none}
.day-row .day{width:96px;font-size:13.5px;flex:0 0 auto}
.chips{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-left:auto;justify-content:flex-end;min-width:0}
.chips form{display:inline-flex;flex-wrap:wrap;align-items:center;gap:5px}
.iv{display:inline-flex;align-items:center;gap:6px;background:#0f0f12;border:1px solid var(--line);border-radius:8px;padding:3px 8px;font-size:13px}
.iv .cap{color:var(--accent);font-weight:600}
.iv-rm{background:none;border:none;color:var(--muted-2);cursor:pointer;padding:0 1px;font-size:12px;line-height:1}
.iv-rm:hover{color:var(--danger)}
/* compact inputs inside hours/capacity rows (chips AND the add-form) */
.chips input[type=time]{padding:4px 7px;font-size:12.5px}
.chips input[type=number]{width:52px;padding:4px 6px;font-size:12.5px}

/* themed time picker (button + popover) */
.tp{position:relative;display:inline-block}
.tp-btn{background:#0f0f12;border:1px solid var(--line);color:var(--text);border-radius:8px;
  padding:5px 12px;font-size:12.5px;font-weight:500;font-variant-numeric:tabular-nums;
  min-width:64px;text-align:center;transition:border-color .12s}
.tp-btn:hover{border-color:var(--muted-2)}
.tp.open .tp-btn{border-color:var(--accent);background:#141417}
.tp-pop{position:absolute;z-index:60;top:calc(100% + 5px);left:0;display:flex;gap:3px;
  background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:5px;
  box-shadow:0 14px 34px rgba(0,0,0,.55)}
.tp-col{display:flex;flex-direction:column;gap:2px;max-height:212px;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.tp-col::-webkit-scrollbar{width:7px}
.tp-col::-webkit-scrollbar-thumb{background:var(--line);border-radius:7px}
.tp-col.tp-mins{border-left:1px solid var(--line);padding-left:3px;margin-left:1px}
.tp-cell{padding:5px 14px;border-radius:6px;font-size:12.5px;cursor:pointer;color:var(--muted);
  font-variant-numeric:tabular-nums;text-align:center;user-select:none;transition:.1s}
.tp-cell:hover{background:#1f1f26;color:var(--text)}
.tp-cell.sel{background:var(--accent-soft);color:#fff;font-weight:600}
.chips .add-iv{padding:5px 9px;font-size:12px}
.add-iv{background:none;border:1px dashed var(--line);color:var(--muted);border-radius:8px;padding:5px 10px;cursor:pointer;font-size:12px}
.add-iv:hover{color:var(--text);border-color:var(--muted-2)}
.closed-lbl{color:var(--muted-2);font-size:13px}
.iv .unit{color:var(--muted);font-size:10.5px;line-height:1.15;max-width:76px;white-space:normal;text-align:left}

/* services / menu cards */
.svc-name{font-weight:600;font-size:14.5px;color:var(--text);background:transparent;
  border:1px solid transparent;border-radius:7px;padding:4px 8px;width:auto;min-width:150px;max-width:60%}
.svc-name:hover{border-color:var(--line)}
.svc-name:focus{border-color:var(--accent);background:#0f0f12}
.svc-set{gap:26px;margin-bottom:4px}
.svc-set .fld label,.svc-avail > label{display:block;color:var(--muted);font-size:11px;
  text-transform:uppercase;letter-spacing:.05em;margin:0 0 6px 1px}
.svc-set .inline{display:inline-flex;align-items:center;gap:7px}
.svc-set input{background:#0f0f12;border:1px solid var(--line);border-radius:8px;padding:6px 9px;font-size:13px}
.svc-avail{border-top:1px solid var(--line);padding-top:13px;margin-top:11px}
.svc-avail .chips{margin-left:0;justify-content:flex-start}

/* exceptions */
.exc-new{margin-bottom:16px}
.exc-new .row{align-items:flex-end;gap:14px}
.exc-list{display:flex;flex-direction:column;gap:12px}
.exc-card{padding:16px 18px}
.exc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;
  padding-bottom:10px;border-bottom:1px solid var(--line)}
.exc-date{font-weight:600;font-size:14.5px}
.exc-kind{margin-right:9px;text-transform:none;letter-spacing:0;font-weight:600}
.exc-kind.hrs{background:#13321f;color:var(--ok)}
.exc-kind.cap{background:#1b2547;color:#9db4ff}
.exc-note{width:100%;margin:0 0 8px;font-size:12.5px;padding:6px 10px;background:#0f0f12}
.exc-card .chips{margin-left:0;justify-content:flex-start}
.exc-card .day-row{padding:9px 2px}
.exc-card .day-row .day{width:104px;color:var(--muted)}

/* billing */
.usage{margin-top:16px}
.usage-row{display:flex;justify-content:space-between;font-size:13px;color:var(--muted)}
.bar{height:7px;background:#0f0f12;border:1px solid var(--line);border-radius:6px;overflow:hidden;margin-top:6px}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#9b8cff)}
.bar-fill.over{background:linear-gradient(90deg,#b3402f,var(--danger))}
.limit-banner{border-color:var(--danger);background:#2a1414;color:#ffd9d4;font-size:13px}
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.plan-card{display:flex;flex-direction:column}
.plan-card.current{border-color:var(--accent)}
.plan-name{font-weight:600;font-size:15px}
.plan-price{font-size:26px;font-weight:700;margin:6px 0}
.plan-price span{font-size:13px;color:var(--muted);font-weight:500}
.plan-feats{list-style:none;padding:0;margin:0 0 14px;color:var(--muted);font-size:13px;line-height:1.95;flex:1}
.plan-feats li::before{content:"✓ ";color:var(--ok)}
@media (max-width:760px){.plan-grid{grid-template-columns:1fr}}

/* ── landing page ─────────────────────────────────────────────────────────── */
body.lp{display:block;height:auto;overflow-x:hidden;overflow-y:auto;
  background:radial-gradient(1100px 560px at 72% -8%, #1b1733 0%, var(--bg) 55%)}
.lp a{color:inherit;text-decoration:none}
.lp .btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;
  border-radius:11px;padding:12px 22px;font-weight:600;font-size:14.5px;line-height:1;transition:.15s}
.lp .btn.sm{border-radius:9px;padding:9px 16px;font-size:13.5px}
.lp .btn:not(.ghost){box-shadow:0 8px 24px rgba(109,94,252,.32)}
.lp .btn:hover{transform:translateY(-1px)}
.lp .btn:not(.ghost):hover{box-shadow:0 10px 30px rgba(109,94,252,.45)}
.lp .btn.ghost:hover{border-color:var(--muted-2)}
.lp-nav{display:flex;align-items:center;justify-content:space-between;max-width:1080px;margin:0 auto;padding:20px 24px}
.lp-brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px}
.lp-links{display:flex;align-items:center;gap:18px}
.lp-links a{color:var(--muted);font-size:14px}
.lp-links a:hover{color:var(--text)}
.lp-hero{max-width:1080px;margin:0 auto;padding:44px 24px 36px;display:grid;
  grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.lp-eyebrow{color:#9b8cff;font-size:12px;font-weight:700;letter-spacing:.14em;margin-bottom:14px}
.lp-hero h1{font-size:46px;line-height:1.07;font-weight:730;margin:0 0 16px;letter-spacing:-.01em}
.lp-hero p{color:var(--muted);font-size:16px;line-height:1.6;margin:0 0 22px;max-width:470px}
.lp-cta{display:flex;gap:12px;flex-wrap:wrap}
.lp-note{color:var(--muted-2);font-size:12.5px;margin-top:14px}
.shot-frame{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel);
  box-shadow:0 30px 80px rgba(0,0,0,.5)}
.shot-frame img{display:block;width:100%;height:auto}
.lp-features{max-width:1080px;margin:34px auto;padding:0 24px;display:grid;
  grid-template-columns:repeat(4,1fr);gap:16px}
.lp-feat{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px}
.lp-ic{display:inline-flex;width:38px;height:38px;border-radius:10px;background:var(--accent-soft);
  color:var(--accent);align-items:center;justify-content:center;margin-bottom:12px}
.lp-ic .ic-svg{width:20px;height:20px}
.lp-feat h3{margin:0 0 6px;font-size:15px}
.lp-feat p{margin:0;color:var(--muted);font-size:13.5px;line-height:1.55}
.lp-show{max-width:1080px;margin:48px auto;padding:0 24px;display:flex;flex-direction:column;gap:52px}
.lp-row{display:grid;grid-template-columns:1.15fr .85fr;gap:42px;align-items:center}
.lp-row.reverse{grid-template-columns:.85fr 1.15fr}
.lp-row.reverse .shot-frame{order:2}
.lp-row-text h2{font-size:26px;margin:0 0 10px;letter-spacing:-.01em}
.lp-row-text p{color:var(--muted);font-size:15px;line-height:1.6;margin:0}
.lp-pricing{max-width:1080px;margin:64px auto 10px;padding:0 24px;text-align:center}
.lp-pricing h2{font-size:30px;margin:0 0 6px;letter-spacing:-.01em}
.lp-pricing .lp-sub{color:var(--muted);margin:0 0 28px}
.lp-plans{text-align:left}
.plan-card.featured{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-soft)}
.lp-final{max-width:760px;margin:64px auto;padding:36px 24px;text-align:center}
.lp-final h2{font-size:28px;margin:0 0 8px;letter-spacing:-.01em}
.lp-final p{margin:0 0 20px}
.lp-foot{max-width:1080px;margin:30px auto;padding:20px 24px;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;color:var(--muted-2);font-size:13px}
.lp-foot a{color:var(--muted);text-decoration:underline;text-underline-offset:2px}
@media (max-width:860px){
  .lp-hero,.lp-row,.lp-row.reverse{grid-template-columns:1fr}
  .lp-row.reverse .shot-frame{order:0}
  .lp-features{grid-template-columns:1fr 1fr}
  .lp-hero h1{font-size:34px}
  .lp-plans{grid-template-columns:1fr}
}
@media (max-width:560px){ .lp-features{grid-template-columns:1fr} .lp-links a:not(.btn){display:none} }

/* auth pages */
.auth-wrap{flex:1;display:grid;place-items:center;height:100vh}
.login{width:340px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:28px}
.login .brand{justify-content:center;font-size:17px;padding-bottom:20px}
.login input{width:100%;margin-bottom:12px}
.login button{width:100%}
.onb-label{color:var(--muted);font-size:12px;margin:2px 2px 8px}
.onb-choice{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.onb-tile{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:3px;
  padding:14px 8px;border:1px solid var(--line);border-radius:11px;background:#0f0f12;cursor:pointer;transition:.12s}
.onb-tile:hover{border-color:var(--muted-2)}
.onb-tile input{position:absolute;opacity:0;pointer-events:none}
.onb-tile:has(input:checked){border-color:var(--accent);background:var(--accent-soft)}
.onb-ic{display:inline-flex;width:34px;height:34px;border-radius:9px;align-items:center;justify-content:center;
  background:#17171b;color:var(--muted);margin-bottom:2px}
.onb-tile:has(input:checked) .onb-ic{color:#fff;background:var(--accent)}
.onb-ic .ic-svg{width:18px;height:18px}
.onb-t{font-weight:600;font-size:13.5px}
.onb-d{color:var(--muted);font-size:11.5px}
.login .switch{text-align:center;color:var(--muted);font-size:13px;margin-top:16px}
.login .switch a{color:var(--accent)}
.legal{color:var(--muted-2);font-size:12px;text-align:center;margin-top:18px;line-height:1.6}
.legal a{color:var(--muted);text-decoration:underline;text-underline-offset:2px}
.legal a:hover{color:var(--text)}

/* htmx */
.htmx-indicator{opacity:0;transition:opacity .2s}
.htmx-request .htmx-indicator,.htmx-request.htmx-indicator{opacity:1}

/* ── mobile (≤760px): drawer nav, full-width content, stacked forms ───────── */
@media (max-width:760px){
  /* page scrolls naturally; sidebar becomes a slide-in drawer */
  body{display:block;height:auto;min-height:100vh;overflow:auto}

  .topbar{display:flex;align-items:center;gap:10px;position:fixed;top:0;left:0;right:0;height:52px;
    z-index:45;background:#0d0d10;border-bottom:1px solid var(--line);padding:0 12px}
  .topbar-brand{display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px}
  .hamb{background:none;border:none;color:var(--text);font-size:22px;line-height:1;padding:4px 8px;cursor:pointer}

  .side{position:fixed;top:0;left:0;z-index:55;width:250px;max-width:84vw;height:100vh;
    transform:translateX(-100%);transition:transform .22s ease;box-shadow:0 0 46px rgba(0,0,0,.6)}
  body.nav-open .side{transform:none}
  .backdrop{display:block;position:fixed;inset:0;z-index:50;background:rgba(0,0,0,.55);
    opacity:0;pointer-events:none;transition:opacity .2s}
  body.nav-open .backdrop{opacity:1;pointer-events:auto}

  .main{height:auto;min-height:calc(100vh - 52px);overflow:visible;padding:70px 16px 36px}
  .wrap{max-width:none}
  .head{flex-wrap:wrap;align-items:flex-start}
  h1{font-size:21px}
  .grid2{grid-template-columns:1fr}
  .seg, .seg a{flex:0 0 auto}

  /* hours/capacity/exceptions: day label on its own line, chips left-aligned */
  .day-row .day{width:100%}
  .chips{margin-left:0;justify-content:flex-start}

  /* form rows: one field per line, full-width controls + buttons */
  .card .row{gap:12px}
  .card .row > div{flex:1 1 100%}
  .card .row > div input,.card .row > div select{width:100%}
  .card .row > button{width:100%}

  /* data tables scroll sideways instead of crushing columns */
  .table-wrap{-webkit-overflow-scrolling:touch}
  .table-wrap table{min-width:500px}
  th,td{padding:10px 12px}

  /* roomier tap targets */
  .tp-cell{padding:8px 16px;font-size:13px}
  .tp-pop{max-width:calc(100vw - 24px)}
  .iv-rm{padding:4px 6px;font-size:14px}

  .login{max-width:92vw}
}
