/* APEX SPINE & INJURY INSTITUTE - Design System v3 (Light / Clinical)
   Bright, professional medical theme. Serif display x clean sans. WCAG 2.1 AA. */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Space+Grotesk:wght@400;500;600&display=swap');

:root{
  --bg:#ffffff; --bg2:#f3f6f9; --bg3:#e9eef3;
  --ink:#0d1422; --muted:#56607380; --muted:#566073; --faint:#8a94a4;
  --accent:#0a7572;          /* text-safe deep teal (AA on white) */
  --accent-bright:#19c3bf;   /* graphics on dark panels / hero */
  --accent2:#6b5cff;
  --grad:linear-gradient(115deg,var(--accent-bright),var(--accent2));
  --line:rgba(13,20,34,.12); --line2:rgba(13,20,34,.05);
  --shadow:0 18px 50px -28px rgba(13,20,34,.35);
  --maxw:1340px;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Space Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
canvas{display:block}
img{max-width:100%;display:block}
.mono{font-family:"SF Mono",ui-monospace,Menlo,Consolas,monospace;letter-spacing:.04em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.6;
  background-image:linear-gradient(var(--line2) 1px,transparent 1px),linear-gradient(90deg,var(--line2) 1px,transparent 1px);
  background-size:92px 92px;-webkit-mask-image:radial-gradient(120% 80% at 50% 0%,#000 20%,transparent 75%);mask-image:radial-gradient(120% 80% at 50% 0%,#000 20%,transparent 75%);}

.skip{position:absolute;left:-999px;top:0;z-index:300;background:var(--accent);color:#fff;padding:12px 20px;font-weight:600;border-radius:0 0 8px 0}
.skip:focus{left:0}
:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

#preloader{position:fixed;inset:0;z-index:400;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;transition:opacity .8s var(--ease),visibility .8s}
#preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.pre-mark{display:flex;align-items:flex-end;gap:5px;height:46px}
.pre-mark i{width:5px;background:var(--grad);border-radius:4px;display:block;animation:prebar 1.1s var(--ease) infinite}
.pre-mark i:nth-child(1){height:18px;animation-delay:0s}.pre-mark i:nth-child(2){height:30px;animation-delay:.1s}
.pre-mark i:nth-child(3){height:46px;animation-delay:.2s}.pre-mark i:nth-child(4){height:30px;animation-delay:.3s}.pre-mark i:nth-child(5){height:18px;animation-delay:.4s}
@keyframes prebar{0%,100%{transform:scaleY(.4);opacity:.5}50%{transform:scaleY(1);opacity:1}}
.pre-txt{font-family:var(--serif);font-size:18px;letter-spacing:.5em;color:var(--ink);padding-left:.5em}
.pre-sub{font-size:10px;letter-spacing:.34em;color:var(--faint)}

@media(hover:hover) and (pointer:fine){
  body{cursor:none}
  a,button,input,select,textarea,.reg,label{cursor:none}
  .cursor{position:fixed;top:0;left:0;z-index:350;pointer-events:none;width:9px;height:9px;border-radius:50%;background:var(--accent);transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s,opacity .25s}
  .cursor-ring{position:fixed;top:0;left:0;z-index:349;pointer-events:none;width:40px;height:40px;border:1px solid rgba(13,20,34,.4);border-radius:50%;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),border-color .3s,opacity .3s}
  .cursor-ring.hot{width:64px;height:64px;border-color:var(--accent)}
  .cursor.hot{width:5px;height:5px}
}

.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

.grain{display:none}
.vignette{display:none}

.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .4s,backdrop-filter .4s,border-color .4s,box-shadow .4s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(255,255,255,.86);backdrop-filter:blur(14px) saturate(150%);border-bottom-color:var(--line);box-shadow:0 10px 30px -22px rgba(13,20,34,.5)}
.nav-inner{display:flex;justify-content:space-between;align-items:center;padding:18px 40px;max-width:var(--maxw);margin:0 auto}
.logo{font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.34em;display:flex;align-items:center;gap:11px;color:var(--ink)}
.logo .mark{width:9px;height:20px;border-radius:5px;background:var(--grad);display:inline-block;box-shadow:0 0 14px rgba(25,195,191,.5)}
.navlinks{display:flex;gap:4px;align-items:center;font-size:13px;letter-spacing:.04em}
.navlinks a{padding:9px 15px;border-radius:999px;color:var(--muted);transition:.3s var(--ease)}
.navlinks a:hover,.navlinks a:focus-visible{color:var(--ink);background:rgba(13,20,34,.06)}
.navlinks a[aria-current="page"]{color:var(--accent)}
.nav-cta{background:var(--ink);color:#fff !important;font-weight:600;padding:11px 20px !important;border-radius:999px}
.nav-cta:hover{background:var(--accent) !important;color:#fff !important}
.menu-btn{display:none;background:none;border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:9px 13px;font-size:13px;font-family:inherit}
/* home: light nav text while over the video hero */
.home .nav:not(.scrolled) .logo{color:#fff}
.home .nav:not(.scrolled) .navlinks a{color:rgba(255,255,255,.84)}
.home .nav:not(.scrolled) .navlinks a:hover{color:#fff;background:rgba(255,255,255,.16)}
.home .nav:not(.scrolled) .navlinks a[aria-current="page"]{color:#fff}
.home .nav:not(.scrolled) .menu-btn{color:#fff;border-color:rgba(255,255,255,.4)}

.btn{display:inline-flex;align-items:center;gap:10px;border:none;font-family:var(--sans);font-size:15px;font-weight:500;letter-spacing:.01em;padding:16px 30px;border-radius:999px;transition:.4s var(--ease);position:relative;overflow:hidden;cursor:pointer}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:var(--accent);color:#fff;transform:translateY(-2px);box-shadow:0 16px 40px -16px rgba(10,117,114,.7)}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

main{position:relative;z-index:2}
.section{padding:130px 0}
.section-sm{padding:84px 0}
.label{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);margin-bottom:24px;display:inline-flex;align-items:center;gap:12px;font-weight:600}
.label::before{content:"";width:26px;height:1px;background:var(--accent);display:inline-block;opacity:.7}
.h1{font-family:var(--serif);font-size:clamp(46px,8vw,116px);font-weight:400;letter-spacing:-.015em;line-height:.94}
.h2{font-family:var(--serif);font-size:clamp(32px,5vw,64px);font-weight:400;letter-spacing:-.012em;line-height:1.04}
.h3{font-family:var(--sans);font-size:22px;font-weight:600;letter-spacing:-.01em}
.lead{max-width:660px;color:var(--muted);font-size:17px;margin-top:26px;line-height:1.7}
.eyebrow{font-size:11px;letter-spacing:.34em;color:var(--accent);text-transform:uppercase}

.hero{position:relative;height:100vh;min-height:660px;width:100%;background:#0a1018;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(6,12,20,.78),rgba(6,12,20,.34) 52%,rgba(6,12,20,.12)),linear-gradient(0deg,rgba(6,12,20,.66),transparent 46%)}
.hero-canvas{position:absolute;inset:0;z-index:1}
.hero-overlay{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:space-between;max-width:var(--maxw);margin:0 auto;padding:140px 40px 54px;pointer-events:none}
.hero-overlay a,.hero-overlay button,.hero-overlay input{pointer-events:auto}
.hero .eyebrow{color:var(--accent-bright)}
.hero-h{margin-top:20px;color:#fff}
.hero-h span{display:block}
.hero-h .stroke{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.hero-bottom{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:26px}
.hero-desc{max-width:400px;font-size:15px;color:rgba(255,255,255,.85);line-height:1.7}
.scrollcue{font-size:10px;letter-spacing:.3em;color:rgba(255,255,255,.8);display:flex;align-items:center;gap:10px}
.scrollcue::before{content:"";width:34px;height:1px;background:rgba(255,255,255,.8);display:inline-block;animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%,100%{transform:scaleX(.35);opacity:.4}50%{transform:scaleX(1);opacity:1}}
.cmd{position:absolute;left:40px;bottom:140px;z-index:3;pointer-events:auto}
.cmd h2{font-size:10px;letter-spacing:.28em;color:rgba(255,255,255,.6);margin-bottom:13px;font-weight:400}
.cmd ul{list-style:none;font-size:13px}
.cmd a{display:block;padding:6px 0;color:rgba(255,255,255,.82);transition:.3s var(--ease)}
.cmd a::before{content:"-> ";color:var(--accent-bright)}
.cmd a:hover,.cmd a:focus-visible{color:#fff;transform:translateX(8px)}

.page-head{padding:184px 0 64px;border-bottom:1px solid var(--line);position:relative;background:var(--bg2)}
.crumbs{font-size:12px;letter-spacing:.14em;color:var(--muted);margin-bottom:22px}
.crumbs a:hover{color:var(--accent)}

.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);margin-top:84px}
.stat{padding:34px 0;border-right:1px solid var(--line);transition:.4s}
.stat:last-child{border-right:none}
.stat:hover{background:linear-gradient(180deg,rgba(10,117,114,.06),transparent)}
.stat .n{font-family:var(--serif);font-size:clamp(34px,4.6vw,60px);font-weight:400;letter-spacing:-.02em;line-height:1;color:var(--ink)}
.stat .n b{font-weight:400;color:var(--accent)}
.stat .t{font-size:12px;color:var(--muted);margin-top:10px;letter-spacing:.02em}

.explore-grid{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line);border-bottom:1px solid var(--line);min-height:88vh}
.explore-left{padding:120px 40px;display:flex;flex-direction:column;justify-content:center;background:var(--bg)}
.explore-right{position:relative;border-left:1px solid var(--line);min-height:560px;background:radial-gradient(70% 70% at 50% 45%,#13202f,#0a1018)}
.spine-canvas{width:100%;height:100%;min-height:560px;touch-action:none}
.hint{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);font-size:10px;letter-spacing:.22em;color:rgba(255,255,255,.5);pointer-events:none;z-index:3}
.region-tag{position:absolute;top:24px;left:24px;font-size:11px;letter-spacing:.2em;color:var(--accent-bright);z-index:3}
.regions{margin-top:38px;border-top:1px solid var(--line)}
.reg{width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--line);color:var(--ink);font-family:inherit;padding:20px 0;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;transition:.4s var(--ease);cursor:pointer}
.reg:hover,.reg:focus-visible{padding-left:14px}
.reg .rn{font-family:var(--serif);font-size:22px;font-weight:400}
.reg .rk{font-size:11px;color:var(--muted);letter-spacing:.18em;display:block;margin-top:3px}
.reg .rd{font-size:13.5px;color:var(--muted);flex-basis:100%;max-height:0;overflow:hidden;opacity:0;transition:.5s var(--ease);line-height:1.6}
.reg[aria-expanded="true"]{padding-left:14px}
.reg[aria-expanded="true"] .rd{max-height:160px;opacity:1;margin-top:14px}
.reg .dot{width:9px;height:9px;border-radius:50%;background:var(--line);transition:.4s;flex-shrink:0}
.reg[aria-expanded="true"] .dot{background:var(--accent);box-shadow:0 0 16px var(--accent)}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:64px;border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.card{background:#fff;padding:44px 32px;position:relative;overflow:hidden;transition:.5s var(--ease)}
.card:hover{background:var(--bg2)}
.card .ix{font-size:11px;color:var(--accent);letter-spacing:.2em;font-weight:600}
.card h3{font-family:var(--serif);font-size:25px;font-weight:400;margin:18px 0 13px;letter-spacing:-.01em}
.card p{font-size:14.5px;color:var(--muted);line-height:1.65}
.card::after{content:"";position:absolute;left:0;bottom:0;height:3px;width:0;background:var(--grad);transition:.6s var(--ease)}
.card:hover::after{width:100%}

.loc{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);margin-top:64px;border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.loc-card{background:#fff;padding:48px 40px;transition:.5s var(--ease)}
.loc-card:hover{background:var(--bg2)}
.loc-card .tagx{font-size:11px;letter-spacing:.2em;color:var(--accent);font-weight:600}
.loc-card h2{font-family:var(--serif);font-size:32px;font-weight:400;margin:14px 0 6px;letter-spacing:-.01em}
.loc-card .addr{color:var(--muted);font-size:15px;line-height:1.6}
.loc-meta{margin-top:30px;border-top:1px solid var(--line);padding-top:26px;display:grid;grid-template-columns:1fr 1fr;gap:18px}
.loc-meta dt{font-size:10px;letter-spacing:.2em;color:var(--faint);text-transform:uppercase}
.loc-meta dd{font-size:15px;margin-top:5px}
.loc-meta a:hover{color:var(--accent)}
.loc-actions{margin-top:32px;display:flex;gap:12px;flex-wrap:wrap}

.form{max-width:700px;margin-top:54px}
.field{margin-bottom:26px}
.field label{display:block;font-size:13px;letter-spacing:.03em;margin-bottom:9px;font-weight:500}
.field .req{color:var(--accent)}
.field input,.field select,.field textarea{width:100%;background:#fff;border:1px solid var(--line);color:var(--ink);font-family:var(--sans);font-size:15px;padding:15px 17px;border-radius:12px;transition:.3s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 4px rgba(10,117,114,.14)}
.field textarea{min-height:130px;resize:vertical}
.field .help{font-size:12px;color:var(--muted);margin-top:7px}
.field .err{font-size:12px;color:#c2410c;margin-top:7px;display:none}
.field[data-invalid="true"] input,.field[data-invalid="true"] select,.field[data-invalid="true"] textarea{border-color:#c2410c}
.field[data-invalid="true"] .err{display:block}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 26px}
.form-note{font-size:12px;color:var(--faint);margin-top:10px}
.success{display:none;border:1px solid var(--accent);background:rgba(10,117,114,.07);border-radius:16px;padding:32px;margin-top:34px}
.success.show{display:block}
.success h3{font-family:var(--serif);color:var(--accent);margin-bottom:10px;font-size:26px;font-weight:400}
.ref-id{font-family:"SF Mono",monospace;color:var(--accent);font-size:18px}

.ask{max-width:580px;margin:46px auto 0;display:flex;border:1px solid var(--line);border-radius:60px;padding:8px 8px 8px 26px;align-items:center;background:#fff;transition:.3s;box-shadow:var(--shadow)}
.ask:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px rgba(10,117,114,.12)}
.ask input{flex:1;background:none;border:none;color:var(--ink);font-size:15px;outline:none;font-family:var(--sans)}
.ask input::placeholder{color:var(--muted)}

.admin-bar{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-top:42px;padding-bottom:26px;border-bottom:1px solid var(--line)}
.admin-bar select,.admin-bar input{background:#fff;border:1px solid var(--line);color:var(--ink);padding:12px 15px;border-radius:10px;font-family:var(--sans);font-size:14px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin:38px 0;border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.kpi{background:#fff;padding:26px}
.kpi .n{font-family:var(--serif);font-size:38px;font-weight:400;color:var(--ink)}
.kpi .t{font-size:11px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;margin-top:5px}
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:14px;background:#fff}
table{width:100%;border-collapse:collapse;min-width:760px}
th,td{text-align:left;padding:15px 17px;border-bottom:1px solid var(--line);font-size:14px}
th{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600;background:var(--bg2)}
tbody tr{transition:.25s}
tbody tr:hover{background:var(--bg2)}
.badge{font-size:11px;padding:4px 11px;border-radius:999px;letter-spacing:.05em;font-weight:600;text-transform:capitalize}
.badge.pending{background:rgba(194,65,12,.12);color:#c2410c}
.badge.confirmed{background:rgba(6,135,90,.12);color:#06875a}
.badge.cancelled{background:rgba(13,20,34,.08);color:var(--muted)}
.row-actions{display:flex;gap:6px;flex-wrap:wrap}
.mini{font-size:12px;padding:7px 12px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--ink);font-family:var(--sans);transition:.25s;cursor:pointer}
.mini:hover{border-color:var(--accent);color:var(--accent)}
.mini.danger:hover{border-color:#c2410c;color:#c2410c}
.empty{padding:64px;text-align:center;color:var(--muted)}

.cta{text-align:center;padding:150px 0;border-top:1px solid var(--line);position:relative;background:var(--bg2)}
.cta::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(50% 80% at 50% 100%,rgba(107,92,255,.08),transparent 70%)}

.footer{border-top:1px solid var(--line);position:relative;z-index:2;background:var(--bg2)}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:60px 40px 34px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
.footer h4{font-size:11px;letter-spacing:.2em;color:var(--faint);text-transform:uppercase;margin-bottom:18px}
.footer ul{list-style:none}
.footer li{margin-bottom:10px;font-size:14px}
.footer li a{color:var(--muted);transition:.25s}
.footer li a:hover{color:var(--ink)}
.footer-brand .logo{margin-bottom:18px}
.footer-brand p{color:var(--muted);font-size:14px;max-width:320px;line-height:1.7}
.footer-base{border-top:1px solid var(--line);padding:24px 40px;max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:11px;color:var(--faint);letter-spacing:.08em}

@media(max-width:920px){
  .wrap,.nav-inner,.hero-overlay,.footer-inner,.footer-base{padding-left:22px;padding-right:22px}
  .explore-grid{grid-template-columns:1fr}
  .explore-right{border-left:none;border-top:1px solid var(--line);min-height:64vh}
  .explore-left{padding:84px 22px}
  .stats,.kpis{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .cards,.loc{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .cmd{display:none}
  .navlinks{display:none;position:absolute;top:64px;right:16px;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;gap:2px;min-width:200px;box-shadow:var(--shadow)}
  .navlinks.open{display:flex}
  .home .nav:not(.scrolled) .navlinks.open a{color:var(--muted)}
  .menu-btn{display:inline-block}
  body{cursor:auto}
  .cursor,.cursor-ring{display:none}
}
@media(max-width:560px){
  .stats,.kpis,.footer-inner{grid-template-columns:1fr}
  .stat{border-right:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  body::before{display:none}
  .reveal{opacity:1;transform:none}
  #preloader{display:none}
  body{cursor:auto}
  .cursor,.cursor-ring{display:none}
  .hero-video{display:none}
}

/* ---------- slot picker / radios (booking) ---------- */
.slot-times{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}
.slot-chip{font-family:var(--sans);font-size:14px;padding:11px 16px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;transition:.2s}
.slot-chip:hover{border-color:var(--accent);color:var(--accent)}
.slot-chip.sel{background:var(--accent);border-color:var(--accent);color:#fff}
.radios{display:flex;gap:24px;flex-wrap:wrap}
.radio{display:inline-flex;align-items:center;gap:9px;font-size:15px;cursor:pointer}
.radio input{width:18px;height:18px;accent-color:var(--accent)}

/* ---------- availability manager (admin) ---------- */
.avbar{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end;margin-top:26px}
.avtimes{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.chk{display:inline-flex;align-items:center;gap:7px;font-size:13px;padding:8px 12px;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer}
.chk input{accent-color:var(--accent)}
.avgroup{border:1px solid var(--line);border-radius:12px;padding:18px 20px;margin-bottom:12px;background:#fff}
.avhead{font-weight:600;font-size:14px;margin-bottom:12px}
.avchips{display:flex;flex-wrap:wrap;gap:8px}
.avchip{display:inline-flex;align-items:center;gap:8px;font-size:13px;padding:6px 10px;border-radius:8px;background:var(--bg2);border:1px solid var(--line)}
.avchip.booked{opacity:.6}
.avchip em{font-style:normal;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.avchip.booked em{color:#c2410c}
.avx{border:none;background:none;color:var(--muted);font-size:16px;line-height:1;cursor:pointer;padding:0 2px}
.avx:hover{color:#c2410c}

/* ---------- AI assistant widget ---------- */
.asst-fab{position:fixed;right:24px;bottom:24px;z-index:200;display:flex;align-items:center;gap:10px;
  background:var(--ink);color:#fff;border:none;border-radius:999px;padding:14px 20px 14px 16px;font-family:var(--sans);
  font-size:14px;font-weight:500;cursor:pointer;box-shadow:0 16px 40px -14px rgba(13,20,34,.55);transition:.3s var(--ease)}
.asst-fab:hover{transform:translateY(-2px);background:var(--accent)}
.asst-fab .ai{width:30px;height:30px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:15px}
.asst-fab.hide{opacity:0;visibility:hidden;transform:scale(.8)}
.asst-panel{position:fixed;right:24px;bottom:24px;z-index:201;width:380px;max-width:calc(100vw - 32px);height:560px;max-height:calc(100vh - 48px);
  background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:0 30px 70px -20px rgba(13,20,34,.5);
  display:none;flex-direction:column;overflow:hidden}
.asst-panel.open{display:flex}
.asst-head{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line);background:var(--bg2)}
.asst-head .ai{width:34px;height:34px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:16px}
.asst-head .nm{font-weight:600;font-size:14px}
.asst-head .st{font-size:11px;color:var(--accent)}
.asst-x{margin-left:auto;background:none;border:none;font-size:22px;color:var(--muted);cursor:pointer;line-height:1}
.asst-x:hover{color:var(--ink)}
.asst-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px;background:var(--bg)}
.asst-msg{max-width:84%;padding:11px 14px;border-radius:14px;font-size:14px;line-height:1.5}
.asst-msg.bot{background:var(--bg2);color:var(--ink);border-bottom-left-radius:4px;align-self:flex-start}
.asst-msg.user{background:var(--ink);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}
.asst-msg a{color:var(--accent);text-decoration:underline}
.asst-quick{display:flex;flex-wrap:wrap;gap:8px;padding:0 18px 14px;background:var(--bg)}
.asst-chip{font-family:var(--sans);font-size:13px;padding:9px 13px;border-radius:999px;border:1px solid var(--accent);
  background:rgba(10,117,114,.06);color:var(--accent);cursor:pointer;transition:.2s}
.asst-chip:hover{background:var(--accent);color:#fff}
.asst-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:#fff}
.asst-input input{flex:1;border:1px solid var(--line);border-radius:999px;padding:11px 15px;font-family:var(--sans);font-size:14px;outline:none;color:var(--ink)}
.asst-input input:focus{border-color:var(--accent)}
.asst-input button{border:none;background:var(--ink);color:#fff;border-radius:50%;width:42px;height:42px;cursor:pointer;font-size:16px;flex-shrink:0}
.asst-input button:hover{background:var(--accent)}
.asst-typing{align-self:flex-start;display:flex;gap:4px;padding:12px 14px;background:var(--bg2);border-radius:14px;border-bottom-left-radius:4px}
.asst-typing span{width:7px;height:7px;border-radius:50%;background:var(--faint);animation:atype 1s infinite}
.asst-typing span:nth-child(2){animation-delay:.15s}.asst-typing span:nth-child(3){animation-delay:.3s}
@keyframes atype{0%,100%{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}
@media(max-width:520px){.asst-panel{right:8px;left:8px;bottom:8px;width:auto;height:calc(100vh - 16px)}.asst-fab{right:14px;bottom:14px}}
@media(prefers-reduced-motion:reduce){.asst-typing span{animation:none}}

/* ---------- calendar ---------- */
.cal-wrap{max-width:420px}
.cal{border:1px solid var(--line);border-radius:16px;padding:16px;background:#fff;box-shadow:var(--shadow)}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cal-title{font-family:var(--serif);font-weight:500;font-size:18px}
.cal-nav{border:1px solid var(--line);background:#fff;border-radius:9px;width:34px;height:34px;cursor:pointer;font-size:17px;color:var(--ink);line-height:1}
.cal-nav:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.cal-nav:disabled{opacity:.3;cursor:default}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.cal-wd{margin-bottom:5px}
.cal-wdc{text-align:center;font-size:11px;letter-spacing:.06em;color:var(--faint);padding:2px 0}
.cal-cell{position:relative;aspect-ratio:1;border:1px solid transparent;border-radius:10px;background:var(--bg2);color:var(--ink);font-family:var(--sans);font-size:14px;cursor:pointer;transition:.15s;display:flex;align-items:center;justify-content:center}
.cal-cell.empty{background:none;border:none;cursor:default}
.cal-cell.off{opacity:.3;cursor:not-allowed;background:none;border-color:transparent}
.cal-cell:not(.off):not(.empty):hover{border-color:var(--accent);color:var(--accent)}
.cal-cell.active{background:var(--accent);color:#fff}
.cal-badge{position:absolute;top:4px;right:5px;font-size:9px;font-weight:600;background:var(--accent);color:#fff;border-radius:999px;padding:0 4px;line-height:14px;min-width:14px;text-align:center}
.cal-cell.active .cal-badge{background:#fff;color:var(--accent)}
.cal-cell.off .cal-badge{display:none}
.cal-editor{border:1px solid var(--line);border-radius:14px;padding:20px;background:#fff;align-self:flex-start}
.cal-editor h4{font-size:15px;margin-bottom:14px;font-weight:600}
.avgrid{display:grid;grid-template-columns:420px 1fr;gap:26px;margin-top:22px;align-items:start}
.chip-doc{display:block;font-size:10px;letter-spacing:.04em;opacity:.75;margin-top:2px}
.slot-chip.sel .chip-doc{opacity:.95}
@media(max-width:820px){.avgrid{grid-template-columns:1fr}.cal-wrap{max-width:100%}}

/* ---------- hero video pause control (a11y) ---------- */
.hero-pause{position:absolute;right:24px;bottom:28px;z-index:4;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.55);background:rgba(6,12,20,.45);color:#fff;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:auto;transition:.25s}
.hero-pause:hover{background:rgba(6,12,20,.72);border-color:#fff}
.hero-pause:focus-visible{outline:3px solid var(--accent-bright);outline-offset:3px}
@media(max-width:560px){.hero-pause{right:14px;bottom:96px}}

/* --- cursor fix: use the normal OS mouse pointer (custom dot was hard to see on white) --- */
.cursor,.cursor-ring{display:none!important}
html,body{cursor:auto!important}
a[href],button,.btn,.mini,.reg,label,select,option,[role=button],.nav-cta,.slot-chip,.radio,.chk,.cal-cell,.cal-nav,.asst-fab,.asst-chip{cursor:pointer!important}
input,textarea{cursor:text!important}
