/* =============================================
   AnimateMyMap — Premium v4 — Stunning Dark
   ============================================= */
:root{
    --bg:#050505;
    --bg-2:#0a0a0a;
    --surface:rgba(255,255,255,.04);
    --surface-solid:#111111;
    --surface-2:#1a1a1a;
    --glass:rgba(255,255,255,.03);
    --border:rgba(255,255,255,.07);
    --border-h:rgba(255,255,255,.15);
    --accent:#d4a957;
    --accent-2:#ead29b;
    --accent-bright:#e9c97e;
    --grad:#d4a957;
    --grad-warm:#f97316;
    --text:#f5f5f7;
    --text-2:rgba(255,255,255,.55);
    --text-3:rgba(255,255,255,.3);
    --heading:'Space Grotesk',sans-serif;
    --body:'Inter',sans-serif;
    --ease:cubic-bezier(.16,1,.3,1);
    --ease-out:cubic-bezier(.33,1,.68,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-padding-top:80px}
body{font-family:var(--body);background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:1140px;margin:0 auto;padding:0}

/* ===== NAV ===== */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.1rem 2rem;transition:all .5s var(--ease);background:transparent}
#navbar.scrolled{background:rgba(5,5,5,.85);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border);padding:.7rem 2rem}
.nav-container{max-width:1140px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:.6rem;z-index:1001}
.logo-icon{flex-shrink:0;display:flex;align-items:center}
.logo-text{font-family:var(--heading);font-size:1.3rem;font-weight:700;letter-spacing:-.02em}
.logo-text .accent{color:#d4a957}
.nav-links {
    display: flex;
    align-items: center;
    gap: 3rem;
}
.nav-links a{font-size:.85rem;font-weight:400;color:var(--text-2);transition:color .3s;position:relative;letter-spacing:.01em}
.nav-links a:not(.nav-cta):hover{color:var(--text)}
.nav-links a:not(.nav-cta)::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--text);border-radius:1px;transition:width .3s var(--ease)}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{background:#fff;color:#000!important;padding:.45rem 1.15rem;border-radius:100px;font-weight:600;font-size:.82rem!important;transition:all .3s var(--ease)!important;letter-spacing:.01em}
.nav-cta:hover{transform:scale(1.04);box-shadow:0 4px 24px rgba(255,255,255,.15)}
/* =============================================
   MOBILE MENU — full-screen overlay takeover
   Single source of truth: body.menu-open class.
   - Toggle button transforms into an X via that body class.
   - Overlay fades in via that body class.
   - Body scroll locks via that body class.
   ============================================= */

/* Toggle button (hamburger). Hidden on desktop, shown on mobile. */
.nav-toggle{display:none;width:44px;height:44px;padding:0;background:transparent;border:none;cursor:pointer;position:relative;z-index:1002;-webkit-tap-highlight-color:transparent}
.nav-toggle-bar{display:block;position:absolute;left:50%;width:22px;height:2px;background:#fff;border-radius:2px;transform:translateX(-50%);transition:top 0.25s cubic-bezier(0.4,0,0.2,1) 0.25s,transform 0.25s cubic-bezier(0.4,0,0.2,1) 0s,opacity 0.15s ease 0.1s}
.nav-toggle-bar:nth-child(1){top:14px}
.nav-toggle-bar:nth-child(2){top:21px}
.nav-toggle-bar:nth-child(3){top:28px}
/* Open state: bars 1+3 collapse to center then rotate; bar 2 fades. */
body.menu-open .nav-toggle-bar{transition:top 0.25s cubic-bezier(0.4,0,0.2,1) 0s,transform 0.25s cubic-bezier(0.4,0,0.2,1) 0.25s,opacity 0.15s ease}
body.menu-open .nav-toggle-bar:nth-child(1){top:21px;transform:translateX(-50%) rotate(45deg)}
body.menu-open .nav-toggle-bar:nth-child(2){opacity:0}
body.menu-open .nav-toggle-bar:nth-child(3){top:21px;transform:translateX(-50%) rotate(-45deg)}

/* Full-screen overlay. Hidden by default (opacity 0 + pointer-events none)
   so the layout doesn't fight existing content. Body class drives visibility. */
.nav-overlay{position:fixed;inset:0;z-index:1001;background:rgba(5,5,8,0.98);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);opacity:0;pointer-events:none;transition:opacity 0.28s ease;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}
body.menu-open .nav-overlay{opacity:1;pointer-events:auto}

/* Three-zone column: logo top, .nav-overlay-links middle (flex:1), auth bottom. */
.nav-overlay-inner{flex:1;display:flex;flex-direction:column;align-items:stretch;width:100%;max-width:420px;margin:0 auto;padding:1.5rem 1.5rem 2rem;padding-top:calc(1.5rem + env(safe-area-inset-top));padding-bottom:calc(2rem + env(safe-area-inset-bottom))}

/* Logo at the top — tap returns to landing. */
.nav-overlay-logo{display:inline-flex;align-items:center;gap:0.55rem;align-self:center;padding:0.55rem 1rem;border-radius:12px;text-decoration:none;color:inherit;transition:background 0.18s ease;-webkit-tap-highlight-color:transparent}
.nav-overlay-logo:active,.nav-overlay-logo:hover{background:rgba(255,255,255,0.04)}
.nav-overlay-logo .logo-icon{display:flex;align-items:center;flex-shrink:0}
.nav-overlay-logo .logo-text{font-family:var(--heading);font-size:1.2rem;font-weight:700;color:#fff;letter-spacing:-0.02em}
.nav-overlay-logo .logo-text .accent{color:var(--accent)}

/* Middle zone: nav links centered vertically. */
.nav-overlay-links{flex:1;display:flex;flex-direction:column;justify-content:center;gap:0.3rem;margin:1rem 0}

/* Top-level nav links inside the middle zone. */
.nav-overlay-link{display:block;padding:1rem 1.25rem;font-family:var(--heading);font-size:1.4rem;font-weight:500;color:rgba(255,255,255,0.85);text-align:center;border-radius:14px;text-decoration:none;letter-spacing:-0.01em;transition:background 0.18s ease,color 0.18s ease}
.nav-overlay-link:active,.nav-overlay-link:hover{background:rgba(255,255,255,0.05);color:#fff}

/* Auth links container (filled by spa-router updateNavigation()).
   Stacks vertically below a divider. The links inside use .nav-cta for the
   primary call-to-action, .nav-overlay-logout for sign-out, and inherit base
   styling otherwise. */
.nav-overlay-auth{display:flex;flex-direction:column;gap:0.5rem;width:100%;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,0.08)}
.nav-overlay-auth a{display:block;padding:1rem 1.25rem;font-family:var(--heading);font-size:1.15rem;font-weight:500;color:rgba(255,255,255,0.85);text-align:center;border-radius:14px;text-decoration:none;transition:background 0.18s ease,color 0.18s ease,transform 0.18s ease}
.nav-overlay-auth a:active,.nav-overlay-auth a:hover{background:rgba(255,255,255,0.05);color:#fff}
.nav-overlay-auth a.nav-cta{background:var(--accent);color:#fff !important;font-weight:600;box-shadow:0 8px 30px rgba(212,169,87,0.25)}
.nav-overlay-auth a.nav-cta:active,.nav-overlay-auth a.nav-cta:hover{background:#e9c97e;transform:scale(1.02)}
/* Sign-out: subtle, transparent, with destructive hover tint. */
.nav-overlay-auth a.nav-overlay-logout{background:transparent;color:rgba(255,255,255,0.55) !important;border:1px solid rgba(255,255,255,0.08);font-weight:500;font-size:1rem;box-shadow:none;margin-top:0.25rem}
.nav-overlay-auth a.nav-overlay-logout:active,.nav-overlay-auth a.nav-overlay-logout:hover{background:rgba(239,68,68,0.08);border-color:rgba(239,68,68,0.2);color:#fca5a5 !important;transform:none}

/* Lock body scroll when overlay is open. */
body.menu-open{overflow:hidden}

/* Desktop: nuke the overlay entirely so it can never interfere. */
@media (min-width:769px){
    .nav-overlay,.nav-toggle{display:none !important}
}

/* ===== HERO ===== */
#hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
#hero-map{position:absolute;inset:-100%;z-index:0;opacity:.15;transform:scale(0.3334);transform-origin:center;will-change:transform}
#hero-map .maplibregl-canvas{width:100%!important;height:100%!important}
.hero-vignette{position:absolute;inset:0;z-index:1;pointer-events:none;background:
    radial-gradient(ellipse 60% 50% at 50% 50%,transparent 0%,rgba(5,5,5,.6) 60%,rgba(5,5,5,.95) 100%),
    linear-gradient(180deg,rgba(5,5,5,.4) 0%,transparent 30%,transparent 70%,rgba(5,5,5,1) 100%)}
/* Fractal-noise dither over the vignette gradients to break up the
   banding rings the user could see at low opacity. Inline SVG, no
   asset, tiles 180×180 across the hero. mix-blend-mode: overlay maps
   the grayscale noise onto the gradient luminance — light areas get
   brighter speckle, dark areas get darker — which is what hides the
   step transitions inside the radial fade. */
.hero-vignette::after{content:'';position:absolute;inset:0;pointer-events:none;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
    background-size:180px 180px;background-repeat:repeat;
    opacity:.1;mix-blend-mode:overlay}
.hero-content{position:relative;z-index:2;text-align:center;max-width:850px;padding:0 2rem}
.hero-badge{display:inline-flex;align-items:center;gap:.55rem;padding:.4rem 1.1rem;border-radius:100px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);font-size:.75rem;font-weight:500;color:var(--text-2);margin-bottom:2rem;letter-spacing:.04em;text-transform:uppercase;backdrop-filter:blur(10px)}
.rec-dot{width:6px;height:6px;border-radius:50%;background:#ef4444;animation:rec-blink 1.2s ease-in-out infinite}
@keyframes rec-blink{0%,100%{opacity:1}50%{opacity:.2}}
#hero h1{font-family:var(--heading);font-size:clamp(3rem,7vw,5.8rem);font-weight:700;line-height:1.02;letter-spacing:-.05em;margin-bottom:1.6rem;color:#fff}
.gradient-text{color:#d4a957}
.hero-sub{font-size:1.1rem;line-height:1.8;color:var(--text-2);max-width:540px;margin:0 auto 2.8rem;font-weight:400}
.hero-btns{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:2.8rem}
.btn-primary{display:inline-flex;align-items:center;gap:.55rem;padding:.8rem 1.8rem;border-radius:100px;font-size:.92rem;font-weight:600;font-family:var(--body);color:#000;background:#fff;border:none;cursor:pointer;transition:all .4s var(--ease);position:relative;letter-spacing:.01em}
.btn-primary:hover{transform:scale(1.04);box-shadow:0 8px 40px rgba(255,255,255,.15)}
.btn-primary.btn-lg{padding:.9rem 2.4rem;font-size:1rem}
.btn-ghost{display:inline-flex;align-items:center;gap:.55rem;padding:.8rem 1.8rem;border-radius:100px;font-size:.92rem;font-weight:500;color:var(--text);background:transparent;border:1px solid rgba(255,255,255,.15);cursor:pointer;transition:all .4s var(--ease);letter-spacing:.01em}
.btn-ghost:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.25);transform:scale(1.02)}
.hero-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem}
.hero-chips span{padding:.35rem .9rem;border-radius:100px;font-size:.7rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);color:var(--text-3)}
.scroll-cue{display:none;position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:2;opacity:.3}
.scroll-line{width:1px;height:48px;border-radius:1px;background:rgba(255,255,255,.4);animation:scroll-pulse 2.5s ease-in-out infinite}
@keyframes scroll-pulse{0%{opacity:1;transform:scaleY(1)}50%{opacity:.2;transform:scaleY(.4)}100%{opacity:1;transform:scaleY(1)}}

/* ===== STATS ===== */
#stats{position:relative;z-index:2;padding:0 2rem;margin-top:-2.5rem}
.stats-inner{max-width:800px;margin:0 auto;display:flex;align-items:center;justify-content:center;padding:1.8rem 2rem;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:20px;backdrop-filter:blur(16px)}
.stat{flex:1;text-align:center;padding:.5rem 0}
.stat-val{font-family:var(--heading);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;color:#fff;line-height:1.1}
.stat-plus{font-family:var(--heading);font-size:clamp(1.1rem,2vw,1.5rem);font-weight:700;color:#fff}
.stat-lbl{display:block;font-size:.7rem;font-weight:400;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-top:.3rem}
.stat-sep{width:1px;height:32px;background:var(--border);flex-shrink:0}

/* ===== SECTION HEADERS ===== */
.sec-head{text-align:center;margin-bottom:4rem}
.tag{display:inline-block;padding:.3rem .85rem;border-radius:100px;background:rgba(212,169,87,.1);border:1px solid rgba(212,169,87,.2);font-size:.68rem;font-weight:600;color:var(--accent-bright);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.2rem}
.sec-head h2{font-family:var(--heading);font-size:clamp(2.2rem,4.5vw,3.4rem);font-weight:700;letter-spacing:-.04em;line-height:1.1;margin-bottom:.8rem;color:#fff}
.sec-sub{font-size:1.05rem;color:var(--text-2);max-width:480px;margin:0 auto;line-height:1.75;font-weight:400}

/* =============================================
   FEATURES — Apple-style sticky scroll
   ============================================= */
#features{padding:8rem 0 0;position:relative;z-index:1}
.feat-scroll{height:400vh;position:relative}
.feat-pin{position:sticky;top:0;height:100vh;display:flex;align-items:center;overflow:hidden}
.feat-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:center;width:100%}
.feat-list{display:flex;flex-direction:column;gap:0}
.feat-item{padding:1.3rem 1.6rem;border-radius:12px;border-left:2px solid transparent;opacity:.25;transition:all .6s var(--ease);cursor:default}
.feat-item.active{opacity:1;border-left-color:var(--accent);background:rgba(212,169,87,.04)}
.feat-num{font-family:var(--heading);font-size:.68rem;font-weight:700;color:var(--accent-bright);letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:.4rem}
.feat-item h3{font-family:var(--heading);font-size:1.1rem;font-weight:600;margin-bottom:.25rem;transition:color .4s;color:var(--text-2)}
.feat-item.active h3{color:#fff}
.feat-item p{font-size:.85rem;line-height:1.7;color:var(--text-2);max-height:0;overflow:hidden;opacity:0;transition:all .6s var(--ease)}
.feat-item.active p{max-height:120px;opacity:1;margin-top:.25rem}

/* Feature visual — screen mockup */
.feat-visual{display:flex;justify-content:center}
.feat-screen{width:100%;max-width:640px;border-radius:20px;overflow:hidden;border:1px solid var(--border);background:var(--bg-2);box-shadow:0 40px 100px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.03) inset}
.feat-screen-bar{display:flex;align-items:center;gap:6px;padding:12px 16px;background:rgba(255,255,255,.03);border-bottom:1px solid var(--border)}
.feat-screen-bar span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.08)}
.feat-screen-bar span:nth-child(1){background:#ff5f57}
.feat-screen-bar span:nth-child(2){background:#febc2e}
.feat-screen-bar span:nth-child(3){background:#28c840}
.feat-canvas{position:relative;aspect-ratio:4/3;overflow:hidden;background:#0a0e1a}
.fv{position:absolute;inset:0;opacity:0;transition:opacity .7s var(--ease);pointer-events:none}
.fv.active{opacity:1}
.fv-video{width:100%;height:100%;object-fit:cover;display:block}

/* =============================================
   LIVE DEMO MAP
   ============================================= */
#demo{padding:8rem 0;position:relative;z-index:1}
.demo-note{display:inline-flex;align-items:flex-start;gap:.6rem;max-width:640px;margin:1.5rem auto 0;padding:.75rem 1.1rem;background:rgba(212,169,87,.08);border:1px solid rgba(212,169,87,.2);border-radius:12px;font-size:.82rem;line-height:1.55;color:var(--text-2);text-align:left}
.demo-note svg{flex-shrink:0;color:#e9c97e;margin-top:2px}
.demo-wrap{border-radius:20px;overflow:hidden;border:1px solid var(--border);background:var(--bg-2);box-shadow:0 40px 120px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.03) inset;margin-top:2.5rem}
.demo-toolbar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:rgba(255,255,255,.03);border-bottom:1px solid var(--border)}
.demo-style-switcher{display:flex;gap:2px;margin-left:12px;background:rgba(255,255,255,.04);border-radius:8px;padding:2px}
.demo-style-btn{background:none;border:none;color:var(--text-3);padding:5px 8px;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center}
.demo-style-btn:hover{color:var(--text-2)}
.demo-style-btn.active{background:rgba(255,255,255,.08);color:var(--accent-bright)}
.demo-title{margin-left:auto;font-size:.72rem;font-weight:500;color:var(--text-3);letter-spacing:.04em;text-transform:uppercase}
.demo-body{display:flex;height:520px}
.demo-sidebar{width:240px;flex-shrink:0;background:rgba(255,255,255,.02);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.demo-panel-head{padding:10px 14px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);border-bottom:1px solid var(--border)}
.demo-country-list{flex:1;overflow-y:auto;padding:6px}
.demo-country-list::-webkit-scrollbar{width:4px}
.demo-country-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.demo-empty{padding:20px 12px;text-align:center;font-size:.75rem;color:var(--text-3);line-height:1.6}
.demo-country-chip{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:8px;margin-bottom:2px;cursor:pointer;transition:background .15s;font-size:.8rem;color:var(--text)}
.demo-country-chip:hover{background:rgba(255,255,255,.05)}
.demo-country-chip.active{background:rgba(212,169,87,.12)}
.demo-chip-swatch{width:14px;height:14px;border-radius:4px;flex-shrink:0;border:1px solid rgba(255,255,255,.1)}
.demo-chip-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.demo-chip-remove{background:none;border:none;color:var(--text-3);cursor:pointer;padding:2px;line-height:1;font-size:.9rem;border-radius:4px;transition:color .15s}
.demo-chip-remove:hover{color:#f87171}
.demo-controls{padding:10px 12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}
.demo-control-group{display:flex;align-items:center;justify-content:space-between;gap:8px}
.demo-control-group label{font-size:.7rem;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.demo-control-group input[type="color"]{-webkit-appearance:none;appearance:none;width:28px;height:22px;border:1px solid var(--border);border-radius:5px;background:none;cursor:pointer;padding:1px}
.demo-control-group input[type="color"]::-webkit-color-swatch-wrapper{padding:0}
.demo-control-group input[type="color"]::-webkit-color-swatch{border:none;border-radius:3px}
.demo-control-group select{background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.72rem;padding:4px 8px;cursor:pointer;outline:none}
.demo-control-group select:focus{border-color:var(--accent)}
.demo-control-group select option{background:var(--bg-2);color:var(--text)}
.demo-anim-divider{display:flex;align-items:center;gap:6px;padding:4px 10px;margin:2px 6px}
.demo-anim-line{flex:1;height:1px;background:var(--accent);opacity:.3}
.demo-anim-label{display:flex;align-items:center;gap:4px;flex-shrink:0}
.demo-anim-label select{background:rgba(212,169,87,.1);border:1px solid rgba(212,169,87,.25);border-radius:5px;color:var(--accent-bright);font-size:.62rem;font-weight:600;padding:2px 6px;cursor:pointer;outline:none;text-transform:uppercase;letter-spacing:.03em}
.demo-anim-label select:focus{border-color:var(--accent)}
.demo-anim-label select option{background:var(--bg-2);color:var(--text)}
.demo-anim-remove{background:none;border:none;color:var(--text-3);cursor:pointer;padding:1px;font-size:.8rem;line-height:1;border-radius:3px;transition:color .15s}
.demo-anim-remove:hover{color:#f87171}
.demo-actions{padding:8px 12px;border-top:1px solid var(--border);display:flex;gap:6px}
.demo-actions-bottom{border-top:none;padding-top:0}
.demo-btn{flex:1;padding:7px 0;border:none;border-radius:8px;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;justify-content:center;gap:5px}
.demo-btn-anim{background:rgba(212,169,87,.12);color:var(--accent-bright);border:1px solid rgba(212,169,87,.2)}
.demo-btn-anim:hover{background:rgba(212,169,87,.2);transform:translateY(-1px)}
.demo-btn-play{background:var(--accent);color:#fff}
.demo-btn-play:hover{background:#e9c97e;transform:translateY(-1px)}
.demo-btn-play:disabled{opacity:.4;pointer-events:none}
.demo-btn-clear{background:rgba(255,255,255,.05);color:var(--text-2);border:1px solid var(--border)}
.demo-btn-clear:hover{background:rgba(255,255,255,.08);color:var(--text)}
.demo-playing .demo-country-chip.highlight{background:rgba(212,169,87,.18)}
.demo-playing .demo-anim-divider.highlight{background:rgba(212,169,87,.08);border-radius:6px}
.demo-map-area{flex:1;position:relative;min-width:0}
#demo-text-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}
#demo-map{width:100%;height:100%}
.demo-launch{position:absolute;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;width:100%;height:100%;border:none;cursor:pointer;background:radial-gradient(ellipse at center, rgba(212,169,87,.05) 0%, transparent 60%), linear-gradient(180deg, #0a0a0a 0%, #050505 100%);color:var(--text);font-family:inherit;transition:opacity .35s var(--ease)}
.demo-launch::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%, transparent 0%, transparent 35%, rgba(0,0,0,.3) 100%);pointer-events:none}
.demo-launch-inner{position:relative;z-index:1;display:flex;align-items:center;gap:.85rem;padding:.95rem 1.5rem .95rem 1.2rem;background:rgba(212,169,87,.07);border:1px solid rgba(212,169,87,.25);border-radius:12px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:transform .25s var(--ease),background .25s,border-color .25s}
.demo-launch:hover .demo-launch-inner{background:rgba(212,169,87,.1);border-color:rgba(212,169,87,.35);transform:translateY(-1px)}
.demo-launch-icon{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:var(--accent);color:#000;flex-shrink:0;transition:transform .25s var(--ease)}
.demo-launch:hover .demo-launch-icon{transform:scale(1.04)}
.demo-launch-icon svg{margin-left:2px}
.demo-launch-title{font-family:var(--heading);font-size:.92rem;font-weight:600;letter-spacing:.01em;color:var(--text)}
.demo-launch-leaving{opacity:0;pointer-events:none}
#demo-map .maplibregl-canvas{width:100%!important;height:100%!important}
.demo-info{padding:10px 16px;background:rgba(255,255,255,.03);font-size:.8rem;font-weight:500;color:var(--text-2);border-top:1px solid var(--border);display:flex;align-items:center;gap:.5rem;min-height:40px;transition:all .3s}
.demo-info.active{color:#f59e0b}
@media(max-width:768px){
    .demo-body{flex-direction:column;height:auto}
    .demo-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border)}
    .demo-country-list{max-height:120px}
    .demo-map-area{height:360px}
    .demo-style-switcher{display:none}
}

/* =============================================
   ANIMATIONS — Horizontal scroll
   ============================================= */
#animations{padding:6rem 0 0;position:relative;z-index:1;overflow:hidden}
.anim-horizontal{position:relative;width:100%;overflow:visible}
.anim-track{display:flex;gap:1.5rem;padding:2rem 2rem 5rem;will-change:transform}
.anim-slide{flex:0 0 400px;border-radius:20px;overflow:hidden;background:rgba(255,255,255,.03);border:1px solid var(--border);transition:all .5s var(--ease)}
.anim-slide:hover{border-color:var(--border-h);transform:translateY(-8px);box-shadow:0 30px 80px rgba(0,0,0,.4)}
.anim-vis{height:220px;background:var(--bg);position:relative;overflow:hidden}
.anim-video{width:100%;height:100%;object-fit:cover;display:block}
.anim-info{padding:1.4rem 1.6rem}
.anim-info h3{font-family:var(--heading);font-size:1.1rem;font-weight:600;margin-bottom:.35rem;color:#fff}
.anim-info p{font-size:.82rem;color:var(--text-2);line-height:1.7}

/* =============================================
   HOW IT WORKS — Animated timeline
   ============================================= */
#how-it-works{padding:8rem 0;position:relative;z-index:1}
.timeline{max-width:640px;margin:0 auto;position:relative;padding-left:44px}
.timeline-line{position:absolute;left:14px;top:0;bottom:0;width:1.5px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden}
.timeline-progress{width:100%;height:0;background:var(--grad);border-radius:2px;transition:height .1s linear}
.tl-step{position:relative;padding:0 0 3.5rem 2rem}
.tl-step:last-child{padding-bottom:0}
.tl-dot{position:absolute;left:-37px;top:6px;width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.08);border:2px solid var(--bg);transition:all .5s var(--ease);z-index:1}
.tl-step.active .tl-dot{background:var(--accent);box-shadow:0 0 20px rgba(212,169,87,.5)}
.tl-card{padding:1.8rem 2rem;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid var(--border);transition:all .6s var(--ease);opacity:.35;transform:translateX(12px)}
.tl-step.active .tl-card{opacity:1;transform:translateX(0);border-color:rgba(212,169,87,.2);box-shadow:0 16px 50px rgba(0,0,0,.3)}
.tl-num{font-family:var(--heading);font-size:.68rem;font-weight:700;color:var(--accent-bright);letter-spacing:.1em;display:block;margin-bottom:.5rem}
.tl-card h3{font-family:var(--heading);font-size:1.15rem;font-weight:600;margin-bottom:.4rem;color:#fff}
.tl-card p{font-size:.85rem;color:var(--text-2);line-height:1.75}

/* =============================================
   USE CASES
   ============================================= */
#use-cases{padding:8rem 0;position:relative;z-index:1}
.uc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.uc-card{padding:2.2rem 1.6rem;border-radius:20px;background:rgba(255,255,255,.03);border:1px solid var(--border);text-align:center;transition:all .5s var(--ease);position:relative;overflow:hidden}
.uc-card::before{content:'';position:absolute;inset:0;border-radius:20px;background:rgba(212,169,87,.04);opacity:0;transition:opacity .5s}
.uc-card:hover{transform:translateY(-10px);border-color:rgba(255,255,255,.12);box-shadow:0 30px 80px rgba(0,0,0,.3)}
.uc-card:hover::before{opacity:1}
.uc-icon-wrap{width:52px;height:52px;border-radius:14px;background:rgba(255,255,255,.04);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto 1.1rem}
.uc-card h3{font-family:var(--heading);font-size:1rem;font-weight:600;margin-bottom:.4rem;color:#fff}
.uc-card p{font-size:.82rem;color:var(--text-2);line-height:1.7}

/* =============================================
   CTA
   ============================================= */
/* ===== PRODUCT PREVIEW ===== */
#product-preview{padding:6rem 0 4rem;position:relative}
.preview-header{text-align:center;margin-bottom:3rem}
.preview-header h2{font-family:var(--heading);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;letter-spacing:-.04em;color:#fff;margin-bottom:.6rem}
.preview-header p{font-size:1rem;color:var(--text-2);max-width:540px;margin:0 auto}
.preview-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:1.5rem;align-items:start}
.preview-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:16px;overflow:hidden;transition:transform .4s var(--ease)}
.preview-card-main{transform:perspective(1200px) rotateY(3deg);grid-row:span 1}
.preview-card-side{transform:perspective(1200px) rotateY(-4deg)}
.preview-card:hover{transform:perspective(1200px) rotateY(0deg) translateY(-4px)}
.preview-chrome{padding:.6rem 1rem;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center}
.preview-chrome-title{font-size:.7rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em}
.preview-body{padding:1.2rem}
.preview-greeting{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.preview-avatar{width:36px;height:36px;border-radius:50%;background:rgba(212,169,87,.2);border:2px solid rgba(212,169,87,.3);flex-shrink:0}
.preview-avatar-lg{width:48px;height:48px}
.preview-name{font-size:.85rem;font-weight:600;color:#fff}
.preview-badge{display:inline-block;font-size:.6rem;font-weight:700;padding:.15rem .45rem;border-radius:4px;background:rgba(212,169,87,.15);color:#e9c97e;margin-top:.15rem;text-transform:uppercase;letter-spacing:.04em}
.preview-stats-row{display:flex;gap:1rem;margin-bottom:1rem}
.preview-stat{display:flex;flex-direction:column;gap:.15rem;flex:1;padding:.5rem;background:rgba(255,255,255,.03);border-radius:8px;border:1px solid rgba(255,255,255,.05)}
.preview-stat-val{font-size:.75rem;font-weight:600;color:#fff}
.preview-stat-label{font-size:.6rem;color:var(--text-3)}
.preview-actions{display:flex;gap:.5rem}
.preview-btn-mock{flex:1;padding:.4rem;border-radius:8px;background:#d4a957;color:#fff;font-size:.65rem;font-weight:600;text-align:center}
.preview-btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--text-2)}
.preview-toggle-mock{display:flex;gap:.3rem;margin-bottom:.75rem;padding:.2rem;background:rgba(255,255,255,.04);border-radius:6px;font-size:.6rem;color:var(--text-3)}
.preview-toggle-mock span{flex:1;text-align:center;padding:.25rem;border-radius:4px}
.preview-toggle-active{background:rgba(212,169,87,.2)!important;color:#e9c97e!important;font-weight:600}
.preview-plan-cards{display:flex;flex-direction:column;gap:.4rem}
.preview-plan{padding:.5rem .6rem;border-radius:8px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center}
.preview-plan-pop{border-color:rgba(212,169,87,.3);background:rgba(212,169,87,.06);position:relative}
.preview-plan-label{position:absolute;top:-.45rem;right:.5rem;font-size:.5rem;font-weight:700;color:#e9c97e;background:var(--bg-1);padding:0 .3rem;text-transform:uppercase;letter-spacing:.05em}
.preview-plan-name{font-size:.7rem;font-weight:600;color:#fff}
.preview-plan-price{font-size:.7rem;font-weight:700;color:#fff}
.preview-plan-price span{font-size:.55rem;color:var(--text-3);font-weight:400}
.preview-acct-hero{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.06)}
.preview-acct-badges{display:flex;gap:.3rem}
.preview-acct-badge{font-size:.55rem;font-weight:600;padding:.15rem .4rem;border-radius:4px}
.preview-acct-badge-beta{background:rgba(212,169,87,.12);color:#e9c97e}
.preview-acct-badge-plan{background:rgba(52,211,153,.1);color:#34d399}
.preview-acct-sections{display:flex;flex-direction:column;gap:.4rem}
.preview-acct-row{height:10px;border-radius:4px;background:rgba(255,255,255,.04)}
.preview-acct-row-sm{width:60%}
@media(max-width:768px){.preview-grid{grid-template-columns:1fr;max-width:400px;margin:0 auto}.preview-card-main,.preview-card-side{transform:none}}

/* ===== CTA ===== */
#cta{padding:5rem 0 8rem;position:relative;z-index:1}
.cta-inner{position:relative;background:linear-gradient(135deg,#1a1408 0%,#0d0805 100%);border:1px solid rgba(255,255,255,.07);border-radius:18px;padding:3.5rem 3.5rem 3.4rem;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:2rem;max-width:1140px;margin:0 auto}
.cta-inner::before{content:'';position:absolute;top:-50%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(212,169,87,.22) 0%,transparent 65%);pointer-events:none}
.cta-inner::after{content:'';position:absolute;bottom:-50%;left:-10%;width:380px;height:380px;background:radial-gradient(circle,rgba(234,210,155,.14) 0%,transparent 65%);pointer-events:none}
.cta-text{position:relative;z-index:1;flex:1;min-width:0}
.cta-kicker{display:inline-block;font-family:var(--body);font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;color:#ead29b;font-weight:700;margin-bottom:.875rem}
.cta-title{font-family:var(--heading);font-size:clamp(1.75rem,3.2vw,2.5rem);font-weight:700;letter-spacing:-.02em;line-height:1.15;color:#fff;margin:0}
.cta-body{font-size:.875rem;color:var(--text-2);margin-top:.875rem;max-width:520px;line-height:1.6}
.cta-button{position:relative;z-index:1;display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2.2rem;border-radius:100px;font-size:.9rem;font-weight:600;font-family:var(--body);color:var(--text-2);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);letter-spacing:.02em;text-decoration:none;cursor:default;white-space:nowrap;flex-shrink:0}
@media(max-width:980px){.cta-inner{flex-direction:column;align-items:flex-start;padding:2.5rem}}
@media(max-width:768px){#cta{padding:3rem 0 6rem}.cta-inner{padding:2rem 1.5rem}.cta-body{font-size:.85rem}}

/* ===== FOOTER ===== */
footer{position:relative;z-index:1;border-top:1px solid var(--border);padding:4rem 0 0;background:var(--bg)}
.footer-inner{display:grid;grid-template-columns:1.5fr 2fr;gap:3rem;padding-bottom:3rem}
.footer-brand .logo{margin-bottom:.8rem}
.footer-desc{font-size:.82rem;color:var(--text-3);line-height:1.8;max-width:280px}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.footer-col h4{font-family:var(--heading);font-size:.8rem;font-weight:600;margin-bottom:.8rem;color:var(--text-2);letter-spacing:.02em}
.footer-col a{display:block;font-size:.78rem;color:var(--text-3);padding:.3rem 0;transition:color .3s}
.footer-col a:hover{color:var(--text)}
.footer-bottom{border-top:1px solid var(--border);padding:1.5rem 0;text-align:center}
.footer-bottom p{font-size:.72rem;color:var(--text-3)}
.footer-credits{margin-top:.4rem;font-size:.68rem;color:var(--text-3);opacity:.7}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ===== MAPLIBRE OVERRIDES ===== */
.maplibregl-ctrl-bottom-left,.maplibregl-ctrl-bottom-right,.maplibregl-ctrl-top-left,.maplibregl-ctrl-top-right{display:none!important}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
    .feat-layout{grid-template-columns:1fr;gap:2rem}
    .feat-visual{order:-1}
    .feat-scroll{height:300vh}
    .anim-slide{flex:0 0 340px}
    .uc-grid{grid-template-columns:repeat(2,1fr)}
    .footer-inner{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:768px){
    .nav-links{display:none}
    .nav-toggle{display:block}
    .feat-scroll{height:auto;position:relative}
    .feat-pin{position:relative;height:auto;padding:2rem 0}
    .feat-layout{grid-template-columns:1fr}
    .feat-item{opacity:1;border-left-color:transparent}
    .feat-item p{max-height:none;opacity:1}
    .feat-visual{display:none}
    .anim-slide{flex:0 0 300px}
    .uc-grid{grid-template-columns:1fr}
    .stats-inner{flex-direction:column;gap:.8rem;padding:1.5rem}
    .stat-sep{width:60%;height:1px}
    .demo-map-area{height:320px}
    .footer-cols{grid-template-columns:repeat(2,1fr)}
    .timeline{padding-left:34px}
    .tl-dot{left:-27px}
    .tl-card{padding:1.3rem 1.4rem}
}
@media(max-width:480px){
    #hero h1{font-size:2.6rem}
    .btn-primary,.btn-ghost{padding:.7rem 1.4rem;font-size:.85rem}
    .anim-slide{flex:0 0 270px}
    .sec-head h2{font-size:2rem}
}

/* ===== SELECTION & SCROLLBAR ===== */
::selection{background:rgba(212,169,87,.3);color:#fff}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.06);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.12)}

/* ===== MISSING-VIDEO PLACEHOLDER =====
   Applied by static/js/modules/videos.js when a <video class="fv-video"> or
   <video class="anim-video"> fails to load (e.g. MP4 asset not yet recorded).
   Hides the empty video box and draws a neutral "coming soon" placeholder. */
.fv.video-missing,
.anim-vis.video-missing{
    background:#0f1220;
    border:1.5px dashed rgba(212,169,87,.25);
    border-radius:12px;
    display:flex;
    align-items:center;
    justify-content:center;
    position:relative;
}
.fv.video-missing::after,
.anim-vis.video-missing::after{
    content:"Preview coming soon";
    color:rgba(255,255,255,.35);
    font-family:var(--heading,'Space Grotesk',sans-serif);
    font-size:.8rem;
    font-weight:600;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.fv.video-missing .fv-video,
.anim-vis.video-missing .anim-video{display:none}
