/* ═══════════════════════════════════
   TLOG LANDING v3 — exact app DNA
═══════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800;900&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* — App exact colors (from index.css) — */
  --bg:       #020617;
  --bg2:      #0f172a;
  --bg-card:  #243044;
  --border:   #3d4f6a;
  --blue:     #3b82f6;
  --blue2:    #2563eb;
  --blue3:    #1d4ed8;
  --blue-lt:  #60a5fa;
  --blue-xlt: #93c5fd;
  --green:    #22c55e;
  --red:      #ef4444;
  --white:    #ffffff;
  --t1:       rgba(255,255,255,0.92);
  --t2:       rgba(255,255,255,0.5);
  --t3:       rgba(255,255,255,0.22);

  /* — Popup glass (from popup.html CSS vars) — */
  --glass-bg:    rgba(5,5,8,0.65);
  --glass-card:  rgba(18,20,26,0.90);
  --glass-bo:    rgba(255,255,255,0.06);
  --glass-bohi:  rgba(255,255,255,0.13);
  /* The KEY edge shine — copied exactly from .panel in popup.html */
  --glass-shine: inset 0 1px 1px rgba(255,255,255,0.15), inset 0 -1px 0 rgba(255,255,255,0.04);

  /* — App glass-card dark (from index.css .dark .glass-card) — */
  --app-glass:       rgba(255,255,255,0.07);
  --app-glass-bo:    rgba(255,255,255,0.07);
  --app-glass-shine: inset 0 1px 0 rgba(255,255,255,0.08);
  --app-glass-shadow:0 8px 32px rgba(0,0,0,0.37);
}

html{scroll-behavior:smooth}
body{
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg);
  color:var(--white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{text-decoration:none;color:inherit}
em{font-style:normal}

/* ── ANNOUNCE BAR ── */
.announce-bar{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:9px 48px;
  background:var(--blue3);
  border-bottom:1px solid rgba(59,130,246,0.3);
  font-size:13px;font-weight:600;color:rgba(255,255,255,0.85);
  position:relative;z-index:200;
}
.announce-pill{
  background:rgba(255,255,255,0.15);
  border:1px solid rgba(255,255,255,0.2);
  padding:1px 9px;border-radius:50px;
  font-size:10px;font-weight:800;letter-spacing:1px;color:#fff;
}
.announce-cta{color:#fff;font-weight:700;text-decoration:underline;text-underline-offset:2px;margin-left:4px}
.announce-close{position:absolute;right:16px;background:none;border:none;color:rgba(255,255,255,0.5);cursor:pointer;font-size:14px}
.announce-close:hover{color:#fff}

/* ── NAV — discord style transparent ── */
.nav{
  position:absolute;top:0;left:0;width:100%;z-index:150;
  background:transparent;
}
.nav-inner{
  max-width:1240px;margin:0 auto;padding:0 40px 0 200px;
  height:80px;display:flex;align-items:center;justify-content:flex-start;
  position:relative;
}
#nav-brand{
  position:fixed;top:26px;left:40px;z-index:999;
  padding:0;
  border-radius:40px;
  background:transparent;
  transition:all 0.3s;
}
#nav-brand.scrolled{
  top:20px;
}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand-icon{filter:drop-shadow(0 0 8px rgba(59,130,246,0.45))}
.brand-name{
  font-size:20px;font-weight:800;letter-spacing:-.5px;
  background:linear-gradient(135deg,var(--blue-xlt),var(--blue));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.nav-links{display:flex;list-style:none;gap:36px}
.nav-links a{font-size:15px;font-weight:700;color:var(--t1);transition:color .2s}
.nav-links a:hover{color:var(--blue-lt)}
.nav-end{position:absolute;right:40px;display:flex;align-items:center;gap:12px}
.nav-open{
  display:flex;align-items:center;gap:6px;
  padding:8px 18px;
  background:var(--glass-bg);
  border:1px solid var(--glass-bohi);
  border-radius:50px;
  font-size:13px;font-weight:700;color:var(--blue-lt);
  backdrop-filter:blur(12px);
  box-shadow:var(--glass-shine);
  transition:all .2s;white-space:nowrap;
}
.nav-open:hover{background:rgba(59,130,246,0.12);border-color:var(--blue);color:var(--white);transform:translateY(-1px)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.burger span{display:block;width:22px;height:2px;background:var(--t2);border-radius:2px;transition:all .3s}
/* Mobile-only "Open in Browser" item inside burger menu */
.nav-mobile-open{display:none}

/* ── HERO ── */
.hero{
  position:relative;min-height:100vh;display:flex;flex-direction:column;overflow:hidden;
  background:
    radial-gradient(ellipse at 15% -10%, rgba(30,58,138,0.6) 0%, transparent 70%),
    radial-gradient(ellipse at 40% 10%, rgba(59,130,246,0.25) 0%, transparent 50%),
    var(--bg);
}
#canvas{position:absolute;inset:0;pointer-events:none;z-index:0}
.hero-blobs{position:absolute;inset:0;pointer-events:none;z-index:0}
.hblob{position:absolute;border-radius:50%;filter:blur(100px);animation:blob 10s ease-in-out infinite}
.hblob-1{width:600px;height:600px;background:rgba(29,78,216,0.2);top:-200px;left:-150px}
.hblob-2{width:450px;height:450px;background:rgba(59,130,246,0.13);bottom:-80px;right:-60px;animation-delay:-4s}
.hblob-3{width:300px;height:300px;background:rgba(37,99,235,0.1);top:35%;right:12%;animation-delay:-7s}
@keyframes blob{0%,100%{transform:translate(0,0)}40%{transform:translate(20px,-22px)}70%{transform:translate(-14px,14px)}}

.hero-wrap{
  position:relative;z-index:2;
  max-width:1160px;margin:0 auto;padding:80px 24px 20px;
  width:100%;flex:1;
  display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;
}

/* hero copy */
.hero-tag{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 14px;
  background:rgba(59,130,246,0.1);
  border:1px solid rgba(59,130,246,0.25);
  border-radius:50px;
  font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  color:var(--blue-lt);margin-bottom:24px;
}
.tag-dot{width:6px;height:6px;background:var(--blue);border-radius:50%;animation:pulse 1.5s ease infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero-h1{
  font-size:clamp(42px,5.5vw,72px);font-weight:900;
  line-height:1.06;letter-spacing:-2.5px;
  color:var(--white);margin-bottom:20px;
}
.hero-h1 em{
  background:linear-gradient(135deg,var(--blue-xlt),var(--blue));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-p{font-size:17px;color:rgba(255,255,255,0.7);line-height:1.75;margin-bottom:36px;max-width:480px}

/* Buttons — matching app's style */
.btn-primary{
  display:flex;align-items:center;gap:8px;padding:13px 26px;
  background:var(--blue2);
  color:#fff;border-radius:14px;font-size:14px;font-weight:700;
  cursor:pointer;transition:all .22s;
  box-shadow:0 4px 24px rgba(37,99,235,0.45),var(--glass-shine);
  border:1px solid rgba(255,255,255,0.1);
}
.btn-primary:hover{background:var(--blue);transform:translateY(-2px);box-shadow:0 8px 32px rgba(59,130,246,0.5)}
.btn-ghost{
  display:flex;align-items:center;padding:13px 26px;
  color:var(--t2);border:1px solid var(--glass-bohi);
  border-radius:14px;font-size:14px;font-weight:600;
  cursor:pointer;transition:all .22s;
  background:var(--glass-bg);
  backdrop-filter:blur(12px);
  box-shadow:var(--glass-shine);
}
.btn-ghost:hover{color:var(--white);border-color:rgba(59,130,246,0.4);background:rgba(59,130,246,0.08);transform:translateY(-1px)}

.btn-white{
  display:flex;align-items:center;gap:8px;padding:13px 26px;
  background:#fff;
  color:#0f172a;border-radius:14px;font-size:14px;font-weight:700;
  cursor:pointer;transition:all .22s;
  border:none;
  box-shadow:0 0 30px rgba(255,255,255,0.15), var(--glass-shine);
}
.btn-white:hover{background:#f8fafc;transform:translateY(-2px);box-shadow:0 8px 32px rgba(255,255,255,0.30)}

/* Hero centered CTAs */
.hero-cta-center{
  position:relative;z-index:10;
  display:flex;justify-content:center;align-items:center;gap:20px;
  padding-bottom:50px;
  margin-top:-40px;
}
.hero-cta-center a{
  padding:16px 36px;
  font-size:16px;
  border-radius:40px;
}
  
/* stats row */
.hero-stats{display:flex;align-items:center;gap:24px}
.hstat-v{font-size:24px;font-weight:800;letter-spacing:-.5px;color:var(--white)}
.hstat-l{font-size:11px;color:var(--t3);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.hstat-sep{width:1px;height:32px;background:var(--glass-bohi)}

/* ── MASCOT SCENE ── */
.hero-visual{display:flex;justify-content:center;align-items:center}
.mascot-scene{position:relative;width:360px;height:520px}

.mascot-glow-floor{
  position:absolute;bottom:70px;left:50%;transform:translateX(-50%);
  width:260px;height:50px;
  background:radial-gradient(ellipse,rgba(59,130,246,0.35) 0%,transparent 70%);
  filter:blur(20px);border-radius:50%;
  animation:glowPulse 3s ease-in-out infinite;
}
@keyframes glowPulse{0%,100%{opacity:.7;transform:translateX(-50%) scaleX(1)}50%{opacity:1;transform:translateX(-50%) scaleX(1.15)}}

.mascot-svg{
  width:100%;height:100%;
  filter:drop-shadow(0 8px 40px rgba(0,0,0,0.8)) drop-shadow(0 0 20px rgba(59,130,246,0.15));
  animation:breathe 4s ease-in-out infinite;
}
@keyframes breathe{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Floating stat chips — gradient popup glass */
.chip{
  position:absolute;
  background:linear-gradient(135deg, rgba(30, 58, 138, 0.45) 0%, rgba(15, 23, 42, 0.65) 100%);
  backdrop-filter:blur(20px) saturate(200%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid rgba(96, 165, 250, 0.15);
  border-top:1px solid rgba(96, 165, 250, 0.25);
  border-radius:14px;
  padding:10px 14px;
  box-shadow: 0 4px 6px rgba(0,0,0,0.1), 0 16px 32px rgba(0,0,0,0.5), inset 0 1px 1px rgba(255,255,255,0.1);
  animation:chipFloat 4s ease-in-out infinite;
  animation-delay:var(--cd);
}
@keyframes chipFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.chip-tl{top:36px;left:-30px}
.chip-tr{top:16px;right:-28px}
.chip-bl{bottom:116px;left:-38px}
.chip-br{bottom:130px;right:-24px}
.chip-lbl{font-size:9px;text-transform:uppercase;letter-spacing:.8px;font-weight:700;color:var(--t3);margin-bottom:3px}
.chip-val{font-size:18px;font-weight:800;color:var(--t1);letter-spacing:-.5px}
.chip-val.g{color:var(--green)}

.mini-chart{
  position:absolute;bottom:62px;left:50%;transform:translateX(-50%);
  background:var(--glass-bg);
  backdrop-filter:blur(20px) saturate(200%);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-bohi);
  border-radius:14px;padding:10px 14px;width:188px;
  box-shadow:var(--glass-shine),0 4px 24px rgba(0,0,0,0.4);
  animation:chipFloat 5s ease-in-out infinite;animation-delay:0.7s;
}
.mc-row{display:flex;justify-content:space-between;font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.5px;color:var(--t3);margin-bottom:6px}
.mc-up{color:var(--green)}
.mc-svg{width:100%;height:auto}

/* candles deco */
.candles{position:absolute;right:-16px;top:175px;display:flex;align-items:flex-end;gap:4px;opacity:.55;filter:drop-shadow(0 0 4px rgba(59,130,246,0.3))}
.candle{width:8px;border-radius:2px;position:relative}
.candle::before,.candle::after{content:'';position:absolute;left:50%;transform:translateX(-50%);width:2px;border-radius:1px}
.c-g{background:rgba(34,197,94,.3);height:38px}
.c-g::before{background:#22c55e;height:7px;top:-7px}
.c-g::after{background:#22c55e;height:5px;bottom:-5px}
.c-r{background:rgba(239,68,68,.3);height:26px}
.c-r::before{background:#ef4444;height:5px;top:-5px}
.c-r::after{background:#ef4444;height:4px;bottom:-4px}
.ct{height:55px}.cs{height:18px}

.scroll-ind{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:5;opacity:.45}
.scroll-m{width:20px;height:34px;border:2px solid var(--t3);border-radius:10px;display:flex;justify-content:center;padding-top:5px;margin:0 auto 5px}
.scroll-w{width:4px;height:7px;background:var(--t3);border-radius:2px;animation:sw 1.5s ease infinite}
@keyframes sw{0%{transform:translateY(0);opacity:1}100%{transform:translateY(8px);opacity:0}}

/* ── GRADIENT TEXT ── */
.grad-blue{
  background:linear-gradient(135deg,var(--blue-xlt),var(--blue));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ── MARQUEE ── */
.marquee-band{
  overflow:hidden;
  background:var(--blue2);
  border-top:1px solid rgba(255,255,255,0.06);
  border-bottom:1px solid rgba(255,255,255,0.06);
  padding:16px 0;
}
.marquee-track{
  display:flex;gap:28px;width:max-content;
  animation:marquee 30s linear infinite;
  font-size:13px;font-weight:800;letter-spacing:2px;
  color:rgba(255,255,255,0.8);text-transform:uppercase;white-space:nowrap;
}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-dot{opacity:.5;font-size:10px}

/* ── FEATURES — alternating sections ── */
.features-alt{background:var(--bg);padding:60px 0}
.feat-row{
  max-width:1160px;margin:0 auto;padding:80px 24px;
  display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;
}
.feat-row-rev{direction:rtl}
.feat-row-rev>*{direction:ltr}

.feat-tag{
  display:inline-block;padding:3px 12px;border-radius:50px;
  font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;
  margin-bottom:16px;
  background:rgba(59,130,246,0.1);color:var(--blue-lt);
  border:1px solid rgba(59,130,246,0.2);
}
.feat-copy h2{
  font-size:clamp(28px,3.5vw,46px);font-weight:900;
  line-height:1.15;letter-spacing:-1.5px;color:var(--white);margin-bottom:16px;
}
.feat-copy p{font-size:15px;color:var(--t2);line-height:1.75;margin-bottom:22px;max-width:420px}
.feat-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.feat-list li{
  display:flex;align-items:center;gap:10px;
  font-size:14px;color:var(--t2);font-weight:500;
}
.feat-list li::before{
  content:'';width:5px;height:5px;border-radius:50%;
  background:var(--blue);flex-shrink:0;
}

/* ── FEATURE SCREENS — exact popup.html glass ── */
.feat-visual{position:relative;display:flex;justify-content:center;align-items:center}
.feat-screen{
  background:var(--glass-bg);
  backdrop-filter:blur(20px) saturate(200%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid var(--glass-bohi);
  border-radius:20px;overflow:hidden;width:100%;max-width:460px;
  /* THE edge shine from popup.html */
  box-shadow:var(--glass-shine), 0 32px 80px rgba(0,0,0,0.7);
  transition:transform .35s cubic-bezier(0.34,1.56,0.64,1);
}
.tilt-r{transform:perspective(1000px) rotateY(-9deg) rotateX(4deg) rotate(-1.5deg)}
.tilt-l{transform:perspective(1000px) rotateY(9deg)  rotateX(4deg) rotate(1.5deg)}
.feat-screen:hover{transform:perspective(1000px) rotateY(0) rotateX(0) rotate(0) scale(1.015)}

.fs-bar{
  background:rgba(0,0,0,0.35);padding:10px 14px;
  display:flex;gap:6px;
  border-bottom:1px solid var(--glass-bo);
}
.fs-dot{width:11px;height:11px;border-radius:50%}
.fs-dot.r{background:#ff5f57}.fs-dot.y{background:#febc2e}.fs-dot.g{background:#28c840}
.fs-body{padding:16px}

/* stat grid inside screen */
.fs-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.fs-stat{
  background:var(--glass-input);
  border:1px solid var(--glass-bo);
  border-radius:10px;padding:11px;
  box-shadow:var(--app-glass-shine);
}
.fss-l{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);font-weight:700;margin-bottom:3px}
.fss-v{font-size:18px;font-weight:800;color:var(--t1);letter-spacing:-.5px}
.fss-v.g{color:var(--green)}
.fs-chart-svg{width:100%;margin-bottom:12px}
.fs-trades{display:flex;flex-direction:column;gap:3px}
.fs-tr{
  display:flex;align-items:center;gap:8px;
  padding:7px 9px;
  background:var(--glass-input);
  border:1px solid var(--glass-bo);
  border-radius:8px;font-size:11px;
  box-shadow:var(--app-glass-shine);
}
.fstr-p{font-weight:800;flex:1;color:var(--t1);letter-spacing:.5px}
.fstr-t{padding:2px 7px;border-radius:4px;font-size:9px;font-weight:800;letter-spacing:.5px}
.fstr-t.long{background:rgba(34,197,94,0.12);color:var(--green)}
.fstr-t.short{background:rgba(239,68,68,0.12);color:var(--red)}
.fstr-pnl{font-weight:800;margin-left:auto}
.fstr-pnl.g{color:var(--green)}.fstr-pnl.r{color:var(--red)}

/* popup demo inside screen */
.popup-demo{
  background:rgba(0,0,0,0.35);
  border:1px solid var(--glass-bo);
  border-radius:14px;padding:14px;
  display:flex;flex-direction:column;gap:8px;
  box-shadow:var(--app-glass-shine);
}
.pd-hdr{display:flex;align-items:center;gap:8px;margin-bottom:2px;font-weight:800;color:var(--t1);font-size:12px}
.pd-logo{width:22px;height:22px;background:var(--blue2);border-radius:7px;display:grid;place-items:center;font-size:11px;font-weight:900;color:#fff}
.pd-close{margin-left:auto;color:var(--t3);font-size:13px}
.pd-field{display:flex;align-items:center;gap:10px;padding:7px 9px;background:var(--glass-input);border:1px solid var(--glass-bo);border-radius:8px;font-size:11px;box-shadow:var(--app-glass-shine)}
.pd-lbl{color:var(--t3);font-weight:700;min-width:68px;text-transform:uppercase;font-size:9px;letter-spacing:.5px}
.pd-val{color:var(--t1);font-weight:800}
.pd-val.r{color:var(--red)}.pd-val.g{color:var(--green)}
.pd-tags{display:flex;gap:5px}
.pd-tag{padding:2px 9px;border-radius:4px;font-size:9px;font-weight:800;background:var(--glass-input);border:1px solid var(--glass-bo);color:var(--t3)}
.pd-tag.on{background:rgba(34,197,94,0.12);color:var(--green);border-color:rgba(34,197,94,0.25)}
.pd-emojis{font-size:15px;letter-spacing:3px}
.pd-save{background:var(--blue2);color:#fff;border:1px solid rgba(255,255,255,0.1);border-radius:8px;padding:9px;font-size:12px;font-weight:700;cursor:pointer;width:100%;margin-top:3px;transition:opacity .2s;box-shadow:var(--glass-shine)}
.pd-save:hover{opacity:.88}

/* psychology bars */
.psych-demo{display:flex;flex-direction:column;gap:10px}
.psd-title{font-weight:800;font-size:14px;color:var(--t1);margin-bottom:4px}
.psd-row{display:flex;align-items:center;gap:10px;font-size:11px}
.psd-em{min-width:90px;color:var(--t2);font-weight:600}
.psd-bar{flex:1;height:7px;background:var(--glass-input);border:1px solid var(--glass-bo);border-radius:4px;overflow:hidden}
.psd-fill{height:100%;border-radius:4px}
.psd-pnl{min-width:52px;text-align:right;font-weight:800;font-size:11px}
.psd-pnl.g{color:var(--green)}.psd-pnl.r{color:var(--red)}
.psd-insight{
  margin-top:4px;padding:9px 11px;
  background:rgba(59,130,246,0.07);
  border:1px solid rgba(59,130,246,0.18);
  border-radius:8px;font-size:11px;color:var(--blue-lt);font-weight:600;
  box-shadow:inset 0 1px 0 rgba(59,130,246,0.12);
}

/* glow blobs behind screens */
.feat-glow{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:-1;width:280px;height:280px;top:50%;left:50%;transform:translate(-50%,-50%)}
.fgb-blue{background:rgba(59,130,246,0.12)}

/* ── DOWNLOAD ── */
.download{
  position:relative;overflow:hidden;padding:100px 0;
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%);
}
.dl-blob{position:absolute;border-radius:50%;filter:blur(110px);pointer-events:none}
.dlb1{width:480px;height:480px;background:rgba(29,78,216,0.13);top:-150px;right:-100px}
.dlb2{width:360px;height:360px;background:rgba(37,99,235,0.08);bottom:-80px;left:8%}
.dl-inner{max-width:1060px;margin:0 auto;padding:0 24px;position:relative;z-index:2;text-align:center}
.dl-tag{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:2px;color:var(--blue-lt);margin-bottom:14px;display:block}
.dl-h2{font-size:clamp(34px,4.5vw,58px);font-weight:900;letter-spacing:-2px;line-height:1.1;color:var(--white);margin-bottom:14px}
.dl-sub{font-size:15px;color:var(--t2);margin-bottom:56px}
.dl-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}

/* DL card — gradient popup glass */
.dl-card{
  position:relative;
  background:linear-gradient(135deg, rgba(30, 58, 138, 0.45) 0%, rgba(15, 23, 42, 0.65) 100%);
  backdrop-filter:blur(20px) saturate(200%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid rgba(96, 165, 250, 0.15);
  border-top:1px solid rgba(96, 165, 250, 0.25);
  border-radius:20px;padding:28px 18px;
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;
  box-shadow:0 4px 6px rgba(0,0,0,0.1), 0 16px 32px rgba(0,0,0,0.5), inset 0 1px 1px rgba(255,255,255,0.1);
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.dl-card:hover{
  transform:translateY(-5px);
  border-color:rgba(96, 165, 250, 0.4);
  box-shadow:0 8px 12px rgba(0,0,0,0.2), 0 24px 48px rgba(0,0,0,0.6), inset 0 1px 1px rgba(255,255,255,0.2), 0 0 40px rgba(59,130,246,0.1);
}
.dl-card-hero{
  background:linear-gradient(135deg, rgba(37, 99, 235, 0.55) 0%, rgba(15, 23, 42, 0.75) 100%);
  border-color:rgba(96, 165, 250, 0.35);
  box-shadow:0 8px 12px rgba(0,0,0,0.2), 0 16px 40px rgba(37,99,235,0.25), inset 0 1px 1px rgba(255,255,255,0.2);
}
.dl-card-soon{opacity:.42;pointer-events:none}
.dlc-pill{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--blue2);color:#fff;
  font-size:10px;font-weight:800;padding:3px 14px;border-radius:50px;
  letter-spacing:.5px;white-space:nowrap;
  box-shadow:0 4px 16px rgba(37,99,235,0.45);
  border:1px solid rgba(255,255,255,0.1);
}
.dlc-name{font-size:18px;font-weight:800;color:var(--white);letter-spacing:-.3px}
.dlc-ver{font-size:11px;color:var(--t3)}
.dlc-btn{
  display:flex;align-items:center;justify-content:center;padding:10px 22px;
  background:var(--glass-input);
  border:1px solid var(--glass-bohi);
  border-radius:50px;font-size:12px;font-weight:700;
  color:var(--blue-lt);cursor:pointer;transition:all .22s;width:100%;
  box-shadow:var(--app-glass-shine);
}
.dlc-btn:hover{background:rgba(59,130,246,0.15);border-color:var(--blue);box-shadow:var(--glass-shine)}
.dlc-btn-accent{background:var(--blue2);border-color:rgba(255,255,255,0.1);color:#fff;box-shadow:var(--glass-shine),0 6px 24px rgba(37,99,235,0.4)}
.dlc-btn-accent:hover{background:var(--blue);box-shadow:var(--glass-shine),0 10px 32px rgba(59,130,246,0.5)}
.dlc-btn-off{
  display:flex;align-items:center;justify-content:center;padding:10px 22px;
  background:transparent;border:1px solid var(--glass-bo);
  border-radius:50px;font-size:12px;font-weight:600;color:var(--t3);width:100%;
}

/* ── FINAL CTA ── */
.cta-final{
  position:relative;overflow:hidden;padding:140px 24px;text-align:center;
  background:radial-gradient(ellipse at center,rgba(29,78,216,0.15) 0%,transparent 60%),var(--bg);
}
.ctaf-blob{position:absolute;border-radius:50%;filter:blur(110px);pointer-events:none}
.ctab1{width:500px;height:500px;background:rgba(29,78,216,0.18);top:-200px;left:50%;transform:translateX(-50%)}
.ctaf-inner{position:relative;z-index:2}
.ctaf-h2{font-size:clamp(40px,6vw,76px);font-weight:900;letter-spacing:-3px;line-height:1.05;color:var(--white);margin-bottom:18px}
.ctaf-sub{font-size:17px;color:var(--t2);margin-bottom:38px;max-width:460px;margin-left:auto;margin-right:auto}
.ctaf-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}

/* ── FOOTER ── */
.footer{background:var(--bg2);border-top:1px solid rgba(255,255,255,0.04)}
.footer-inner{max-width:1160px;margin:0 auto;padding:56px 24px 36px;display:flex;gap:80px}
.footer-brand{flex:1}
.footer-tag{margin-top:12px;font-size:13px;color:var(--t3);max-width:200px;line-height:1.6}
.footer-cols{display:flex;gap:56px}
.footer-col{display:flex;flex-direction:column;gap:10px}
.fc-title{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--t1);margin-bottom:4px}
.footer-col a{font-size:13px;color:var(--t3);transition:color .2s}
.footer-col a:hover{color:var(--blue-lt)}
.footer-base{max-width:1160px;margin:0 auto;padding:18px 24px;border-top:1px solid rgba(255,255,255,0.04);display:flex;justify-content:space-between;font-size:12px;color:var(--t3)}

/* ── SCROLL ANIM ── */
[data-anim]{opacity:0;transition:opacity .75s ease,transform .75s ease}
[data-anim="left"]{transform:translateX(-44px)}
[data-anim="right"]{transform:translateX(44px)}
[data-anim="up"]{transform:translateY(36px)}
[data-anim].visible{opacity:1;transform:none}

/* Toast */
#toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%);z-index:9999;pointer-events:none}

/* ── RESPONSIVE ── */

/* ── Tablet (≤1024px) ── */
@media(max-width:1024px){
  /* Hero: stack copy on top, visual below */
  .hero-wrap{
    grid-template-columns:1fr;
    gap:0;
    padding:100px 32px 24px;
    text-align:center;
  }
  .hero-visual{
    display:flex;
    justify-content:center;
    align-items:center;
    margin-top:0;
  }
  .mascot-scene{
    width:300px;
    height:420px;
  }
  /* Centre the stats row */
  .hero-stats{justify-content:center}
  /* Centre paragraph */
  .hero-p{margin-left:auto;margin-right:auto}
  /* Centre hero copy */
  .hero-copy{text-align:center;display:flex;flex-direction:column;align-items:center}

  /* Feature rows: stack visual above text */
  .feat-row{
    grid-template-columns:1fr;
    gap:40px;
    padding:60px 32px;
  }
  /* Fix reversed row on tablet — visual first, copy second */
  .feat-row-rev{direction:ltr}
  .feat-row-rev .feat-visual{order:-1}
  .feat-row-rev .feat-copy{order:0}

  /* Download: 2-col grid */
  .dl-cards{grid-template-columns:repeat(2,1fr)}

  /* Footer */
  .footer-inner{flex-direction:column;gap:40px}
}

/* ── Mobile (≤768px) ── */
@media(max-width:768px){
  /* NAV */
  #nav-brand{left:20px;top:16px}
  #nav-brand.scrolled{top:12px}
  .nav-inner{padding:0 20px;height:64px;justify-content:flex-end}
  /* Hide "Open in Browser" pill on mobile — it's in the burger menu instead */
  .nav-end{right:16px;gap:8px}
  .nav-open{display:none}
  .burger{display:flex}
  .nav-links{
    display:none;
    position:absolute;top:64px;left:0;right:0;
    background:rgba(2,6,23,0.97);
    backdrop-filter:blur(20px);
    padding:20px 24px 28px;
    flex-direction:column;gap:18px;
    border-bottom:1px solid rgba(255,255,255,0.06);
  }
  /* Add "Open in Browser" link inside the mobile burger menu */
  .nav-links.open{display:flex}
  .nav-mobile-open{display:block}
  .nav-mobile-open a{color:var(--blue-lt) !important;font-weight:700}

  /* HERO */
  .hero-wrap{
    grid-template-columns:1fr;
    gap:0;
    padding:90px 20px 16px;
    text-align:center;
  }
  .hero-copy{
    text-align:center;
    display:flex;flex-direction:column;align-items:center;
  }
  .hero-h1{
    font-size:clamp(34px,9vw,52px);
    letter-spacing:-1.5px;
  }
  .hero-p{
    font-size:15px;
    margin-left:auto;margin-right:auto;
    max-width:340px;
  }
  .hero-stats{
    justify-content:center;
    gap:16px;
    flex-wrap:wrap;
  }
  .hstat-v{font-size:20px}

  /* Mascot: show below, smaller */
  .hero-visual{
    display:flex;
    justify-content:center;
    align-items:center;
    margin-top:8px;
  }
  .mascot-scene{
    width:240px;
    height:340px;
  }
  /* Scale down the chip decorations so they don't overflow */
  .chip{
    transform:scale(0.8);
    transform-origin:center;
  }

  /* CTA buttons: stack vertically on very small screens */
  .hero-cta-center{
    flex-direction:column;
    align-items:center;
    gap:12px;
    padding-bottom:40px;
    margin-top:-20px;
  }
  .hero-cta-center a{
    width:100%;
    max-width:320px;
    justify-content:center;
    padding:15px 28px;
    font-size:15px;
  }

  /* FEATURES */
  .feat-row{
    grid-template-columns:1fr;
    gap:32px;
    padding:44px 20px;
  }
  .feat-row-rev{direction:ltr}
  .feat-row-rev .feat-visual{order:-1}
  .feat-row-rev .feat-copy{order:0}
  .feat-copy h2{font-size:clamp(24px,6vw,36px);letter-spacing:-1px}
  .feat-copy p{font-size:14px}
  .feat-screen{max-width:100%}

  /* DOWNLOAD */
  .dl-cards{grid-template-columns:repeat(2,1fr);gap:12px}
  .dl-h2{font-size:clamp(28px,8vw,44px);letter-spacing:-1.5px}
  .download{padding:70px 0}

  /* FINAL CTA */
  .cta-final{padding:90px 20px}
  .ctaf-h2{font-size:clamp(32px,8vw,52px);letter-spacing:-2px}
  .ctaf-sub{font-size:15px}
  .ctaf-btns{flex-direction:column;align-items:center;gap:12px}
  .ctaf-btns a{width:100%;max-width:320px;justify-content:center}

  /* FOOTER */
  .footer-inner{flex-direction:column;gap:36px;padding:44px 20px 28px}
  .footer-cols{flex-direction:column;gap:24px}
  .footer-base{flex-direction:column;gap:6px;text-align:center}
}

/* ── Small phones (≤480px) ── */
@media(max-width:480px){
  .hero-h1{font-size:clamp(28px,10vw,40px);letter-spacing:-1px}
  .mascot-scene{width:200px;height:290px}
  /* Stack download cards fully */
  .dl-cards{grid-template-columns:1fr}
  .dl-card{padding:22px 16px}
  .nav-inner{padding:0 16px}
  .hero-wrap{padding:80px 16px 12px}
  .feat-row{padding:36px 16px}
  /* Make chips even smaller so they stay inside viewport */
  .chip{transform:scale(0.7);transform-origin:center}
}
