/* ============================================================
   StreetNet — sections.css
   phone HUD mockup, bento, deep-dives, online, privacy, cta
   ============================================================ */

/* ---------------- iPhone frame ---------------- */
.phone{
  --w:300px;
  position:relative; width:var(--w); margin-inline:auto;
  aspect-ratio:300/620;
  border-radius:46px; padding:11px;
  background:linear-gradient(160deg,#23272f,#0c0e13 60%);
  box-shadow:
    0 2px 2px rgba(255,255,255,.06) inset,
    0 50px 90px -30px rgba(0,0,0,.85),
    0 0 0 1px rgba(255,255,255,.05);
}
.phone::after{ /* side button */
  content:""; position:absolute; right:-2px; top:128px; width:3px; height:54px;
  border-radius:3px; background:#2a2e36;
}
.phone-screen{
  position:relative; width:100%; height:100%; border-radius:36px; overflow:hidden;
  background:radial-gradient(120% 80% at 50% -10%, #0e1626, #07090f 60%);
  display:flex; flex-direction:column;
}
.island{
  position:absolute; top:11px; left:50%; transform:translateX(-50%);
  width:84px; height:24px; border-radius:14px; background:#000; z-index:6;
}
.statusbar{
  display:flex; justify-content:space-between; align-items:center;
  padding:13px 22px 6px; font-size:12px; font-weight:600; color:var(--ink);
  font-family:var(--font-mono);
}
.statusbar .sb-r{ display:flex; gap:6px; align-items:center; }
.statusbar .sb-r i{ width:16px;height:10px;border-radius:2px;border:1px solid var(--ink-mut);
  position:relative; opacity:.8; }
.statusbar .sb-r i::after{ content:""; position:absolute; inset:1.5px; right:5px;
  background:var(--ink); border-radius:1px; }

/* ---- HUD: lap timer screen ---- */
.hud{ flex:1; display:flex; flex-direction:column; padding:6px 16px 16px; gap:12px; min-height:0; }
.hud-top{ display:flex; justify-content:space-between; align-items:flex-start; }
.hud-track{ font-size:12.5px; color:var(--ink-soft); font-weight:600; }
.hud-track small{ display:block; color:var(--ink-faint); font-weight:500; font-size:11px;
  font-family:var(--font-mono); margin-top:2px; letter-spacing:.04em; }
.hud-lap{ text-align:right; font-family:var(--font-mono); }
.hud-lap b{ display:block; font-size:20px; color:var(--orange); line-height:1; }
.hud-lap small{ font-size:10px; color:var(--ink-faint); text-transform:uppercase; letter-spacing:.12em; }

.hud-timer{ text-align:center; margin-top:6px; }
.hud-timer .lbl{ font-family:var(--font-mono); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-faint); }
.hud-timer .big{
  font-family:var(--font-mono); font-weight:800; letter-spacing:-.02em;
  font-size:52px; line-height:1; color:#fff; font-variant-numeric:tabular-nums;
  text-shadow:0 0 28px rgba(77,159,255,.45);
}
.hud-timer .big .ms{ color:var(--blue); }
.hud-delta{ display:inline-flex; align-items:center; gap:6px; margin-top:8px;
  padding:4px 11px; border-radius:999px; font-family:var(--font-mono); font-weight:700;
  font-size:13px; }
.hud-delta.faster{ color:var(--faster); background:rgba(70,224,168,.12); }
.hud-delta .pr{ color:var(--ink-faint); font-weight:500; }

/* mini track map */
.hud-map{ position:relative; margin-top:2px; border-radius:14px; overflow:hidden;
  background:rgba(255,255,255,.025); border:1px solid var(--line);
  padding:10px; }
.hud-map svg{ width:100%; height:auto; display:block; }
.hud-map .mtag{ position:absolute; top:9px; left:11px; font-family:var(--font-mono);
  font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); }

/* sector splits */
.hud-splits{ display:grid; grid-template-columns:repeat(3,1fr); gap:7px; }
.split{ background:rgba(255,255,255,.03); border:1px solid var(--line); border-radius:10px;
  padding:8px 8px; text-align:center; }
.split .s-n{ font-family:var(--font-mono); font-size:9px; letter-spacing:.14em;
  color:var(--ink-faint); text-transform:uppercase; }
.split .s-t{ font-family:var(--font-mono); font-weight:700; font-size:14px; margin-top:3px;
  font-variant-numeric:tabular-nums; }
.split.up .s-t{ color:var(--faster); } .split.down .s-t{ color:var(--slower); }
.split .s-d{ font-family:var(--font-mono); font-size:10px; margin-top:1px; }
.split.up .s-d{ color:var(--faster); } .split.down .s-d{ color:var(--slower); }

/* speed / g readout */
.hud-readout{ display:grid; grid-template-columns:1fr 1fr; gap:7px; margin-top:auto; }
.ro{ background:rgba(255,255,255,.03); border:1px solid var(--line); border-radius:10px;
  padding:9px 11px; }
.ro .ro-l{ font-family:var(--font-mono); font-size:9px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-faint); }
.ro .ro-v{ font-family:var(--font-mono); font-weight:800; font-size:19px; margin-top:2px;
  font-variant-numeric:tabular-nums; }
.ro .ro-v u{ font-size:11px; text-decoration:none; color:var(--ink-mut); font-weight:600; }

/* ---------------- floating hero cards ---------------- */
.fcard{
  position:absolute; pointer-events:auto; z-index:4;
  background:rgba(14,18,27,.82); border:1px solid var(--line-2);
  border-radius:16px; padding:13px 15px; backdrop-filter:blur(14px);
  box-shadow:0 24px 60px -22px rgba(0,0,0,.85), inset 0 1px 0 rgba(255,255,255,.06);
  will-change:transform;
}
.fcard .fc-l{ font-family:var(--font-mono); font-size:10px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-faint); display:flex; align-items:center; gap:6px; }
.fcard .fc-l b{ width:6px;height:6px;border-radius:50%; }
.fcard .fc-v{ font-family:var(--font-mono); font-weight:800; font-variant-numeric:tabular-nums; }

.fcard-record{ top:-3%; left:-12%; }
.fcard-record .fc-l b{ background:var(--orange); box-shadow:0 0 8px 1px rgba(255,122,26,.8); }
.fcard-record .fc-v{ font-size:22px; color:#fff; margin-top:5px; }
.fcard-record .fc-v small{ color:var(--orange); font-size:12px; }
.fcard-record .fc-meta{ font-size:11px; color:var(--ink-mut); margin-top:2px; }

.fcard-g{ bottom:14%; right:-7%; width:126px; }
.fcard-g .fc-l b{ background:var(--blue); box-shadow:0 0 8px 1px rgba(77,159,255,.8); }
.gmini{ position:relative; width:88px; height:88px; margin:8px auto 4px; }
.gmini svg{ width:100%; height:100%; }
.fcard-g .fc-v{ text-align:center; font-size:18px; color:#fff; }
.fcard-g .fc-v small{ font-size:11px; color:var(--ink-mut); }

.fcard-drive{ bottom:-2%; left:-7%; display:flex; align-items:center; gap:11px; }
.fcard-drive .fc-v{ white-space:nowrap; }
.drive-ring{ position:relative; width:46px;height:46px; flex:none; }
.drive-ring svg{ width:100%;height:100%; transform:rotate(-90deg); }
.drive-ring b{ position:absolute; inset:0; display:grid; place-items:center;
  font-family:var(--font-mono); font-weight:800; font-size:15px; color:#fff; }
.fcard-drive .fc-v{ font-size:14px; color:#fff; } 
.fcard-drive .fc-meta{ font-size:11px; color:var(--ink-mut); }

@media (max-width:520px){
  .fcard-record{ left:-2%; } .fcard-g{ right:-4%; transform:scale(.9); }
  .fcard-drive{ left:0; }
}

/* ---------------- stat strip ---------------- */
.strip{ border-block:1px solid var(--line); }
.strip-grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.strip-item{ padding:30px 22px; text-align:center; border-left:1px solid var(--line); }
.strip-item:first-child{ border-left:0; }
.strip-item .s-v{ font-family:var(--font-disp); font-size:clamp(28px,3.6vw,40px); color:#fff;
  line-height:1; }
.strip-item .s-v .u{ color:var(--blue); }
.strip-item .s-l{ margin-top:9px; font-size:13.5px; color:var(--ink-mut); }
@media (max-width:680px){ .strip-grid{ grid-template-columns:1fr 1fr; }
  .strip-item:nth-child(3){ border-left:0; }
  .strip-item:nth-child(odd){ border-left:0; }
  .strip-item{ border-top:1px solid var(--line); }
  .strip-item:nth-child(-n+2){ border-top:0; } }

/* ---------------- bento features ---------------- */
.bento{ display:grid; grid-template-columns:repeat(6,1fr); gap:16px; margin-top:54px; }
.tile{
  position:relative; overflow:hidden; border-radius:var(--radius);
  background:linear-gradient(180deg,var(--panel),var(--bg-2));
  border:1px solid var(--line); padding:26px;
  transition:transform .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
  display:flex; flex-direction:column;
}
.tile:hover{ transform:translateY(-4px); border-color:var(--line-2);
  box-shadow:0 30px 60px -30px rgba(0,0,0,.7); }
.tile::before{ /* hover glow */
  content:""; position:absolute; inset:0; opacity:0; transition:opacity .4s var(--ease);
  background:radial-gradient(420px 200px at var(--mx,50%) 0%, rgba(77,159,255,.12), transparent 70%);
  pointer-events:none;
}
.tile:hover::before{ opacity:1; }
.tile-ic{ width:42px;height:42px; border-radius:11px; display:grid; place-items:center;
  background:rgba(77,159,255,.12); border:1px solid rgba(77,159,255,.25); color:var(--blue);
  margin-bottom:16px; }
.tile-ic svg{ width:21px;height:21px; }
.tile.is-orange .tile-ic{ background:rgba(255,122,26,.12); border-color:rgba(255,122,26,.28); color:var(--orange); }
.tile.is-violet .tile-ic{ background:rgba(139,108,255,.14); border-color:rgba(139,108,255,.3); color:var(--violet); }
.tile h3{ font-size:19px; font-weight:600; letter-spacing:-.02em; }
.tile p{ margin-top:9px; color:var(--ink-mut); font-size:14.5px; line-height:1.55; }
.tile .tile-tag{ margin-top:auto; padding-top:16px; }
.chip{ display:inline-block; font-family:var(--font-mono); font-size:10.5px; letter-spacing:.08em;
  text-transform:uppercase; padding:4px 9px; border-radius:999px; color:var(--ink-mut);
  background:rgba(255,255,255,.04); border:1px solid var(--line); }

.col-3{ grid-column:span 3; } .col-2{ grid-column:span 2; } .col-4{ grid-column:span 4; }
.col-6{ grid-column:span 6; }
@media (max-width:880px){ .bento{ grid-template-columns:repeat(2,1fr); }
  .col-3,.col-2,.col-4,.col-6{ grid-column:span 1; }
  .tile.span2-m{ grid-column:span 2; } }
@media (max-width:520px){ .bento{ grid-template-columns:1fr; }
  .tile.span2-m{ grid-column:span 1; } }

/* big bento tile with mini visual */
.tile-feature{ background:linear-gradient(160deg,#0e1626,#0a0d15); }
.mini-replay{ margin-top:18px; border-radius:14px; border:1px solid var(--line);
  background:rgba(255,255,255,.02); padding:14px; position:relative; overflow:hidden; }
.mini-replay svg{ width:100%; height:auto; }

/* ---------------- deep-dive sections ---------------- */
.dive{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,80px); align-items:center; }
.dive.flip .dive-media{ order:-1; }
@media (max-width:900px){ .dive{ grid-template-columns:1fr; }
  .dive.flip .dive-media{ order:0; } }
.dive + .dive{ margin-top:clamp(80px,9vw,130px); }
.dive-copy .feat-list{ margin-top:26px; display:flex; flex-direction:column; gap:16px; }
.feat-list li{ list-style:none; display:flex; gap:13px; align-items:flex-start; }
.feat-list li .fi{ width:26px;height:26px;border-radius:8px; flex:none; margin-top:1px;
  display:grid; place-items:center; background:rgba(77,159,255,.12);
  border:1px solid rgba(77,159,255,.25); color:var(--blue); }
.feat-list li .fi svg{ width:14px;height:14px; }
.feat-list li b{ font-weight:600; }
.feat-list li p{ color:var(--ink-mut); font-size:14.5px; margin-top:3px; }
ul.feat-list{ padding:0; margin-block:26px 0; }

.dive-media{ position:relative; }

/* G-meter big gauge */
.gauge-card{ position:relative; border-radius:var(--radius-lg);
  background:linear-gradient(160deg,#0e1626,#090c14); border:1px solid var(--line);
  padding:30px; box-shadow:0 40px 80px -40px rgba(0,0,0,.8); }
.gauge-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:22px; }
.gauge-head .gh-l{ font-family:var(--font-mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink-faint); }
.gauge-head .gh-score{ display:flex; align-items:center; gap:10px; }
.gauge-wrap{ position:relative; width:min(320px,80%); margin:0 auto; aspect-ratio:1; }
.gauge-wrap svg{ width:100%; height:100%; }
.g-dot{ position:absolute; width:18px;height:18px; border-radius:50%;
  background:var(--orange); box-shadow:0 0 16px 3px rgba(255,122,26,.8), 0 0 0 4px rgba(255,122,26,.18);
  transform:translate(-50%,-50%); left:50%; top:50%; transition:left .12s linear, top .12s linear; }
.g-val{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center;
  justify-content:center; pointer-events:none; }
.g-val b{ font-family:var(--font-mono); font-weight:800; font-size:38px; color:#fff;
  font-variant-numeric:tabular-nums; }
.g-val small{ font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; color:var(--ink-faint);
  text-transform:uppercase; }
.gauge-foot{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:24px; }
.gauge-foot .gf{ text-align:center; }
.gauge-foot .gf .v{ font-family:var(--font-mono); font-weight:800; font-size:18px; color:#fff; }
.gauge-foot .gf .l{ font-size:11px; color:var(--ink-faint); margin-top:2px; }

/* ---------------- placeholder media ---------------- */
.ph{ position:relative; border-radius:var(--radius-lg); overflow:hidden;
  border:1px dashed rgba(255,255,255,.16);
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.025) 0 14px, transparent 14px 28px),
    linear-gradient(160deg,#0d1119,#090c13);
  display:grid; place-items:center; min-height:300px; text-align:center; padding:30px; }
.ph .ph-tag{ font-family:var(--font-mono); font-size:12px; letter-spacing:.08em; color:var(--ink-mut);
  border:1px solid var(--line-2); padding:8px 14px; border-radius:999px; background:rgba(0,0,0,.3); }
.ph .ph-ic{ width:46px;height:46px; margin:0 auto 14px; color:var(--ink-faint);
  border:1px solid var(--line-2); border-radius:13px; display:grid; place-items:center; }
.ph .ph-ic svg{ width:24px;height:24px; }

/* ---------------- online section ---------------- */
.online-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,5vw,72px); align-items:center; }
@media (max-width:900px){ .online-grid{ grid-template-columns:1fr; } }

.board{ border-radius:var(--radius-lg); background:linear-gradient(160deg,#0e1626,#090c14);
  border:1px solid var(--line); overflow:hidden; box-shadow:0 40px 80px -40px rgba(0,0,0,.8); }
.board-head{ display:flex; justify-content:space-between; align-items:center;
  padding:18px 22px; border-bottom:1px solid var(--line); }
.board-head .bh-t{ font-weight:600; font-size:16px; }
.board-head .bh-t small{ display:block; font-family:var(--font-mono); font-size:11px;
  color:var(--ink-faint); margin-top:2px; letter-spacing:.06em; }
.presence{ display:inline-flex; align-items:center; gap:8px; font-family:var(--font-mono);
  font-size:12px; color:var(--faster); }
.presence i{ width:8px;height:8px;border-radius:50%; background:var(--faster);
  box-shadow:0 0 10px 1px rgba(70,224,168,.8); animation:pulse 2s infinite; }
@keyframes pulse{ 0%,100%{opacity:1} 50%{opacity:.35} }
@media (prefers-reduced-motion: reduce){ .presence i{ animation:none; } }

.row{ display:grid; grid-template-columns:36px 1fr auto; gap:14px; align-items:center;
  padding:13px 22px; border-bottom:1px solid var(--line); transition:background .2s; }
.row:last-child{ border-bottom:0; }
.row:hover{ background:rgba(255,255,255,.025); }
.row.me{ background:rgba(77,159,255,.07); }
.row .rk{ font-family:var(--font-mono); font-weight:800; color:var(--ink-faint); text-align:center; }
.row.podium-1 .rk{ color:var(--orange); } .row.podium-2 .rk{ color:#cdd6e4; } .row.podium-3 .rk{ color:#d8965a; }
.row .who{ display:flex; align-items:center; gap:11px; }
.row .av{ width:30px;height:30px;border-radius:9px; flex:none;
  background:linear-gradient(150deg,#26303f,#161b27); border:1px solid var(--line-2);
  display:grid; place-items:center; font-family:var(--font-mono); font-size:12px; font-weight:700; color:var(--ink-soft); }
.row .nm{ font-weight:600; font-size:14.5px; }
.row .nm small{ display:block; color:var(--ink-faint); font-size:11.5px; font-weight:500; font-family:var(--font-mono); }
.row .tt{ font-family:var(--font-mono); font-weight:700; font-size:15px; color:#fff; font-variant-numeric:tabular-nums; }
.row .tt small{ display:block; text-align:right; font-size:11px; color:var(--faster); }
.row.me .tt small{ color:var(--blue); }

/* ---------------- achievements ---------------- */
.medals{ display:flex; flex-wrap:wrap; gap:14px; margin-top:40px; }
.medal{ display:flex; align-items:center; gap:13px; padding:14px 18px 14px 14px;
  border-radius:15px; background:var(--panel); border:1px solid var(--line);
  transition:transform .3s var(--ease), border-color .3s; }
.medal:hover{ transform:translateY(-3px); border-color:var(--line-2); }
.medal .mi{ width:44px;height:44px; flex:none; border-radius:12px; display:grid; place-items:center;
  font-size:20px; background:radial-gradient(circle at 30% 25%, rgba(255,255,255,.12), transparent 60%); }
.medal.gold .mi{ background:radial-gradient(circle at 30% 25%, #ffcf8a, #b8721f); color:#3a2207; }
.medal.blue .mi{ background:radial-gradient(circle at 30% 25%, #7bb6ff, var(--blue-deep)); color:#06122a; }
.medal.violet .mi{ background:radial-gradient(circle at 30% 25%, #b3a0ff, #5b43c9); color:#140a2e; }
.medal .mt b{ display:block; font-size:14.5px; font-weight:600; }
.medal .mt span{ font-size:12px; color:var(--ink-faint); font-family:var(--font-mono); }

/* ---------------- privacy block ---------------- */
.privacy{ position:relative; overflow:hidden; }
.privacy-card{ position:relative; border-radius:var(--radius-lg); padding:clamp(40px,6vw,84px);
  background:linear-gradient(160deg,rgba(20,26,38,.7),rgba(9,12,20,.7));
  border:1px solid var(--line-2); text-align:center; overflow:hidden;
  box-shadow:0 50px 100px -50px rgba(0,0,0,.8); }
.privacy-card::before{ content:""; position:absolute; inset:0; z-index:-1;
  background:radial-gradient(80% 120% at 50% -20%, rgba(77,159,255,.18), transparent 60%); }
.privacy-lock{ width:62px;height:62px; margin:0 auto 22px; border-radius:17px;
  display:grid; place-items:center; color:var(--blue);
  background:rgba(77,159,255,.12); border:1px solid rgba(77,159,255,.3);
  box-shadow:0 0 40px -8px rgba(77,159,255,.6); }
.privacy-lock svg{ width:30px;height:30px; }
.privacy-points{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:40px; text-align:left; }
.pp{ padding:22px; border-radius:16px; background:rgba(255,255,255,.025); border:1px solid var(--line); }
.pp .pp-i{ color:var(--blue); margin-bottom:12px; } .pp .pp-i svg{ width:22px;height:22px; }
.pp b{ font-size:15.5px; font-weight:600; } .pp p{ margin-top:7px; color:var(--ink-mut); font-size:13.5px; line-height:1.55; }
@media (max-width:760px){ .privacy-points{ grid-template-columns:1fr; } }

/* ---------------- final cta ---------------- */
.cta-final{ position:relative; overflow:hidden; }
.cta-card{ position:relative; border-radius:var(--radius-lg); text-align:center;
  padding:clamp(48px,7vw,96px) clamp(24px,5vw,64px);
  background:linear-gradient(160deg,#0f1830,#0a0d18);
  border:1px solid var(--line-2); overflow:hidden;
  box-shadow:0 50px 120px -50px rgba(47,123,255,.5); }
.cta-card::before{ content:""; position:absolute; inset:-2px; z-index:0;
  background:radial-gradient(70% 90% at 50% 0%, rgba(77,159,255,.28), transparent 60%),
             radial-gradient(50% 70% at 80% 100%, rgba(255,122,26,.16), transparent 60%); }
.cta-card > *{ position:relative; z-index:1; }
.cta-card h2{ font-family:var(--font-disp); font-weight:400; font-size:clamp(30px,5vw,60px);
  line-height:1.02; }
.cta-card h2 .grad{ background:linear-gradient(110deg,#7bb6ff,var(--blue) 50%,var(--violet));
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.cta-card p{ margin:20px auto 0; max-width:50ch; color:var(--ink-mut); font-size:clamp(16px,1.7vw,19px); }
.cta-actions{ margin-top:34px; display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }
.cta-meta{ margin-top:22px; font-family:var(--font-mono); font-size:13px; color:var(--ink-faint);
  display:flex; flex-wrap:wrap; gap:10px 22px; justify-content:center; }
.cta-meta span{ display:inline-flex; align-items:center; gap:7px; }

/* ---------------- responsive nav ---------------- */
@media (max-width:860px){
  .nav-links{ display:none; }
  .nav-cta .btn-secondary-text{ display:none; }
}
@media (max-width:560px){
  .nav-cta .btn span.lng{ display:none; }
  .variant-switch{ right:10px; bottom:10px; transform:scale(.92); transform-origin:bottom right; }
}
@media (max-width:430px){
  .hero{ padding-top:120px; }
  .hero .phone{ --w:clamp(236px,72vw,290px); }
  .hero-stage{ margin-top:30px; }
  .fcard-record{ top:-2%; left:0; } .fcard-g{ right:0; }
  .hud-timer .big{ font-size:46px; }
  body.hero-c .hero h1{ font-size:clamp(32px,9vw,108px); }
}
