:root{
  --bg:#0b0b0c; --panel:#141416; --panel2:#1c1c20; --line:#2a2a30;
  --text:#ece8df; --muted:#8b8b95; --red:#d2232a;
  --open:#3ec98b; --mine:#e0b73a; --booked:#3a3a42;
  --r:16px; --safe: env(safe-area-inset-bottom, 0px);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
[hidden]{display:none!important}
html,body{margin:0;background:var(--bg);color:var(--text);font-size:16px;line-height:1.45}
h2{font-size:15px;margin:0;font-weight:600;letter-spacing:.02em}
h3{margin:0;font-size:17px}
.muted{color:var(--muted)}
.x{color:var(--red);font-weight:700}

/* gate */
.gate{min-height:100dvh;display:grid;place-items:center;padding:24px}
.gate-card{width:100%;max-width:360px;text-align:center}
.brand{font-size:24px;font-weight:700;letter-spacing:.04em}
.brand.sm{font-size:17px}
.brand-sub{color:var(--muted);margin:6px 0 26px;font-size:14px}
#passcode{width:100%;padding:16px;font-size:17px;border-radius:14px;border:1px solid var(--line);background:var(--panel);color:var(--text);text-align:center;margin-bottom:12px}
.btn{border:0;border-radius:14px;padding:15px 18px;font-size:16px;font-weight:600;cursor:pointer;background:var(--panel2);color:var(--text)}
.btn.primary{background:var(--red);color:#fff}
.btn.full{width:100%}
.btn:active{transform:scale(.985)}
.msg{min-height:20px;margin-top:10px;font-size:13.5px;color:var(--red)}
.msg.ok{color:var(--open)}

/* app shell */
.app{max-width:560px;margin:0 auto;padding:0 14px calc(40px + var(--safe))}
.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;
  padding:14px 2px;background:linear-gradient(var(--bg),rgba(11,11,12,.85));backdrop-filter:blur(8px)}
.top-actions{display:flex;align-items:center;gap:8px}
.chip{border:1px solid var(--line);background:var(--panel);color:var(--text);border-radius:999px;padding:8px 12px;font-size:13px;cursor:pointer;min-height:36px}
.sync{font-size:11.5px;color:var(--muted)}

.strip{display:flex;gap:8px;overflow-x:auto;padding:4px 0 12px;scrollbar-width:none}
.strip::-webkit-scrollbar{display:none}
.strip .d{flex:0 0 auto;min-width:62px;text-align:center;border:1px solid var(--line);border-radius:12px;padding:10px 8px;background:var(--panel)}
.strip .d .dow{font-size:11px;color:var(--muted)}
.strip .d .num{font-size:18px;font-weight:600;margin:2px 0}
.strip .d .st{font-size:10.5px;letter-spacing:.04em}
.strip .d.open{border-color:rgba(62,201,139,.5)} .strip .d.open .st{color:var(--open)}
.strip .d.mine{border-color:rgba(224,183,58,.55)} .strip .d.mine .st{color:var(--mine)}
.strip .d.booked .st{color:var(--muted)}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:14px;margin:10px 0}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.legend{display:flex;gap:14px;align-items:center;font-size:12px;color:var(--muted);margin-bottom:12px}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:5px;vertical-align:middle}
.dot.open{background:var(--open)} .dot.mine{background:var(--mine)} .dot.booked{background:var(--booked);border:1px solid var(--line)}

/* calendar */
.cal-nav{display:flex;align-items:center;gap:10px;margin:2px 0 12px}
.navbtn{flex:0 0 auto;width:42px;height:42px;border-radius:12px;border:1px solid var(--line);background:var(--panel);color:var(--text);font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.navbtn:disabled{opacity:.3;cursor:default}
.navbtn:active:not(:disabled){transform:scale(.95)}
.month-select{flex:1;min-width:0;padding:11px 12px;font-size:15px;font-weight:600;border-radius:12px;border:1px solid var(--line);background:var(--panel);color:var(--text);-webkit-appearance:none;appearance:none;text-align:center;text-align-last:center}
.cal-stat{margin-left:auto;color:var(--open);font-weight:600}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:4px}
.cal .hd{font-size:10.5px;color:var(--muted);text-align:center;padding-bottom:2px}
.cal .cell{aspect-ratio:1;border-radius:11px;border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:14px;background:var(--panel2);min-height:42px}
.cal .cell.pad{border:0;background:transparent}
.cal .cell.open{background:rgba(62,201,139,.12);border-color:rgba(62,201,139,.5);cursor:pointer}
.cal .cell.open:active{background:rgba(62,201,139,.22)}
.cal .cell.mine{background:rgba(224,183,58,.16);border-color:rgba(224,183,58,.55);cursor:pointer}
.cal .cell.booked{background:var(--panel2);color:var(--muted);opacity:.6}
.cal .cell .tag{font-size:9px;margin-top:2px}
.cal .cell.open .tag{color:var(--open)} .cal .cell.mine .tag{color:var(--mine)}

/* bookings + billing */
.bookings .row,.analytics .row{display:flex;justify-content:space-between;gap:10px;padding:11px 0;border-bottom:1px solid var(--line)}
.bookings .row:last-child,.analytics .row:last-child{border-bottom:0}
.bookings .b-main{min-width:0}
.bookings .b-date{font-weight:600}
.bookings .b-sub{font-size:12.5px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bookings .b-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex:0 0 auto}
.pill{font-size:11px;padding:3px 8px;border-radius:999px;border:1px solid var(--line)}
.pill.hold{color:var(--mine);border-color:rgba(224,183,58,.5)}
.pill.confirmed{color:var(--open);border-color:rgba(62,201,139,.5)}
.pill.synced{color:var(--muted)}
.pill.unpaid{color:var(--red);border-color:rgba(210,35,42,.5)}
.b-btns{display:flex;gap:6px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.cancel{background:transparent;border:1px solid var(--line);color:var(--muted);border-radius:10px;padding:6px 10px;font-size:12.5px;cursor:pointer}
.confirm{background:rgba(62,201,139,.14);border:1px solid rgba(62,201,139,.5);color:var(--open);border-radius:10px;padding:6px 10px;font-size:12.5px;cursor:pointer}
.mini{background:transparent;border:1px solid var(--line);color:var(--muted);border-radius:8px;padding:5px 9px;font-size:11.5px;cursor:pointer;min-height:32px}
.hold-note{font-size:12.5px;color:var(--mine);margin-top:10px}
.total-row{display:flex;align-items:baseline;justify-content:space-between;margin:16px 0 2px;padding-top:14px;border-top:1px solid var(--line)}
.total-amt{font-size:21px;font-weight:700}
.cal-hint{font-size:12.5px;margin:-4px 0 10px}
.bookings .b-cli{font-weight:600;font-size:14.5px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bookings .row[data-detail]{cursor:pointer}
.hold-banner{background:rgba(224,183,58,.12);border:1px solid rgba(224,183,58,.45);color:var(--mine);border-radius:12px;padding:11px 13px;font-size:13px;margin-bottom:12px;line-height:1.45}
.hold-banner b{color:var(--mine)}
.btn.danger{background:rgba(210,35,42,.12);color:#ff7a72;border:1px solid rgba(210,35,42,.5)}
#dActions .btn.full{margin-top:10px}
#dBody{margin:4px 0 6px}
.cal .cell.today{box-shadow:inset 0 0 0 2px #5aa0ff}
.strip .d.today{box-shadow:inset 0 0 0 2px #5aa0ff}
.empty{color:var(--muted);font-size:13.5px;padding:8px 0}
.analytics .kpis{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:6px}
.kpi{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:12px}
.kpi .v{font-size:20px;font-weight:700} .kpi .l{font-size:11.5px;color:var(--muted)}

.info-list{list-style:none;margin:0;padding:0;font-size:14px}
.info-list li{padding:8px 0;border-bottom:1px solid var(--line)}
.info-list li:last-child{border-bottom:0} .info-list b{color:var(--muted);font-weight:600;margin-right:8px}
.foot{text-align:center;font-size:12px;padding:18px 0}

/* modal sheet */
.modal{position:fixed;inset:0;z-index:20;background:rgba(0,0,0,.55);display:flex;align-items:flex-end;justify-content:center}
.sheet{width:100%;max-width:560px;background:var(--panel);border-radius:20px 20px 0 0;border:1px solid var(--line);
  padding:18px 16px calc(20px + var(--safe));max-height:92dvh;overflow:auto}
.sheet-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.mDate{color:var(--mine);font-weight:600;margin-bottom:14px}
.lbl{display:block;font-size:12px;color:var(--muted);margin:12px 0 6px}
.fld{width:100%;padding:13px;font-size:16px;border-radius:12px;border:1px solid var(--line);background:var(--panel2);color:var(--text)}
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.tier{border:1px solid var(--line);border-radius:12px;padding:10px 6px;text-align:center;cursor:pointer;background:var(--panel2)}
.tier.sel{border-color:var(--red);background:rgba(210,35,42,.12)}
.tier .t{font-size:12.5px} .tier .c{font-size:13px;font-weight:700;margin-top:3px}
.btn.full{margin-top:18px}
.toast{position:fixed;left:50%;bottom:calc(20px + var(--safe));transform:translateX(-50%);background:var(--panel2);
  border:1px solid var(--line);border-radius:12px;padding:12px 16px;font-size:14px;z-index:30;max-width:90%}

@media(min-width:600px){ .cal .cell{min-height:54px} }
