/* ============================================================
   SPRINT DRIVING SCHOOL — Concept Landing Pages
   Brand: Sprint orange #fb7000/#e87722 · deep navy #1d4354 (aasprint.com.au)
   Type : Sora (display) + Inter (body)
   Motion: Lenis (desktop) + reveal stagger + live layer
   Themes: body.t-dark (navy glass) · body.t-light (daylight) · body.t-bold (orange DR)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@600;700;800&family=Inter:wght@300;400;500;600;700&display=swap');

:root{
  --org:#fb7000; --org-hi:#ff9a3d; --org-lo:#cf5f00; --org-deep:#8a3f00;
  --navy:#1d4354; --navy-deep:#0c2230; --navy-soft:#2c5b72;
  --bg:#091a23; --bg-2:#0f2733; --bg-3:#14323f;
  --ink:#f2f6f8; --ink-soft:#b9c9d1; --ink-mute:#7e939d;
  --line:rgba(255,255,255,.11); --line-org:rgba(251,112,0,.32);
  --glass:linear-gradient(135deg,rgba(255,255,255,.085),rgba(255,255,255,.03) 42%,rgba(255,255,255,.055));
  --glass-flat:rgba(255,255,255,.05);
  --blur:26px; --radius:24px; --radius-sm:16px;
  --shadow:0 30px 90px -34px rgba(0,0,0,.85);
  --inner:inset 0 1px 0 rgba(255,255,255,.14), inset 0 -1px 0 rgba(0,0,0,.3);
  --glow:0 0 0 1px rgba(251,112,0,.45), 0 22px 70px -20px rgba(251,112,0,.4);
  --grad-org:linear-gradient(100deg,var(--org-hi),var(--org) 45%,var(--org-lo));
  --btn-ink:#fff;
  --ease:cubic-bezier(.22,1,.36,1);
  --maxw:1140px;
  --aura1:rgba(251,112,0,.2); --aura2:rgba(44,91,114,.35); --aura3:rgba(251,112,0,.12);
  --green:#37e08b;
}

/* daylight theme — warm white, navy ink, orange accent */
body.t-light{
  --bg:#f7f4ef; --bg-2:#fff; --bg-3:#f0ebe2;
  --ink:#16313f; --ink-soft:#41606f; --ink-mute:#7c919c;
  --line:rgba(22,49,63,.13); --line-org:rgba(251,112,0,.4);
  --glass:linear-gradient(135deg,rgba(255,255,255,.85),rgba(255,255,255,.6) 42%,rgba(255,255,255,.75));
  --glass-flat:rgba(255,255,255,.72);
  --shadow:0 26px 70px -30px rgba(22,49,63,.3);
  --inner:inset 0 1px 0 rgba(255,255,255,.9), inset 0 -1px 0 rgba(22,49,63,.05);
  --aura1:rgba(251,112,0,.14); --aura2:rgba(29,67,84,.10); --aura3:rgba(255,154,61,.14);
}
/* bold direct-response theme — deep orange field */
body.t-bold{
  --bg:#1c0e03; --bg-2:#2a1505; --bg-3:#361c08;
  --ink:#fff4ea; --ink-soft:#e3c4a8; --ink-mute:#a8866b;
  --line:rgba(255,255,255,.13); --line-org:rgba(255,154,61,.4);
  --aura1:rgba(251,112,0,.32); --aura2:rgba(207,95,0,.22); --aura3:rgba(255,154,61,.16);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top:96px}
section[id]{scroll-margin-top:96px}
body{margin:0; background:var(--bg); color:var(--ink);
  font-family:'Inter',system-ui,sans-serif; font-weight:400; line-height:1.6;
  -webkit-font-smoothing:antialiased; overflow-x:hidden}

.bg-aura{position:fixed; inset:-20%; z-index:-2; pointer-events:none}
.bg-aura i{position:absolute; border-radius:50%; filter:blur(90px); opacity:.55; will-change:transform}
.bg-aura i:nth-child(1){width:52vw;height:52vw; left:60%; top:-18%;
  background:radial-gradient(circle,var(--aura1),transparent 65%); animation:aura1 26s var(--ease) infinite alternate}
.bg-aura i:nth-child(2){width:44vw;height:44vw; left:-12%; top:4%;
  background:radial-gradient(circle,var(--aura2),transparent 65%); animation:aura2 32s var(--ease) infinite alternate}
.bg-aura i:nth-child(3){width:50vw;height:50vw; left:28%; top:78%;
  background:radial-gradient(circle,var(--aura3),transparent 65%); animation:aura1 38s var(--ease) infinite alternate-reverse}
@keyframes aura1{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(-6vw,5vh,0) scale(1.18)}}
@keyframes aura2{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(5vw,-4vh,0) scale(1.12)}}

h1,h2,h3,.display{font-family:'Sora',sans-serif; font-weight:800; line-height:1.06; letter-spacing:-.02em; margin:0}
h1{font-size:clamp(2.5rem,6vw,4.6rem); line-height:1.02}
h2{font-size:clamp(1.9rem,4.2vw,3rem)}
h3{font-size:clamp(1.15rem,2.1vw,1.45rem); font-weight:700}
p{margin:0 0 1rem}
.lead{font-size:clamp(1.04rem,1.5vw,1.26rem); color:var(--ink-soft)}
.eyebrow{text-transform:uppercase; letter-spacing:.28em; font-weight:700; font-size:.76rem; color:var(--org)}
.grad{background:var(--grad-org); -webkit-background-clip:text; background-clip:text; color:transparent}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 22px}
section{padding:clamp(56px,9vw,116px) 0; position:relative}
.shead{text-align:center; max-width:780px; margin:0 auto}
.shead p{margin-top:14px}

.glass,.glass-soft{position:relative; background:var(--glass);
  backdrop-filter:blur(var(--blur)) saturate(165%); -webkit-backdrop-filter:blur(var(--blur)) saturate(165%);
  border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--inner),var(--shadow)}
.glass-soft{background:var(--glass-flat); border-radius:var(--radius-sm); box-shadow:var(--inner)}
.glass::before{content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,-40%),rgba(255,255,255,.1),transparent 65%);
  opacity:0; transition:opacity .5s var(--ease)}
.glass:hover::before{opacity:1}
.card-lift{transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease)}
.card-lift:hover{transform:translateY(-5px); border-color:var(--line-org); box-shadow:var(--inner),var(--glow)}

.btn{display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  font-weight:700; font-size:1.02rem; letter-spacing:.01em;
  padding:.95rem 1.9rem; border-radius:999px; text-decoration:none; cursor:pointer;
  border:0; transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .35s;
  position:relative; overflow:hidden; white-space:nowrap; font-family:'Inter',sans-serif}
.btn svg{width:1.05em; height:1.05em; flex:none}
.btn-primary{background:var(--grad-org); color:var(--btn-ink);
  box-shadow:0 14px 40px -12px rgba(251,112,0,.6), inset 0 1px 0 rgba(255,255,255,.4)}
.btn-primary::after{content:""; position:absolute; top:0; left:-80%; width:55%; height:100%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.5),transparent);
  transform:skewX(-20deg); transition:left .7s var(--ease)}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 20px 54px -14px rgba(251,112,0,.75), inset 0 1px 0 rgba(255,255,255,.4)}
.btn-primary:hover::after{left:130%}
.btn-ghost{background:rgba(127,127,127,.1); color:var(--ink); border:1px solid var(--line);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px)}
.btn-ghost:hover{transform:translateY(-2px); border-color:var(--line-org)}
.btn-row{display:flex; gap:14px; flex-wrap:wrap; align-items:center; justify-content:center}

.chip{display:inline-flex; align-items:center; gap:.5em; font-size:.86rem; font-weight:600;
  color:var(--ink-soft); background:var(--glass-flat); border:1px solid var(--line);
  border-radius:999px; padding:.5rem .95rem; backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px)}
.chip svg{width:1em; height:1em; color:var(--org); flex:none}
.badges{display:flex; gap:10px; flex-wrap:wrap; margin-top:24px; justify-content:center}

.concept-strip{position:relative; z-index:60; text-align:center;
  font:600 11.5px/1.5 'Inter',sans-serif; letter-spacing:.2em; text-transform:uppercase;
  color:var(--org); background:rgba(9,26,35,.85); border-bottom:1px solid var(--line-org);
  padding:9px 14px; backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px)}
body.t-light .concept-strip{background:rgba(255,255,255,.85)}
.concept-strip a{color:var(--ink-soft); text-decoration:none}
.concept-strip a:hover{color:var(--org)}

.navbar{position:fixed; top:14px; left:50%; transform:translateX(-50%); z-index:90;
  width:min(calc(100% - 24px),1080px); transition:transform .55s var(--ease), opacity .45s var(--ease)}
.navbar.nav-hide{transform:translate(-50%,-160%); opacity:0; pointer-events:none}
.navbar .bar{display:flex; align-items:center; gap:18px;
  background:linear-gradient(135deg,rgba(15,39,51,.78),rgba(9,26,35,.66));
  backdrop-filter:blur(28px) saturate(170%); -webkit-backdrop-filter:blur(28px) saturate(170%);
  border:1px solid var(--line); border-radius:999px; padding:9px 10px 9px 18px;
  box-shadow:var(--inner),0 18px 50px -18px rgba(0,0,0,.8)}
body.t-light .navbar .bar{background:linear-gradient(135deg,rgba(255,255,255,.85),rgba(255,255,255,.7))}
body.t-bold .navbar .bar{background:linear-gradient(135deg,rgba(42,21,5,.82),rgba(28,14,3,.7))}
.navbar .logo{display:flex; align-items:center; gap:10px; text-decoration:none; flex:none}
.navbar .logo img{height:34px; width:auto; display:block}
.navbar .logo span{font-family:'Sora'; font-weight:800; font-size:1.04rem; letter-spacing:-.01em; color:var(--ink)}
.navbar .logo span i{font-style:normal; color:var(--org)}
.navbar nav{display:flex; gap:4px; margin-left:auto}
.navbar nav a{font:600 .88rem/1 'Inter'; color:var(--ink-soft); text-decoration:none;
  padding:.62rem .9rem; border-radius:999px; transition:color .3s, background .3s}
.navbar nav a:hover{color:var(--ink); background:rgba(127,127,127,.12)}
.navbar .btn{padding:.68rem 1.35rem; font-size:.92rem}
@media(max-width:840px){.navbar nav{display:none}.navbar .bar{gap:10px}.navbar .btn{margin-left:auto}}

.dock{position:fixed; left:50%; bottom:max(14px,env(safe-area-inset-bottom)); z-index:90;
  transform:translate(-50%,170%); opacity:0; width:min(calc(100% - 24px),640px);
  transition:transform .6s var(--ease), opacity .5s var(--ease); pointer-events:none}
.dock.show{transform:translate(-50%,0); opacity:1; pointer-events:auto}
body.cta-in-view .dock{transform:translate(-50%,170%); opacity:0; pointer-events:none}
.dock .bar{display:flex; align-items:center; gap:16px;
  background:linear-gradient(135deg,rgba(15,39,51,.82),rgba(9,26,35,.7));
  backdrop-filter:blur(28px) saturate(170%); -webkit-backdrop-filter:blur(28px) saturate(170%);
  border:1px solid var(--line-org); border-radius:999px; padding:10px 10px 10px 22px;
  box-shadow:var(--inner),0 24px 70px -20px rgba(0,0,0,.9), 0 0 50px -18px rgba(251,112,0,.4)}
body.t-light .dock .bar{background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(255,255,255,.78))}
body.t-bold .dock .bar{background:linear-gradient(135deg,rgba(42,21,5,.85),rgba(28,14,3,.74))}
.dock .meta{display:flex; flex-direction:column; gap:2px; min-width:0}
.dock .meta b{font:700 .92rem/1.2 'Inter'; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.dock .meta span{font:600 .68rem/1 'Inter'; letter-spacing:.14em; text-transform:uppercase; color:var(--org)}
.dock .btn{margin-left:auto; flex:none; padding:.8rem 1.5rem; font-size:.95rem}
@media(max-width:480px){.dock .meta b{font-size:.84rem}.dock .btn{padding:.74rem 1.1rem; font-size:.88rem}}

/* hero */
.hero{padding-top:clamp(120px,15vh,168px); padding-bottom:clamp(40px,6vw,70px)}
.hero .shead{max-width:880px}
.hero-img{position:relative; margin:clamp(26px,4.5vw,46px) auto 0; max-width:980px;
  border-radius:clamp(18px,2.6vw,30px); overflow:hidden;
  border:1px solid var(--line); box-shadow:var(--shadow),0 0 90px -28px rgba(251,112,0,.45)}
.hero-img img{display:block; width:100%; aspect-ratio:16/9; object-fit:cover}
.hero-img::after{content:""; position:absolute; inset:0; pointer-events:none; border-radius:inherit;
  background:linear-gradient(to top,rgba(9,26,35,.55),transparent 40%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}
.hero-img .hbadge{position:absolute; z-index:3; display:inline-flex; align-items:center; gap:.5em;
  font:700 .72rem/1 'Inter'; letter-spacing:.16em; text-transform:uppercase; color:#fff;
  background:rgba(0,0,0,.45); border:1px solid rgba(255,255,255,.2); border-radius:999px; padding:.5rem .85rem;
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px)}
.hero-img .hbadge.tl{top:14px; left:16px}
.hero-img .hbadge.br{bottom:14px; right:16px}
.hero-img .hbadge .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:pulse 1.8s infinite}

/* live strip */
.live-strip{display:grid; grid-template-columns:1.25fr 1fr 1fr; gap:0; max-width:980px;
  margin:18px auto 0; padding:0; overflow:hidden}
.live-strip>div{padding:18px 22px; display:flex; flex-direction:column; gap:6px; justify-content:center}
.live-strip>div+div{border-left:1px solid var(--line)}
.live-strip .lbl{font:600 .66rem/1.4 'Inter'; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-mute);
  display:flex; align-items:center; gap:.6em}
.live-strip .lbl .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:pulse 1.8s infinite; flex:none}
.live-strip b{font-family:'Sora'; font-weight:800; font-size:clamp(1.3rem,2.3vw,1.75rem); line-height:1.2; color:var(--ink)}
.live-strip b.org{color:var(--org-hi)}
body.t-light .live-strip b.org{color:var(--org-lo)}
.live-strip small{color:var(--ink-mute); font-weight:600; font-size:.78rem}
.cd{display:flex; gap:12px; align-items:center; margin-top:4px}
.cd>div{display:flex; flex-direction:column; align-items:center; gap:4px}
.cd b{min-width:1.6em; text-align:center; font-variant-numeric:tabular-nums}
.cd span{font:600 .58rem/1 'Inter'; letter-spacing:.16em; color:var(--ink-mute); text-transform:uppercase}
.cd .sep{color:var(--org); font-family:'Sora'; font-weight:800; font-size:1.2rem; opacity:.7; margin-top:-14px}
.spots-bar{height:6px; border-radius:99px; background:rgba(127,127,127,.18); overflow:hidden}
.spots-bar i{display:block; height:100%; width:0; border-radius:99px; background:var(--grad-org);
  transition:width 1.6s var(--ease); box-shadow:0 0 14px rgba(251,112,0,.6)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
@media(max-width:760px){
  .live-strip{grid-template-columns:1fr}
  .live-strip>div{padding:20px 24px; gap:9px}
  .live-strip>div+div{border-left:0;border-top:1px solid var(--line)}
}

/* ticker */
.ticker{overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:rgba(127,127,127,.04); padding:15px 0; position:relative}
.ticker::before,.ticker::after{content:""; position:absolute; top:0; bottom:0; width:90px; z-index:2; pointer-events:none}
.ticker::before{left:0; background:linear-gradient(90deg,var(--bg),transparent)}
.ticker::after{right:0; background:linear-gradient(-90deg,var(--bg),transparent)}
.ticker-track{display:flex; width:max-content; animation:tick 36s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-track span{font-family:'Sora'; font-weight:700; font-size:.95rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-soft); white-space:nowrap; padding-left:26px; display:inline-flex; align-items:center; gap:26px}
.ticker-track span::after{content:"●"; color:var(--org); font-size:.55rem}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* stats */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:clamp(30px,5vw,52px)}
.stat{padding:24px 18px; text-align:center}
.stat b{display:block; font-family:'Sora'; font-weight:800; font-size:clamp(1.8rem,3.5vw,2.7rem); color:var(--org-hi);
  font-variant-numeric:tabular-nums; line-height:1}
body.t-light .stat b{color:var(--org-lo)}
.stat span{display:block; margin-top:8px; font:600 .72rem/1.35 'Inter'; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-mute)}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}

/* imagery */
.imgcard{position:relative; overflow:hidden; border-radius:var(--radius); border:1px solid var(--line);
  box-shadow:var(--shadow); background:var(--bg-2)}
.imgcard img{display:block; width:100%; height:100%; object-fit:cover; transform:scale(1.08); will-change:transform}
.imgcard::after{content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(to top,rgba(9,20,27,.45),transparent 45%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.imgcard .cap{position:absolute; left:16px; bottom:14px; z-index:2;
  font:600 .68rem/1 'Inter'; letter-spacing:.18em; text-transform:uppercase; color:#fff}

/* steps (3-step process) */
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:clamp(28px,4vw,44px); counter-reset:step}
.step{padding:30px 26px; position:relative}
.step .n{display:flex; align-items:center; justify-content:center; width:46px; height:46px; border-radius:14px;
  font-family:'Sora'; font-weight:800; font-size:1.2rem; color:#fff; background:var(--grad-org);
  box-shadow:0 10px 28px -8px rgba(251,112,0,.6); margin-bottom:16px}
.step h3{margin-bottom:8px}
.step p{color:var(--ink-soft); font-size:.97rem; margin:0}
@media(max-width:820px){.steps{grid-template-columns:1fr}}

/* features */
.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:clamp(28px,4vw,44px)}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:clamp(28px,4vw,44px)}
.feat{padding:28px 26px}
.feat .ic{width:46px; height:46px; border-radius:14px; display:flex; align-items:center; justify-content:center;
  background:rgba(251,112,0,.14); border:1px solid var(--line-org); margin-bottom:16px}
.feat .ic svg{width:22px; height:22px; color:var(--org)}
.feat h3{margin-bottom:8px}
.feat p{color:var(--ink-soft); font-size:.96rem; margin:0}
@media(max-width:880px){.grid3{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.grid3,.grid2{grid-template-columns:1fr}}

/* pricing cards */
.prices{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:clamp(28px,4vw,44px); align-items:stretch}
.price{padding:30px 28px; display:flex; flex-direction:column; gap:10px; text-align:center}
.price .ptag{font:700 .68rem/1 'Inter'; letter-spacing:.22em; text-transform:uppercase; color:var(--org)}
.price .amt{font-family:'Sora'; font-weight:800; font-size:clamp(2.2rem,4vw,3rem); line-height:1; color:var(--ink)}
.price .amt small{font-size:.4em; font-weight:700; color:var(--ink-mute)}
.price .was{color:var(--ink-mute); text-decoration:line-through; font-weight:600; font-size:.95rem}
.price ul{margin:8px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:9px; text-align:left}
.price li{display:flex; gap:.6em; color:var(--ink-soft); font-size:.94rem; align-items:flex-start}
.price li svg{width:1.05em; height:1.05em; color:var(--green); flex:none; margin-top:.22em}
.price .btn{margin-top:auto}
.price.hot{border-color:var(--line-org); box-shadow:var(--inner),var(--glow)}
.price .hotb{align-self:center; font:700 .62rem/1 'Inter'; letter-spacing:.14em; text-transform:uppercase;
  color:#fff; background:var(--grad-org); padding:.4rem .7rem; border-radius:999px}
@media(max-width:820px){.prices{grid-template-columns:1fr}}

/* live feed */
.feedwrap{display:grid; grid-template-columns:1fr 1.1fr; gap:24px; align-items:stretch; margin-top:clamp(28px,4vw,44px)}
.feed{padding:24px; display:flex; flex-direction:column; overflow:hidden}
.feed .fhead{display:flex; align-items:center; gap:.6em; font:600 .68rem/1 'Inter'; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-mute); padding-bottom:14px; border-bottom:1px solid var(--line); margin-bottom:6px}
.feed .fhead .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:pulse 1.8s infinite}
.feed-item{display:flex; gap:12px; align-items:flex-start; padding:11px 2px; border-bottom:1px solid var(--line); animation:feedin .6s var(--ease)}
.feed-item:last-child{border-bottom:0}
.feed-item .fic{width:30px;height:30px;border-radius:9px;flex:none;display:flex;align-items:center;justify-content:center;
  background:rgba(251,112,0,.14); border:1px solid var(--line-org)}
.feed-item .fic svg{width:15px;height:15px;color:var(--org)}
.feed-item p{margin:0; font-size:.92rem; color:var(--ink-soft); line-height:1.45}
.feed-item small{color:var(--ink-mute); font-size:.74rem; font-weight:600}
@keyframes feedin{from{opacity:0; transform:translateY(-10px)}to{opacity:1; transform:none}}
@media(max-width:820px){.feedwrap{grid-template-columns:1fr}}

/* instructor / about split */
.coach{display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(26px,4vw,52px); align-items:center}
.coach .imgcard{aspect-ratio:4/5}
@media(max-width:820px){.coach{grid-template-columns:1fr}.coach .imgcard{aspect-ratio:4/3.4}}

/* fit yes/no */
.fit{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:clamp(28px,4vw,44px)}
.fit ul{margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:12px}
.fit li{display:flex; gap:.65em; align-items:flex-start; color:var(--ink-soft); font-size:1rem}
.fit li svg{width:1.15em; height:1.15em; flex:none; margin-top:.18em}
.fit .yes li svg{color:var(--green)}
.fit .no li svg{color:#ff6b6b}
.fit .feat{padding:30px 28px}
@media(max-width:760px){.fit{grid-template-columns:1fr}}

/* quotes */
.quotes{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:clamp(28px,4vw,44px)}
.quote{padding:26px}
.quote .stars{color:var(--org); letter-spacing:.2em; margin-bottom:12px}
.quote p{color:var(--ink-soft); font-size:.97rem; font-style:italic}
.quote .who{display:flex; align-items:center; gap:12px; margin-top:14px}
.quote .av{width:38px;height:38px;border-radius:50%;background:var(--grad-org);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700; flex:none}
.quote .who b{display:block; font-size:.95rem}
.quote .who span{font-size:.78rem; color:var(--ink-mute)}
@media(max-width:820px){.quotes{grid-template-columns:1fr}}

/* suburbs cloud */
.subs{display:flex; flex-wrap:wrap; gap:9px; justify-content:center; margin-top:clamp(26px,4vw,40px); max-width:900px; margin-left:auto; margin-right:auto}
.subs span{font:600 .82rem/1 'Inter'; color:var(--ink-soft); background:var(--glass-flat);
  border:1px solid var(--line); border-radius:999px; padding:.55rem 1rem}
.subs span.hl{color:#fff; background:var(--grad-org); border-color:transparent}

/* CTA panel */
.cta{text-align:center; padding:clamp(44px,7vw,80px) clamp(24px,5vw,70px); overflow:hidden}
.cta::after{content:""; position:absolute; inset:-40% -20%; z-index:-1; pointer-events:none;
  background:radial-gradient(45% 60% at 50% 0%,rgba(251,112,0,.2),transparent 70%)}
.cta .lead{max-width:640px; margin:14px auto 30px}

/* FAQ */
.faq{max-width:760px; margin:clamp(26px,4vw,40px) auto 0; display:flex; flex-direction:column; gap:12px}
.faq details{padding:0; overflow:hidden}
.faq summary{display:flex; align-items:center; justify-content:space-between; gap:16px; cursor:pointer;
  list-style:none; font:600 1.02rem/1.4 'Inter'; color:var(--ink); padding:20px 24px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{font-family:'Sora'; font-weight:800; color:var(--org); transition:transform .4s var(--ease); flex:none}
.faq details[open] summary .pm{transform:rotate(45deg)}
.faq details p{color:var(--ink-soft); padding:0 24px 22px; margin:0; font-size:.97rem}

footer{border-top:1px solid var(--line); padding:48px 0 130px; text-align:center; color:var(--ink-mute); font-size:.92rem}
footer .foot-logo{height:64px; width:auto; margin:0 auto 16px; display:block}
footer a{color:var(--org); text-decoration:none}
footer .disclaimer{font-size:.76rem; max-width:640px; margin:16px auto 0; color:var(--ink-mute); opacity:.85}

/* hub picker */
.pick{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:44px}
.pcard{padding:30px 28px; text-decoration:none; color:var(--ink); display:flex; flex-direction:column; gap:11px}
.pcard .tag{font:700 .7rem/1 'Inter'; letter-spacing:.22em; text-transform:uppercase; color:var(--org)}
.pcard h3{font-size:1.45rem}
.pcard p{color:var(--ink-soft); font-size:.95rem; margin:0; flex:1}
.pcard .best{align-self:flex-start; font:700 .62rem/1 'Inter'; letter-spacing:.14em; text-transform:uppercase;
  color:#fff; background:var(--grad-org); padding:.38rem .65rem; border-radius:999px}
.pcard .go{font:700 .92rem/1 'Inter'; color:var(--org-hi); display:inline-flex; align-items:center; gap:.45em}
.pcard .go svg{width:1em;height:1em; transition:transform .35s var(--ease)}
.pcard:hover .go svg{transform:translateX(4px)}
@media(max-width:820px){.pick{grid-template-columns:1fr}}

/* booking modal */
.bk-ov{position:fixed; inset:0; z-index:200; background:rgba(4,11,15,.78);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  display:flex; align-items:center; justify-content:center; padding:18px; opacity:0; transition:opacity .25s}
.bk{position:relative; width:100%; max-width:480px; background:var(--bg-2);
  border:1px solid var(--line); border-radius:22px; padding:30px 28px;
  box-shadow:0 30px 90px -30px rgba(0,0,0,.9)}
.bk h3{margin-bottom:4px}
.bk .sub{color:var(--ink-soft); font-size:.92rem; margin-bottom:18px}
.bk label{display:block; font:600 .74rem/1 'Inter'; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); margin:14px 0 6px}
.bk input,.bk select{width:100%; font:500 1rem/1.4 'Inter'; color:var(--ink); background:rgba(127,127,127,.1);
  border:1px solid var(--line); border-radius:12px; padding:.8rem 1rem; outline:none}
.bk input:focus,.bk select:focus{border-color:var(--line-org)}
.bk .btn{width:100%; margin-top:20px}
.bk .x{position:absolute; top:12px; right:14px; width:34px; height:34px; border-radius:50%;
  border:1px solid var(--line); background:rgba(127,127,127,.12); color:var(--ink); font-size:18px; cursor:pointer}
.bk .ok{text-align:center; padding:26px 4px}
.bk .ok .tickc{width:60px;height:60px;border-radius:50%;background:var(--grad-org);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.bk .ok .tickc svg{width:28px;height:28px;color:#fff}
.bk .note{font-size:.74rem; color:var(--ink-mute); margin-top:14px; text-align:center}

/* reveal */
.reveal{opacity:1; transform:none}
.js-anim .reveal{opacity:0; transform:translateY(26px); filter:blur(6px);
  transition:opacity .85s var(--ease), transform .85s var(--ease), filter .85s var(--ease)}
.js-anim .reveal.in{opacity:1; transform:none; filter:none}
.js-anim .d1{transition-delay:.08s}.js-anim .d2{transition-delay:.16s}
.js-anim .d3{transition-delay:.24s}.js-anim .d4{transition-delay:.32s}
.js-anim .d5{transition-delay:.4s}.js-anim .d6{transition-delay:.48s}

@media(max-width:600px){
  .wrap{padding:0 18px}
  .hero{padding-top:124px}
  .stat{padding:20px 12px}
  .stat b{font-size:1.7rem}
  .feat,.step{padding:26px 22px}
  .feed{padding:20px 18px}
  .quote{padding:24px 22px}
  .faq summary{padding:18px 20px; font-size:.96rem}
  .faq details p{padding:0 20px 20px}
  .cta{padding:44px 22px}
  footer{padding:44px 0 130px}
}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important; transition:none !important}
  .bg-aura{display:none}
  .reveal{opacity:1 !important; transform:none !important; filter:none !important}
}

.built-by{display:inline-flex; align-items:center; gap:.55em; margin-top:26px;
  font-size:.7rem; font-weight:600; line-height:1; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-mute); text-decoration:none; opacity:.85; transition:opacity .3s}
.built-by img{height:13px; width:auto; display:block}
.built-by b{color:var(--ink-soft); font-weight:700; letter-spacing:.22em}
.built-by:hover{opacity:1}
