/* ============================================================
   D-Day Explorer — promotional site v2.0.0
   One clean generation. No layered hotfixes, no !important wars.
   Palette: night channel / brass / omaha sand. Self-hosted fonts.
   ============================================================ */

/* ---------- Fonts (self-hosted, GDPR-clean, latin + latin-ext subset) */
@font-face{font-family:"Oswald";src:url("/assets/fonts/oswald-var.woff2") format("woff2");font-weight:200 700;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("/assets/fonts/inter-var.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:"Space Mono";src:url("/assets/fonts/spacemono-bold.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* ---------- Tokens */
:root{
  --night:#06121E;
  --night-2:#081B2C;
  --panel:#0C2236;
  --panel-2:#0A1C2E;
  --line:rgba(237,228,210,.13);
  --line-brass:rgba(201,161,88,.28);
  --brass:#C9A158;
  --brass-bright:#EFC97E;
  --sand:#EDE4D2;
  --ink:#F4F1E9;
  --muted:#A4B4C0;
  --signal:#AD3833;
  --shadow:0 24px 70px rgba(0,0,0,.35);
  --radius:22px;
  --max:1180px;
  --display:"Oswald",Impact,"Arial Narrow",sans-serif;
  --body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --mono:"Space Mono",ui-monospace,"Cascadia Mono",Consolas,monospace;
}

/* ---------- Base */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--night);color:var(--ink);font-family:var(--body);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::before{content:"";position:fixed;inset:0;z-index:-2;background:
  radial-gradient(circle at 14% 12%,rgba(239,201,126,.10),transparent 30%),
  radial-gradient(circle at 88% 4%,rgba(70,123,154,.16),transparent 34%),
  linear-gradient(180deg,var(--night-2) 0%,var(--night) 100%)}
/* Faint route lines, as on a situation map */
body::after{content:"";position:fixed;inset:0;z-index:-1;opacity:.22;background-image:url("data:image/svg+xml,%3Csvg width='190' height='190' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M-20 48 C 36 14, 80 86, 142 42 S 222 64, 262 30' fill='none' stroke='%23C9A158' stroke-opacity='.16' stroke-width='1'/%3E%3Cpath d='M-30 128 C 32 92, 78 152, 138 112 S 215 137, 245 97' fill='none' stroke='%23ffffff' stroke-opacity='.10' stroke-width='1'/%3E%3Cpath d='M32 -20 C 92 38, 74 76, 147 98' fill='none' stroke='%23ffffff' stroke-opacity='.07' stroke-dasharray='7 12' stroke-width='2'/%3E%3C/svg%3E")}
img{max-width:100%;display:block}
figure{margin:0}
a{color:inherit}
:focus-visible{outline:2px solid var(--brass-bright);outline-offset:3px;border-radius:4px}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}
.icon{width:1em;height:1em;fill:currentColor;vertical-align:-0.12em}

/* ---------- Skip link */
.skip{position:absolute;left:-999px;top:8px;background:var(--sand);color:var(--night);padding:8px 14px;border-radius:8px;font-weight:700;text-decoration:none;z-index:999}
.skip:focus{left:8px}

/* ---------- Header */
.site-header{position:sticky;top:0;z-index:30;background:rgba(6,18,30,.8);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:72px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{width:42px;height:42px;border-radius:11px;box-shadow:0 10px 26px rgba(0,0,0,.3)}
.brand strong{font-family:var(--display);letter-spacing:.09em;font-size:17px;font-weight:600}
.brand strong span{color:var(--brass)}
.nav-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.lang-switch{display:flex;gap:6px;align-items:center;list-style:none;margin:0;padding:0}
.lang-switch a{font-size:13px;font-weight:600;text-decoration:none;color:var(--muted);padding:6px 10px;border:1px solid var(--line);border-radius:999px;transition:color .2s,background .2s,border-color .2s}
.lang-switch a:hover{color:var(--night);background:var(--brass);border-color:var(--brass)}
.lang-switch a[aria-current="page"]{color:var(--night);background:var(--brass);border-color:var(--brass)}
.nav-cta{background:var(--sand);color:var(--night);text-decoration:none;font-weight:800;padding:9px 16px;border-radius:999px;transition:transform .15s}
.nav-cta:hover{transform:translateY(-1px)}

/* ---------- Hero */
.hero{padding:80px 0 70px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.05fr .85fr;gap:54px;align-items:center}
.eyebrow{font-family:var(--mono);color:var(--brass-bright);text-transform:uppercase;letter-spacing:.13em;font-size:12.5px;font-weight:700}
h1,.section-title{font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;line-height:.94;margin:.18em 0;font-weight:600}
h1{font-size:clamp(44px,7.6vw,100px)}
h1 span,.section-title span{color:var(--brass)}
.lead{font-size:clamp(17px,2.1vw,21px);color:#DCE6EE;max-width:640px}
.store-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.store-badge{display:inline-flex;align-items:center;gap:13px;padding:12px 20px 12px 16px;border-radius:15px;background:#050B12;border:1px solid rgba(255,255,255,.16);text-decoration:none;box-shadow:0 12px 30px rgba(0,0,0,.25);min-width:190px;transition:transform .15s,border-color .2s}
.store-badge:hover{transform:translateY(-2px);border-color:var(--brass)}
.store-badge .icon{width:26px;height:26px;color:var(--sand);flex:none}
.store-small{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;line-height:1.1}
.store-name{display:block;font-weight:900;font-size:18px;line-height:1.2}
.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:32px}
.trust-chip{border:1px solid var(--line-brass);background:rgba(12,34,54,.72);border-radius:16px;padding:14px}
.trust-chip b{font-family:var(--display);font-weight:600;font-size:26px;color:var(--brass);display:block;line-height:1.05}
.trust-chip span{font-size:13px;color:var(--muted)}
.hero-card{position:relative;border-radius:32px;overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.12);background:#08121B}
.hero-card img{width:100%;height:auto}
.hero-tag{position:absolute;top:18px;right:18px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--sand);background:rgba(6,18,30,.78);border:1px solid var(--line-brass);padding:7px 11px;border-radius:10px;backdrop-filter:blur(8px)}
.floating-note{position:absolute;left:14px;bottom:14px;right:14px;padding:11px 14px;background:rgba(6,18,30,.86);border:1px solid var(--line-brass);border-radius:14px;backdrop-filter:blur(10px);font-weight:600;font-size:13.5px;line-height:1.35}

/* ---------- Sections */
.section{padding:74px 0;border-top:1px solid var(--line)}
.section-head{max-width:780px;margin-bottom:40px}
.section-title{font-size:clamp(34px,4.8vw,64px)}
.section-sub{font-size:17.5px;color:var(--muted);margin:.6em 0 0}
.section-note{font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;color:var(--brass-bright);margin-top:14px}

/* ---------- Signature: the waypoint route
   Each feature is a real place. The dashed line is the itinerary. */
.route{position:relative}
.route::before{content:"";position:absolute;left:27px;top:30px;bottom:26px;border-left:2px dashed rgba(201,161,88,.40)}
.waypoint{position:relative;display:grid;grid-template-columns:56px 1fr 330px;gap:26px;align-items:start;margin:0 0 46px}
.waypoint:last-child{margin-bottom:0}
.waypoint-pin{width:56px;height:56px;border-radius:50% 50% 50% 6px;transform:rotate(-45deg);display:grid;place-items:center;background:var(--brass);color:var(--night);box-shadow:0 0 0 9px rgba(201,161,88,.13),0 14px 28px rgba(0,0,0,.3);z-index:1;align-self:start;margin-top:6px}
.waypoint-pin .icon{width:24px;height:24px;transform:rotate(45deg)}
.waypoint-body{background:linear-gradient(135deg,rgba(12,34,54,.86),rgba(7,22,34,.9));border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:24px 26px;box-shadow:0 20px 48px rgba(0,0,0,.2)}
.waypoint-geo{display:flex;flex-wrap:wrap;gap:6px 14px;align-items:baseline;font-family:var(--mono);font-size:12.5px;letter-spacing:.05em;color:var(--brass-bright)}
.waypoint-geo .place{color:var(--sand);letter-spacing:.02em}
.waypoint-body h3{font-family:var(--display);font-weight:600;font-size:28px;letter-spacing:.03em;text-transform:uppercase;margin:8px 0 9px}
.waypoint-body p{margin:0;color:#D6E0E8}
.phone-shot{border-radius:26px;padding:10px;background:linear-gradient(145deg,#101B27,#03070B);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.15);transform:rotate(1.2deg);justify-self:end;align-self:center}
.phone-shot img{border-radius:18px;width:100%;height:auto}
.waypoint:nth-child(even) .phone-shot{transform:rotate(-1.4deg)}

/* ---------- Cards (differentiators) */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:rgba(12,34,54,.82);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:24px;box-shadow:0 18px 50px rgba(0,0,0,.18)}
.card .icon{width:27px;height:27px;color:var(--brass)}
.card h3{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:22px;margin:13px 0 8px}
.card p{margin:0;color:var(--muted)}

/* ---------- Screens gallery */
.screen-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;align-items:start}
.screen-card{margin:0;background:linear-gradient(145deg,rgba(8,19,31,.97),rgba(4,10,17,.97));border:1px solid rgba(255,255,255,.12);border-radius:24px;box-shadow:0 18px 48px rgba(0,0,0,.26);overflow:hidden;display:flex;flex-direction:column}
.screen-frame{padding:18px 16px 8px;background:radial-gradient(circle at 50% 8%,rgba(201,161,88,.11),transparent 38%),#06131F;display:flex;align-items:flex-start;justify-content:center}
.screen-frame img{width:auto;max-width:100%;height:auto;border-radius:20px;box-shadow:0 16px 38px rgba(0,0,0,.32)}
.screen-card figcaption{padding:15px 16px;background:rgba(5,13,21,.96);border-top:1px solid var(--line-brass);font-weight:800;line-height:1.3;min-height:60px;display:flex;align-items:center}

/* ---------- Audiences & FAQ */
.audiences{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.audiences span{padding:9px 14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:999px;color:#DCE6EE;font-size:15px}
.faq{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:38px}
.faq details{background:rgba(12,34,54,.8);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:17px 18px}
.faq summary{font-weight:800;color:var(--sand);cursor:pointer}
.faq summary::marker{color:var(--brass)}
.faq p{color:var(--muted);margin:12px 0 0}

/* ---------- CTA */
.cta{position:relative;overflow:hidden;background:linear-gradient(135deg,rgba(201,161,88,.18),rgba(12,34,54,.96));border:1px solid var(--line-brass);border-radius:30px;padding:44px;display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center;box-shadow:var(--shadow)}
.cta h2{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:clamp(32px,4.8vw,58px);line-height:.97;margin:0}
.cta .section-sub{margin-top:10px}

/* ---------- Footer */
.footer{padding:42px 0 30px;color:var(--muted);border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px}
.footer strong{color:var(--sand)}
.footer a{color:var(--sand);text-decoration:none}
.footer a:hover{color:var(--brass-bright);text-decoration:underline}
.footer p{margin:.5em 0}
.footer-bottom{margin-top:30px;padding-top:18px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:8px 26px;align-items:baseline;justify-content:space-between}
.small{font-size:13px}
.muted{color:var(--muted)}
.nocookies{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--muted)}

/* ---------- Buttons */
.button-link{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--brass);color:var(--night);text-decoration:none;font-weight:900;border-radius:999px;padding:12px 20px;transition:transform .15s}
.button-link:hover{transform:translateY(-1px)}
.button-link.dark{background:rgba(255,255,255,.08);color:var(--sand);border:1px solid rgba(255,255,255,.14)}

/* ---------- Legal & 404 pages */
.doc{max-width:820px;margin:0 auto;padding:64px 24px 80px}
.doc h1{font-size:clamp(34px,5vw,58px)}
.doc h2{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:24px;margin:1.8em 0 .5em;color:var(--sand)}
.doc p,.doc li{color:#CBD6DF}
.doc .todo{background:rgba(173,56,51,.14);border:1px solid rgba(173,56,51,.45);border-radius:10px;padding:3px 9px;color:#F0B9B5;font-family:var(--mono);font-size:13px}
.doc-back{display:inline-block;margin-top:34px}
.center{text-align:center}

/* ---------- Reveal: content visible by default; JS + motion-ok adds animation */
@media (prefers-reduced-motion:no-preference){
  html.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .65s ease,transform .65s ease}
  html.js .reveal.in{opacity:1;transform:none}
}

/* ---------- Responsive */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr}
  .waypoint{grid-template-columns:56px 1fr}
  .phone-shot{grid-column:2;justify-self:start;max-width:330px}
  .cards,.faq,.footer-grid{grid-template-columns:1fr 1fr}
  .screen-grid{grid-template-columns:1fr 1fr}
  .cta{grid-template-columns:1fr}
  .trust-row{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  .container{padding:0 18px}
  .site-header{position:relative}
  .nav{align-items:flex-start;flex-direction:column;padding:13px 0;gap:10px}
  .nav-actions{width:100%;justify-content:space-between}
  .lang-switch{overflow-x:auto;max-width:100%;padding-bottom:4px}
  .hero{padding:42px 0}
  h1{font-size:clamp(42px,13vw,58px)}
  .waypoint{grid-template-columns:1fr;gap:14px}
  .route::before{display:none}
  .waypoint-pin{width:46px;height:46px;margin-top:0}
  .waypoint-pin .icon{width:20px;height:20px}
  .phone-shot{grid-column:auto;max-width:none}
  .trust-row{grid-template-columns:1fr 1fr}
  .store-badge{width:100%}
  .cards,.faq,.screen-grid,.footer-grid{grid-template-columns:1fr}
  .cta{padding:28px}
}

/* ---------- Print */
@media print{
  html{scroll-behavior:auto}
  body::before,body::after{position:absolute}
  .site-header{position:static}
  html.js .reveal{opacity:1;transform:none;transition:none}
  .waypoint,.card,.screen-card,.cta{break-inside:avoid;page-break-inside:avoid}
  .screen-grid{grid-template-columns:1fr 1fr}
}
