/* ============== TIDEWAKE — landing page styles ============== */
:root{
  --abyss:#081620;
  --deep:#0d2433;
  --navy:#143a52;
  --navy-2:#10303f;
  --steel:#2b5f78;
  --steel-soft:#3e7790;
  --foam:#cdd4cb;
  --foam-dim:#8a9b97;
  --gold:#dcb464;
  --gold-deep:#b6883a;
  --hull:#82302c;
  --ember:#d6360a;
  --ember-soft:#ec5a22;
  --parchment:#ece5d4;
  --ink:#0a1620;

  --accent:#d6360a;            /* tweakable */
  --accent-soft:#ec5a22;       /* tweakable */

  --maxw:1180px;
  --display:"Cinzel", Georgia, serif;
  --decorative:"Cinzel Decorative","Cinzel", Georgia, serif;
  --body:"Spectral", Georgia, serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:84px;}
body{
  margin:0;
  font-family:var(--body);
  color:var(--foam);
  background:var(--abyss);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{margin:0;font-family:var(--display);font-weight:700;line-height:1.04;}
p{margin:0;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
::selection{background:var(--accent);color:#fff;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}

.eyebrow{
  font-family:var(--display);
  font-weight:700;
  font-size:13px;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-block;
}
.eyebrow::before{content:"";display:inline-block;width:26px;height:1px;background:var(--gold);vertical-align:middle;margin-right:14px;opacity:.7;}

.stone-title{
  font-family:var(--display);
  color:var(--parchment);
  text-shadow:0 1px 0 #fff2, 0 3px 0 rgba(0,0,0,.35), 0 14px 30px rgba(0,0,0,.5);
  letter-spacing:.01em;
}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--display);
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:15px;
  padding:16px 30px;
  border-radius:6px;
  border:1px solid transparent;
  cursor:pointer;
  display:inline-flex;align-items:center;gap:11px;
  transition:transform .18s var(--ease), box-shadow .25s var(--ease), background .25s;
  position:relative;white-space:nowrap;
}
.btn i{font-size:19px;flex:none;}
.btn-primary{
  color:#fff;
  background:linear-gradient(180deg,var(--accent-soft),var(--accent));
  box-shadow:0 0 0 1px rgba(0,0,0,.25),0 10px 26px -8px var(--accent), inset 0 1px 0 #ffffff55;
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 0 0 1px rgba(0,0,0,.25),0 18px 40px -10px var(--accent), inset 0 1px 0 #ffffff66;}
.btn-ghost{
  color:var(--foam);
  background:rgba(255,255,255,.04);
  border-color:rgba(205,212,203,.28);
}
.btn-ghost:hover{transform:translateY(-3px);border-color:rgba(205,212,203,.6);background:rgba(255,255,255,.09);}
.btn-lg{font-size:17px;padding:20px 40px;}

/* ============== NAV ============== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 34px;
  transition:background .35s, padding .35s, box-shadow .35s, border-color .35s;
  border-bottom:1px solid transparent;
}
.nav.solid{
  background:rgba(8,22,32,.86);
  backdrop-filter:blur(10px);
  border-bottom-color:rgba(205,212,203,.1);
  box-shadow:0 8px 30px rgba(0,0,0,.35);
  padding-top:13px;padding-bottom:13px;
}
.nav-logo{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:700;letter-spacing:.3em;font-size:16px;color:var(--parchment);text-transform:uppercase;}
.nav-logo img{height:38px;width:auto;filter:drop-shadow(0 3px 6px rgba(0,0,0,.5));}
@media (max-width:1240px){.nav-word{display:none;}}
.nav-links{display:flex;align-items:center;gap:30px;}
.nav-links a{font-family:var(--display);font-weight:600;font-size:13.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--foam-dim);transition:color .2s;position:relative;}
.nav-links a:hover{color:var(--foam);}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-7px;height:2px;width:0;background:var(--accent);transition:width .25s var(--ease);}
.nav-links a:hover::after{width:100%;}
.nav-cta{padding:11px 22px;font-size:13px;}
.nav-burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:8px;}
.nav-burger span{width:24px;height:2px;background:var(--foam);display:block;}

/* ============== HERO ============== */
/* the 7 layers share one 1438x810 canvas (aspect 1.7753).
   each .layer is an identical canvas-sized box, sized to COVER the hero
   and anchored to the bottom; the art sits at its true vertical fraction. */
.hero{position:relative;height:100vh;min-height:660px;overflow:hidden;background:#0c2434;
  /* Maintain 1.7753 aspect ratio (1438x810) while ensuring coverage with minimal buffer */
  --aspect: 1.7753;
  --heroH: max(100vh, 660px);
  --sceneW: max(103vw, calc(var(--heroH) * 1.03 * var(--aspect)));
  --sceneH: calc(var(--sceneW) / var(--aspect));
}
.layer{position:absolute;left:50%;bottom:0;width:var(--sceneW);height:var(--sceneH);
  transform:translateX(-50%);will-change:transform;pointer-events:none;}
.layer img{position:absolute;left:0;width:100%;display:block;}
/* sky is just a gradient — keep it full-cover behind everything to fill any gap */
.l-sky{
  --skyW: max(106vw, calc(var(--heroH) * 1.06 * var(--aspect)));
  --skyH: calc(var(--skyW) / var(--aspect));
  width: var(--skyW); height: var(--skyH);
}
.l-sky      img{top:0;   height:100%;object-fit:cover;}
.l-clouds   img{top:0;   height:57.28%;}
.l-shipsfar img{bottom:0;height:94.44%;}
.l-shipsnear img{bottom:0;height:86.54%;}
.l-waveback img{bottom:0;height:85.80%;}
.l-wavemid  img{bottom:0;height:47.90%;}
.l-wavefront img{bottom:0;height:43.95%;}
.l-wavemid{z-index:7;}
.l-wavefront{z-index:8;}

.hero-content{
  position:absolute;z-index:9;left:50%;top:41%;transform:translate(-50%,-50%);
  width:min(900px,92vw);text-align:center;will-change:transform;
}
.hero-logo{width:min(680px,80vw);margin:0 auto;filter:drop-shadow(0 26px 40px rgba(0,0,0,.55));}
.hero-tag{
  font-family:var(--decorative);
  font-weight:700;
  font-size:clamp(20px,3vw,33px);
  color:var(--parchment);
  letter-spacing:.06em;
  margin-top:6px;
  text-shadow:0 2px 0 rgba(0,0,0,.5),0 12px 30px rgba(0,0,0,.6);
}
.hero-tag .ember{color:var(--accent-soft);}
.hero-ctas{display:flex;gap:18px;justify-content:center;margin-top:34px;flex-wrap:wrap;}
.hero-sub{margin-top:20px;font-size:14.5px;letter-spacing:.2em;text-transform:uppercase;color:#e7ece4;font-family:var(--display);font-weight:600;
  text-shadow:0 1px 2px rgba(0,0,0,.9), 0 3px 14px rgba(0,0,0,.85);}

.hero-vignette{position:absolute;inset:0;z-index:5;pointer-events:none;
  background:radial-gradient(120% 80% at 50% 30%, transparent 40%, rgba(8,22,32,.5) 100%),
             linear-gradient(180deg, rgba(8,22,32,.35) 0%, transparent 22%, transparent 70%, var(--abyss) 100%);
}
.flash{position:absolute;inset:0;z-index:9;background:#dfe9ff;opacity:0;pointer-events:none;mix-blend-mode:screen;}

.scroll-hint{position:absolute;z-index:10;left:50%;bottom:26px;transform:translateX(-50%);
  font-family:var(--display);font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--foam-dim);
  display:flex;flex-direction:column;align-items:center;gap:9px;animation:bobHint 2.4s var(--ease) infinite;}
.scroll-hint .mouse{width:22px;height:34px;border:2px solid var(--foam-dim);border-radius:12px;position:relative;}
.scroll-hint .mouse::after{content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);width:3px;height:7px;border-radius:2px;background:var(--foam-dim);animation:wheel 1.6s infinite;}
@keyframes wheel{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}100%{opacity:0;transform:translate(-50%,10px)}}
@keyframes bobHint{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ============== SECTIONS ============== */
section{position:relative;}
.section{padding:130px 0;position:relative;}
.section-head{max-width:720px;margin-bottom:60px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-title{font-size:clamp(34px,5vw,58px);margin-top:18px;}
.lead{font-size:clamp(18px,2vw,21px);line-height:1.62;color:var(--foam-dim);margin-top:22px;}
.lead strong{color:var(--foam);font-weight:600;}

/* ---- PITCH ---- */
.pitch{background:
   radial-gradient(90% 60% at 50% 0%, rgba(43,95,120,.28), transparent 60%),
   linear-gradient(180deg,var(--abyss),var(--deep));}
.pillrow{display:flex;gap:18px;flex-wrap:wrap;margin-top:46px;}
.pill{flex:1 1 200px;border:1px solid rgba(205,212,203,.14);background:rgba(20,58,82,.32);
  border-radius:10px;padding:26px 24px;backdrop-filter:blur(3px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);}
.pill .k{font-family:var(--display);font-weight:700;font-size:30px;color:var(--gold);display:flex;align-items:center;justify-content:center;height:40px;}
.pill .k i{font-size:32px;flex:none;}
.pill .v{margin-top:8px;font-size:15px;color:var(--foam-dim);letter-spacing:.02em;}

/* ---- SHIP CUSTOMIZATION ---- */
.ship{background:
   radial-gradient(120% 85% at 50% -12%, rgba(62,119,144,.42), transparent 58%),
   linear-gradient(180deg,var(--deep),var(--navy-2));}
.ship-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:14px;}
.part{
  border:1px solid rgba(205,212,203,.18);
  background:linear-gradient(180deg,rgba(33,84,107,.62),rgba(16,46,61,.66));
  border-radius:12px;overflow:hidden;
  box-shadow:0 24px 50px -28px #000, inset 0 1px 0 rgba(255,255,255,.06);
  transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;
}
.part:hover{transform:translateY(-8px);border-color:var(--accent);box-shadow:0 34px 60px -28px #000,0 0 0 1px var(--accent), inset 0 1px 0 rgba(255,255,255,.08);}
.part .pic{aspect-ratio:1/1;}
.part .body{padding:22px 22px 26px;}
.part .num{font-family:var(--display);font-size:12px;letter-spacing:.3em;color:var(--gold);}
.part h3{font-size:22px;color:var(--parchment);margin-top:8px;}
.part p{margin-top:10px;font-size:14.5px;line-height:1.55;color:var(--foam-dim);}

/* ---- TRINKETS ---- */
.trinkets{background:
   radial-gradient(70% 50% at 80% 10%, rgba(214,54,10,.14), transparent 60%),
   linear-gradient(180deg,var(--navy-2),var(--abyss));}
.trinket-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:14px;}
.trinket{
  position:relative;border-radius:12px;padding:30px 28px;
  border:1px solid rgba(205,212,203,.13);
  background:linear-gradient(180deg,rgba(16,48,63,.5),rgba(8,22,32,.7));
  transition:transform .3s var(--ease),box-shadow .3s;
}
.trinket:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px #000;}
.trinket .gem{width:66px;height:66px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 35% 30%,var(--accent-soft),var(--accent) 60%,#5e1402);
  box-shadow:0 0 28px -4px var(--accent),inset 0 2px 6px rgba(255,255,255,.4);margin-bottom:20px;}
.trinket .gem i{font-size:30px;color:#fff;}
.trinket h3{font-size:20px;color:var(--parchment);}
.trinket p{margin-top:10px;font-size:14.5px;line-height:1.55;color:var(--foam-dim);}

/* ---- ROGUELITE LOOP ---- */
.rogue{background:linear-gradient(180deg,var(--abyss),var(--deep));}
.loop{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:30px;position:relative;}
.loop-step{text-align:center;padding:0 22px;position:relative;z-index:2;}
.loop-step .ring{width:88px;height:88px;border-radius:50%;margin:0 auto 22px;display:grid;place-items:center;
  border:2px solid rgba(205,212,203,.22);background:#0b1f2c;color:var(--gold);
  box-shadow:inset 0 2px 10px rgba(0,0,0,.4);position:relative;z-index:2;transition:border-color .3s,box-shadow .3s;}
.loop-step .ring i{font-size:38px;flex:none;}
.loop-step:hover .ring{border-color:var(--accent);box-shadow:0 0 26px -6px var(--accent),inset 0 2px 10px rgba(0,0,0,.4);}
.loop-step h3{font-size:19px;color:var(--parchment);}
.loop-step p{margin-top:9px;font-size:13.5px;line-height:1.5;color:var(--foam-dim);}
.loop::before{content:"";position:absolute;top:44px;left:12%;right:12%;height:2px;
  background:linear-gradient(90deg,transparent,rgba(205,212,203,.25),rgba(205,212,203,.25),transparent);z-index:1;}

/* ---- ROADMAP ---- */
.roadmap{background:linear-gradient(180deg,var(--deep),var(--navy-2));}
.timeline{margin-top:30px;position:relative;}
.timeline::before{content:"";position:absolute;left:13px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--accent),rgba(205,212,203,.18));}
.mile{position:relative;padding:0 0 44px 56px;}
.mile:last-child{padding-bottom:0;}
.mile .dot{position:absolute;left:5px;top:3px;width:18px;height:18px;border-radius:50%;background:var(--deep);border:3px solid var(--foam-dim);}
.mile.active .dot{border-color:var(--accent);background:var(--accent);box-shadow:0 0 18px -2px var(--accent);}
.mile .phase{font-family:var(--display);font-size:12.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);}
.mile h3{font-size:24px;color:var(--parchment);margin-top:6px;}
.mile p{margin-top:9px;font-size:15px;line-height:1.55;color:var(--foam-dim);max-width:560px;}
.mile .tag{display:inline-block;margin-top:12px;font-family:var(--display);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-soft);border:1px solid var(--accent);border-radius:20px;padding:5px 14px;}

/* ---- GALLERY ---- */
.gallery{background:linear-gradient(180deg,var(--navy-2),var(--abyss));}
.gal-main{aspect-ratio:16/9;border-radius:14px;overflow:hidden;border:1px solid rgba(205,212,203,.16);
  box-shadow:0 40px 80px -40px #000;position:relative;}
.gal-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:16px;}
.gal-thumb{aspect-ratio:16/9;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent;opacity:.62;transition:opacity .25s,border-color .25s,transform .25s;}
.gal-thumb:hover{opacity:1;transform:translateY(-3px);}
.gal-thumb.active{opacity:1;border-color:var(--accent);}

/* placeholder art */
.ph{position:relative;width:100%;height:100%;display:grid;place-items:center;
  background:
    repeating-linear-gradient(135deg,rgba(205,212,203,.05) 0 12px,transparent 12px 24px),
    linear-gradient(180deg,var(--steel),var(--navy-2));
  color:var(--foam-dim);}
.ph span{font-family:ui-monospace,Menlo,monospace;font-size:12px;letter-spacing:.08em;
  border:1px dashed rgba(205,212,203,.4);padding:7px 12px;border-radius:4px;background:rgba(8,22,32,.35);text-align:center;}

/* ---- FINAL CTA ---- */
.final{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--abyss),#06121a);padding:150px 0 240px;text-align:center;}
.final .waveart{position:absolute;left:50%;transform:translateX(-50%);bottom:0;width:140%;min-width:1200px;max-width:2200px;opacity:1;pointer-events:none;}
.final .wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;}
/* symmetric, truly-centered eyebrow for the centered CTA */
.final .eyebrow{display:inline-flex;align-items:center;}
.final .eyebrow::after{content:"";display:inline-block;width:26px;height:1px;background:var(--gold);vertical-align:middle;margin-left:calc(14px - .42em);opacity:.7;}
.final h2{font-size:clamp(38px,6vw,76px);margin-top:22px;}
.final .lead{margin:24px auto 0;max-width:600px;}
.final .hero-ctas{margin-top:50px;position:relative;z-index:2;}

/* ---- FOOTER ---- */
.footer{background:#06121a;padding:54px 0 40px;border-top:1px solid rgba(205,212,203,.08);}
.footer-in{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;}
.footer img{height:54px;width:auto;}
.footer .meta{font-size:13px;color:var(--foam-dim);line-height:1.7;}
.footer .social{display:flex;gap:14px;}
.footer .social a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(205,212,203,.2);display:grid;place-items:center;color:var(--foam-dim);transition:.2s;}
.footer .social a:hover{color:var(--foam);border-color:var(--accent);background:rgba(214,54,10,.12);transform:translateY(-2px);}
.footer .social i{font-size:18px;}

/* ============== SCROLL REVEAL & ANIMATIONS ============== */
.reveal{
  opacity:0;
  transform:translateY(38px);
  filter:blur(10px);
  transition:
    opacity .9s var(--ease),
    transform .9s var(--ease),
    filter .9s var(--ease);
}
.reveal-left { transform: translateX(-50px); }
.reveal-right { transform: translateX(50px); }
.reveal-scale { transform: scale(0.92) translateY(20px); }

.reveal.in{
  opacity:1;
  transform:none;
  filter:blur(0);
}

.reveal.d1{transition-delay:.12s;}
.reveal.d2{transition-delay:.24s;}
.reveal.d3{transition-delay:.36s;}
.reveal.d4{transition-delay:.48s;}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;filter:none;}
}

/* Tide Line Progress */
.tide-line {
  position: fixed;
  top: 0;
  left: 0;
  width: 0%;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--gold));
  z-index: 100;
  box-shadow: 0 0 15px var(--accent);
  transition: width 0.1s ease-out;
}

/* Background Depth */
.section-bg-parallax {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}
.floating-particle {
  position: absolute;
  background: white;
  border-radius: 50%;
  opacity: 0.1;
  filter: blur(2px);
  pointer-events: none;
}

/* Interactive Card Enhancement */
.part, .trinket {
  transition: transform 0.4s var(--ease), border-color 0.3s, box-shadow 0.4s, filter 0.4s;
}
.part:hover, .trinket:hover {
  filter: brightness(1.1);
  transform: translateY(-10px) scale(1.02);
}

/* ============== TWEAKS PANEL ============== */
.tweaks{position:fixed;right:20px;bottom:20px;z-index:120;width:288px;
  background:rgba(10,26,37,.96);border:1px solid rgba(205,212,203,.16);border-radius:14px;
  box-shadow:0 30px 70px -20px #000;backdrop-filter:blur(12px);
  font-family:var(--body);color:var(--foam);padding:18px 18px 20px;display:none;}
.tweaks.show{display:block;}
.tweaks h4{font-family:var(--display);font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);display:flex;justify-content:space-between;align-items:center;}
.tweaks .close{background:none;border:0;color:var(--foam-dim);font-size:20px;cursor:pointer;line-height:1;}
.tw-row{margin-top:18px;}
.tw-row label{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--foam-dim);display:flex;justify-content:space-between;}
.tw-row input[type=range]{width:100%;margin-top:9px;accent-color:var(--accent);}
.tw-swatches{display:flex;gap:10px;margin-top:10px;}
.tw-swatches button{width:34px;height:34px;border-radius:8px;border:2px solid transparent;cursor:pointer;}
.tw-swatches button.sel{border-color:#fff;box-shadow:0 0 0 2px var(--abyss),0 0 12px rgba(255,255,255,.4);}
.tw-toggle{display:flex;align-items:center;gap:10px;margin-top:9px;cursor:pointer;font-size:13px;color:var(--foam);}
.tw-toggle .sw{width:42px;height:23px;border-radius:13px;background:rgba(205,212,203,.2);position:relative;transition:background .2s;flex:none;}
.tw-toggle .sw::after{content:"";position:absolute;top:2px;left:2px;width:19px;height:19px;border-radius:50%;background:#fff;transition:transform .2s;}
.tw-toggle.on .sw{background:var(--accent);}
.tw-toggle.on .sw::after{transform:translateX(19px);}

/* ============== RESPONSIVE ============== */
@media (max-width:1000px){
  .ship-grid{grid-template-columns:repeat(2,1fr);}
  .trinket-grid{grid-template-columns:1fr;}
  .loop{grid-template-columns:repeat(2,1fr);row-gap:44px;}
  .loop::before{display:none;}
}
@media (max-width:720px){
  .wrap{padding:0 22px;}
  .section{padding:84px 0;}
  .section-head{margin-bottom:42px;}
  .nav{padding:14px 18px;}
  .nav-links{display:none;}
  .nav-burger{display:flex;}
  .ship-grid{grid-template-columns:1fr;}
  .pillrow{flex-direction:column;}
  .hero-content{top:42%;}
  .car-nav{width:38px;height:38px;}
  .car-nav i{font-size:15px;}
  .car-thumbs{gap:8px;}
}
@media (max-width:520px){
  .wrap{padding:0 18px;}
  .section{padding:64px 0;}
  .hero{min-height:560px;}
  .btn-lg{font-size:15px;padding:16px 24px;}
  .hero-ctas{gap:12px;}
  .hero-ctas .btn{width:100%;justify-content:center;}  /* full-width = bigger tap targets */
  .loop{grid-template-columns:1fr;}
  .car-thumbs{gap:6px;}
  .tweaks{right:12px;left:12px;width:auto;}             /* never overflow the viewport */
}

/* ============ COMING SOON OVERLAY ============ */
/* Delete this block (and the matching markup in index.html) to reveal the full site. */
.coming-soon{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  padding:48px 24px;text-align:center;overflow:hidden;
  background:#06121a;
  animation:csFade .7s var(--ease) both;
}
/* key art, gently drifting and darkened for legibility */
.coming-soon::before{
  content:"";position:absolute;inset:-5%;pointer-events:none;z-index:0;
  background:
    radial-gradient(120% 95% at 50% 38%, transparent 22%, rgba(6,18,26,.55) 70%, rgba(6,18,26,.92) 100%),
    linear-gradient(180deg, rgba(6,18,26,.62), rgba(6,18,26,.80)),
    url("assets/og-image.png") center 30% / cover no-repeat;
  transform:scale(1.05);
  animation:csDrift 28s ease-in-out infinite alternate;
}
/* drifting foreground wave anchored to the base */
.coming-soon::after{
  content:"";position:absolute;left:50%;bottom:-1%;z-index:0;
  width:170%;min-width:1500px;aspect-ratio:1438/356;
  background:url("assets/wave-front.png") center bottom / 100% auto no-repeat;
  opacity:.55;pointer-events:none;
  animation:csWave 10s ease-in-out infinite alternate;
}
.cs-inner{position:relative;z-index:1;max-width:680px;display:flex;flex-direction:column;align-items:center;}
.cs-logo{
  width:min(380px,74vw);margin-bottom:28px;
  animation:csRise .9s var(--ease) both, csGlow 5.5s ease-in-out 1s infinite;
}
.cs-eyebrow{
  font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);
  display:inline-flex;align-items:center;
  animation:csRise .9s .14s var(--ease) both;
}
.cs-eyebrow::before,.cs-eyebrow::after{content:"";display:inline-block;width:32px;height:1px;opacity:.85;}
.cs-eyebrow::before{margin-right:14px;background:linear-gradient(90deg,transparent,var(--gold));}
.cs-eyebrow::after{margin-left:calc(14px - .42em);background:linear-gradient(90deg,var(--gold),transparent);}
.cs-title{font-size:clamp(30px,5vw,56px);margin-top:18px;animation:csRise .9s .26s var(--ease) both;}
.cs-sub{font-size:clamp(16px,2vw,19px);line-height:1.62;color:var(--foam-dim);margin:20px auto 0;max-width:520px;animation:csRise .9s .4s var(--ease) both;}
.cs-ctas{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:38px;animation:csRise .9s .54s var(--ease) both;}
.cs-event{
  display:inline-flex;align-items:center;gap:10px;margin-top:34px;
  font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--foam-dim);
  border:1px solid rgba(220,180,100,.35);border-radius:24px;padding:9px 20px;
  background:rgba(220,180,100,.06);
  animation:csRise .9s .68s var(--ease) both;
}
.cs-event i{color:var(--gold);font-size:14px;}
.cs-event strong{color:var(--gold);font-weight:700;}

@keyframes csFade{from{opacity:0}to{opacity:1}}
@keyframes csRise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes csDrift{from{transform:scale(1.05) translate(-1.2%,-0.8%)}to{transform:scale(1.08) translate(1.2%,0.8%)}}
@keyframes csWave{from{transform:translateX(-51.5%)}to{transform:translateX(-48.5%)}}
@keyframes csGlow{
  0%,100%{filter:drop-shadow(0 22px 34px rgba(0,0,0,.55));}
  50%{filter:drop-shadow(0 0 26px rgba(220,180,100,.38)) drop-shadow(0 22px 34px rgba(0,0,0,.55));}
}
@media (prefers-reduced-motion:reduce){
  .coming-soon,.coming-soon::before,.coming-soon::after,
  .cs-logo,.cs-eyebrow,.cs-title,.cs-sub,.cs-ctas,.cs-leaderboard{animation:none!important;}
  .coming-soon::before{transform:scale(1.05);}
  .coming-soon::after{transform:translateX(-50%);}
}

/* ---- Expo leaderboard on the coming-soon overlay ---- */
.cs-leaderboard{
  width:min(440px,92vw);margin-top:32px;
  padding:20px 22px 16px;text-align:left;
  border:1px solid rgba(220,180,100,.32);border-radius:16px;
  background:linear-gradient(180deg, rgba(13,36,51,.72), rgba(8,22,32,.74));
  backdrop-filter:blur(6px);
  box-shadow:0 18px 40px rgba(0,0,0,.45);
  animation:csRise .9s .82s var(--ease) both;
}
.cs-lb-title{font-size:clamp(20px,3vw,26px);text-align:center;color:var(--gold);}
.cs-lb-sub{
  font-size:13px;line-height:1.5;color:var(--foam-dim);
  text-align:center;margin:8px auto 14px;max-width:340px;
}
.cs-lb-sub strong{color:var(--gold);}
.cs-lb-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px;}
.cs-lb-row{
  display:grid;grid-template-columns:32px 1fr auto;align-items:center;gap:12px;
  padding:9px 12px;border-radius:10px;font-family:var(--display);
}
.cs-lb-row:nth-child(odd){background:rgba(205,212,203,.05);}
.cs-lb-rank{font-weight:700;color:var(--foam-dim);font-size:14px;text-align:center;}
.cs-lb-row.top .cs-lb-rank{color:var(--gold);}
.cs-lb-name{
  color:var(--foam);font-weight:600;font-size:15px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.cs-lb-score{color:var(--gold);font-weight:700;font-size:15px;font-variant-numeric:tabular-nums;}
.cs-lb-empty{text-align:center;color:var(--foam-dim);font-size:13px;margin:6px 0 2px;}

/* ---- Ship customization cards ---- */
/* cover so every shot fills the card edge-to-edge (crops to fit) */
.part .pic{aspect-ratio:4/3;overflow:hidden;background:linear-gradient(180deg,var(--steel),var(--navy-2));}
.part .pic img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .4s var(--ease);}
.part:hover .pic img{transform:scale(1.05);}

/* ---- Media carousel ---- */
.carousel{margin-top:8px;}
.car-stage{display:flex;align-items:center;gap:14px;}
.car-main{
  flex:1;display:block;aspect-ratio:16/9;border-radius:14px;overflow:hidden;
  border:1px solid rgba(205,212,203,.16);box-shadow:0 40px 80px -40px #000;background:var(--navy-2);
}
.car-main img{width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .35s var(--ease);}
.car-main img.show{opacity:1;}
.car-nav{
  flex:none;width:46px;height:46px;border-radius:50%;cursor:pointer;
  display:grid;place-items:center;color:var(--foam);
  background:rgba(8,22,32,.7);border:1px solid rgba(205,212,203,.2);
  transition:background .2s,border-color .2s,transform .2s;
}
.car-nav:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.06);color:#fff;}
.car-nav i{font-size:18px;}
.car-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:14px;}
.car-thumb{
  padding:0;aspect-ratio:16/9;border-radius:8px;overflow:hidden;cursor:pointer;
  border:2px solid transparent;background:var(--navy-2);opacity:.72;
  transition:opacity .25s,border-color .25s,transform .25s;
}
.car-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.car-thumb:hover{opacity:1;transform:translateY(-3px);border-color:var(--accent);}
@media (max-width:720px){
  .car-nav{width:38px;height:38px;}
  .car-nav i{font-size:15px;}
  .car-thumbs{gap:8px;}
}

/* ---- Leaderboard section ---- */
.leaderboard-section{background:linear-gradient(180deg,var(--navy-2),var(--abyss));}
.leaderboard-section .cs-leaderboard{margin:8px auto 0;animation:none;}
