/* ===== FORGE — dark-first design system ===== */
@font-face{font-family:"Anton";font-weight:400;font-display:swap;src:url("/static/fonts/anton.woff2") format("woff2")}
@font-face{font-family:"Inter";font-weight:400;font-display:swap;src:url("/static/fonts/inter-400.woff2") format("woff2")}
@font-face{font-family:"Inter";font-weight:600;font-display:swap;src:url("/static/fonts/inter-600.woff2") format("woff2")}
@font-face{font-family:"Inter";font-weight:800;font-display:swap;src:url("/static/fonts/inter-800.woff2") format("woff2")}

/* Tokens — dark is the no-attribute default */
:root,:root[data-theme="dark"]{
  --bg:#0B0B0D; --bg-2:#0F0F12; --surface:rgba(255,255,255,.045); --surface-solid:#15151A;
  --glass-line:rgba(255,255,255,.09); --text:#F4F5F7; --muted:#8A8C93;
  --brand:#C6FF3C; --brand-on:#0A0A0A;
  --brand-glow:color-mix(in srgb,var(--brand) 55%,transparent);
  --brand-weak:color-mix(in srgb,var(--brand) 14%,transparent);
  --brand-hover:color-mix(in srgb,var(--brand) 82%,#fff);
  --accent-2:#FF6A00; --hot:#FF3B30;
  --ok:var(--brand); --ok-bg:color-mix(in srgb,var(--brand) 16%,transparent);
  --warn:#FF6A00; --warn-bg:color-mix(in srgb,#FF6A00 16%,transparent);
  --info:#5AA9FF; --info-bg:color-mix(in srgb,#5AA9FF 16%,transparent);
  --danger:#FF3B30; --danger-bg:color-mix(in srgb,#FF3B30 16%,transparent);
  --radius:18px; --radius-sm:12px; --radius-pill:999px;
  --shadow:0 18px 40px -16px rgba(0,0,0,.6);
  --font-disp:"Anton",system-ui,sans-serif; --font:"Inter",system-ui,-apple-system,sans-serif;
}
/* Forge Light */
:root[data-theme="light"]{
  --bg:#F4F5F7; --bg-2:#FFFFFF; --surface:#FFFFFF; --surface-solid:#FFFFFF;
  --glass-line:#E4E6EB; --text:#14151A; --muted:#5B5E66;
  --brand-on:#0A0A0A; --shadow:0 14px 34px -18px rgba(20,21,26,.25);
}
@media (prefers-color-scheme: light){:root[data-theme="light"]{}}

*{box-sizing:border-box}
html{color-scheme:dark}
body{margin:0;color:var(--text);font:15px/1.55 var(--font);min-height:100vh;-webkit-font-smoothing:antialiased;
  background:
    radial-gradient(900px 500px at 88% -10%, var(--brand-weak), transparent 60%),
    radial-gradient(800px 500px at -10% 110%, color-mix(in srgb,var(--accent-2) 10%,transparent), transparent 60%),
    var(--bg);background-attachment:fixed}
a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}
h1,h2{font-family:var(--font-disp);font-weight:400;letter-spacing:.02em;text-transform:uppercase;margin:0 0 .6rem;line-height:.96}
h1{font-size:2rem}h2{font-size:1.4rem}
.container{max-width:1160px;margin:1.6rem auto;padding:0 1.4rem}
.muted{color:var(--muted)}.error{color:var(--danger)}
.kicker{font-weight:800;letter-spacing:.2em;text-transform:uppercase;font-size:.7rem;color:var(--brand)}

/* Icons */
.icon{width:1em;height:1em;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vertical-align:-.15em;flex:none}

/* Topbar */
.topbar{position:sticky;top:0;z-index:20;backdrop-filter:blur(14px);background:color-mix(in srgb,var(--bg) 68%,transparent);border-bottom:1px solid var(--glass-line)}
.topbar-inner{max-width:1160px;margin:0 auto;display:flex;align-items:center;gap:1rem;padding:.8rem 1.4rem;flex-wrap:wrap}
.brand-logo{display:flex;align-items:center;gap:.55rem;font-family:var(--font-disp);font-size:1.35rem;letter-spacing:.05em;text-transform:uppercase}
.brand-logo .mark{width:32px;height:32px;border-radius:10px;background:var(--brand);color:var(--brand-on);display:grid;place-items:center;font-weight:800;box-shadow:0 0 18px var(--brand-glow)}
nav.main{display:flex;gap:.15rem;flex-wrap:wrap}
nav.main a{display:inline-flex;align-items:center;gap:.35rem;color:var(--muted);padding:.45rem .75rem;border-radius:10px;font-weight:600;font-size:.9rem}
nav.main a:hover{color:var(--text);background:var(--surface);text-decoration:none}
nav.main a.active{color:var(--brand);background:var(--surface);box-shadow:inset 0 -2px 0 var(--brand)}
.spacer{flex:1}
.account{flex-basis:100%;width:100%;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:center}
.userchip{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.9rem}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--accent-2));color:#000;display:grid;place-items:center;font-weight:800}
.theme-toggle{border:1px solid var(--glass-line);background:var(--surface);color:var(--text);border-radius:var(--radius-pill);width:38px;height:34px;cursor:pointer;font-size:1rem}

/* Buttons */
.btn{font:inherit;font-weight:800;letter-spacing:.02em;padding:.6rem 1.1rem;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;justify-content:center;transition:transform .16s,box-shadow .16s,background .16s}
.btn.p{background:var(--brand);color:var(--brand-on)}
.btn.p:hover{background:var(--brand-hover);text-decoration:none;box-shadow:0 0 22px var(--brand-glow)}
.btn.g{background:var(--surface);color:var(--text);border-color:var(--glass-line)}
.btn.g:hover{background:var(--bg-2);text-decoration:none}
.btn.danger{background:transparent;color:var(--danger);border-color:var(--danger-bg)}
.btn:active{transform:translateY(1px)}
.btn.sm{padding:.35rem .8rem;font-size:.85rem}

/* Cards / panels */
.card,.panel{background:var(--surface);border:1px solid var(--glass-line);border-radius:var(--radius);backdrop-filter:blur(10px)}
.card{padding:1.2rem 1.35rem}
.panel{overflow:hidden}
.panel-head{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.3rem;border-bottom:1px solid var(--glass-line)}
.panel-head h2{margin:0}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.2rem;flex-wrap:wrap}
.page-head.center{justify-content:center;text-align:center}
.page-head h1{display:flex;align-items:center;gap:.5rem}

/* Tables */
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:.75rem 1.1rem}
thead th{background:var(--bg-2);color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--glass-line)}
tbody tr{border-bottom:1px solid var(--glass-line)}
tbody tr:hover{background:var(--surface)}

/* Badges */
.badge{display:inline-block;padding:.18rem .6rem;border-radius:var(--radius-pill);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.badge.ok{color:var(--brand);background:var(--ok-bg)}
.badge.warn{color:var(--warn);background:var(--warn-bg)}
.badge.info{color:var(--info);background:var(--info-bg)}

/* Forms */
form{display:grid;gap:.85rem;max-width:34rem;margin-inline:auto}
label{display:grid;gap:.3rem;font-weight:700}
input:not([type=checkbox]):not([type=radio]):not([type=color]),select,textarea{
  width:100%;padding:.6rem .75rem;border:1px solid var(--glass-line);border-radius:var(--radius-sm);
  font:inherit;background:var(--bg-2);color:var(--text)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-weak)}
input[type=checkbox],input[type=radio]{width:auto;margin:0;accent-color:var(--brand);flex:none}
input[type=color]{width:3.2rem;height:2.2rem;padding:.15rem;border:1px solid var(--glass-line);border-radius:var(--radius-sm);background:var(--bg-2);cursor:pointer}
fieldset{border:1px solid var(--glass-line);border-radius:var(--radius-sm);padding:.7rem .9rem;margin:0}
legend{font-weight:800;padding:0 .3rem;text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;color:var(--brand)}
.check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.4rem .9rem;margin-top:.5rem}

/* Alerts */
.alert{border-radius:var(--radius-sm);padding:.7rem 1rem;margin:0 0 1rem;font-weight:700;border:1px solid transparent}
.alert.err{color:var(--danger);background:var(--danger-bg);border-color:var(--danger-bg)}
.alert.ok{color:var(--brand);background:var(--ok-bg);border-color:var(--ok-bg)}

/* ===== Dashboard ===== */
.dash{display:grid;grid-template-columns:1.55fr 1fr;gap:1.3rem;margin-bottom:1.6rem}
/* Cinematic media hero (photo/video background) */
.hero{position:relative;overflow:hidden;border-radius:var(--radius);border:1px solid var(--glass-line);
  padding:1.7rem 1.8rem;min-height:252px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;
  background:var(--bg-2) url("/static/img/hero-lift.jpg") center/cover no-repeat}
.hero-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.6;z-index:0}
.hero-shade{position:absolute;inset:0;z-index:1;
  background:linear-gradient(110deg,rgba(11,11,13,.92) 20%,rgba(11,11,13,.32) 84%),linear-gradient(0deg,rgba(11,11,13,.7),transparent 55%)}
.hero-body{position:relative;z-index:2}
.hero .kicker{color:var(--brand)}
.hero .big{font-family:var(--font-disp);font-size:3rem;line-height:.92;text-transform:uppercase;margin:.3rem 0 .2rem;text-shadow:0 2px 18px rgba(0,0,0,.6)}
.hero .big span{color:var(--brand);text-shadow:0 0 26px var(--brand-glow)}
.hero .streak .v{color:#fff}.hero .streak .v.n{color:var(--brand)}.hero .streak .v.o{color:var(--accent-2)}
.hero .streak .l{color:rgba(255,255,255,.74)}
@media (prefers-reduced-motion: reduce){.hero-media{display:none}}
/* faint full-page photographic atmosphere */
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:url("/static/img/atmosphere.jpg") center/cover no-repeat;opacity:.06}
.streak{display:flex;gap:1.5rem;margin-top:1rem;flex-wrap:wrap}
.streak .v{font-family:var(--font-disp);font-size:1.7rem;line-height:1}
.streak .v.n{color:var(--brand)}.streak .v.o{color:var(--accent-2)}
.streak .l{color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;margin-top:.25rem}
.spotlight{margin-top:1rem;display:flex;align-items:center;gap:1rem;padding:.9rem 1rem;border-radius:14px;background:linear-gradient(100deg,var(--warn-bg),var(--brand-weak));border:1px solid var(--glass-line)}
.spotlight .tag{font-family:var(--font-disp);font-size:1.05rem;color:var(--accent-2)}
.ring-card{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.ring{--p:0;width:168px;height:168px;border-radius:50%;display:grid;place-items:center;position:relative;margin:.8rem 0;
  background:conic-gradient(var(--brand) calc(var(--p)*1%),rgba(255,255,255,.07) 0);filter:drop-shadow(0 0 16px var(--brand-glow));
  animation:ringfill 1.2s cubic-bezier(.2,.8,.2,1) both}
.ring::before{content:"";position:absolute;inset:14px;border-radius:50%;background:var(--bg-2)}
.ring .mid{position:relative;text-align:center}
.ring .pct{font-family:var(--font-disp);font-size:2rem;color:var(--brand)}
.ring .cap{color:var(--muted);font-size:.66rem;text-transform:uppercase;letter-spacing:.14em}
@property --p{syntax:'<number>';inherits:false;initial-value:0}
@keyframes ringfill{from{--p:0}to{--p:var(--ring-p,0)}}

/* ===== The Rig (booking grid) ===== */
.weeknav{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.days{display:flex;gap:.35rem;flex-wrap:wrap}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.7rem}
.daycol{background:var(--surface);border:1px solid var(--glass-line);border-radius:16px;overflow:hidden;min-height:150px}
.dayhd{padding:.5rem .6rem;border-bottom:1px solid var(--glass-line);background:var(--bg-2);font-weight:800;font-size:.78rem;text-align:center;text-transform:uppercase;letter-spacing:.06em}
.dayhd .num{color:var(--muted)}
.daycol.today .dayhd{color:var(--brand)}
.cell{padding:.5rem}
.slot,.sess{position:relative;border:1px solid var(--glass-line);border-left:4px solid var(--ct,var(--brand));border-radius:14px;padding:.6rem .7rem;margin-bottom:.5rem;background:var(--surface);overflow:hidden;transition:transform .16s,box-shadow .16s,border-color .16s}
.slot:hover,.sess:hover{transform:translateY(-3px);border-color:var(--brand-glow);box-shadow:0 16px 36px -16px var(--brand-glow)}
.sess .t,.slot .t{font-family:var(--font-disp);font-size:1.15rem;color:var(--text)}
.sess .n,.slot .n{font-weight:800;margin:.05rem 0 .35rem;display:flex;align-items:center;gap:.4rem}
.sess .dot,.slot .dot{display:inline-block;width:.6rem;height:.6rem;border-radius:50%;background:var(--ct,var(--brand));flex:none}
.sess .meta,.slot .meta{font-size:.74rem;color:var(--muted)}
.slotbar{height:6px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden;margin:.45rem 0 .5rem}
.slotbar b{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--brand),var(--accent-2))}
.bookbtn{display:block;width:100%;margin-top:.35rem;text-align:center;border:none;border-radius:10px;padding:.4rem;font-weight:800;letter-spacing:.03em;background:var(--brand);color:var(--brand-on);cursor:pointer;transition:box-shadow .16s}
.bookbtn:hover{box-shadow:0 0 22px var(--brand-glow)}
.bookbtn.cancel{background:transparent;color:var(--danger);border:1px solid var(--danger-bg)}
.sess-full{opacity:.85}
.sess-full::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.02) 0 10px,transparent 10px 20px);pointer-events:none}
.lockbadge{position:absolute;top:.55rem;right:.6rem;font-size:.62rem;font-weight:800;letter-spacing:.1em;color:var(--hot);text-transform:uppercase}
.sess-past,.sess-cancelled{opacity:.5}
.empty,.empty-state{text-align:center;color:var(--muted)}
.empty-state{padding:2.4rem 1rem}.empty-state .empty-ic{font-size:2.4rem;color:var(--brand);opacity:.7;margin-bottom:.3rem}.empty-state h3{color:var(--text);margin:.3rem 0 .2rem}

/* ===== Stat cards (kept for compatibility) ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.4rem}
.stat{background:var(--surface);border:1px solid var(--glass-line);border-radius:var(--radius);padding:1rem 1.1rem;display:flex;gap:.8rem;align-items:center}
.stat .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:1.2rem;flex:none;background:var(--brand-weak);color:var(--brand)}
.stat .l{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em}
.stat .n{font-family:var(--font-disp);font-size:1.6rem;line-height:1.1}

/* ===== Motion ===== */
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.slot,.sess,.stat,.card{animation:rise .3s ease both}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}
@media(max-width:900px){.dash{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:820px){.cal-grid{grid-template-columns:1fr}.daycol{min-height:0}}
