*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html, body { width: 100%; height: 100%; overflow: hidden; background: #000; cursor: none; }

:root {
  --c1: #ffffff; --c2: #e8001a; --c3: #8a0010;
  --accent: #ff2233;
  --glass-bg: rgba(232,0,26,0.07);
  --glass-border: rgba(232,0,26,0.25);
  --dot: #e8001a;
}

/* CURSOR */
#cursor {
  position: fixed; top: 0; left: 0; width: 14px; height: 14px;
  border: 1.5px solid var(--accent); border-radius: 50%;
  pointer-events: none; z-index: 9999;
  transform: translate(-50%,-50%);
  transition: transform 0.1s ease, border-color 0.5s ease;
  mix-blend-mode: difference;
}
#cursor-trail {
  position: fixed; top: 0; left: 0; width: 40px; height: 40px;
  border: 1px solid rgba(255,255,255,0.2); border-radius: 50%;
  pointer-events: none; z-index: 9998;
  transform: translate(-50%,-50%);
  transition: top 0.2s ease, left 0.2s ease;
}

/* CORNER BRACKETS */
.bracket { position: fixed; width: 36px; height: 36px; pointer-events: none; z-index: 80; transition: border-color 0.7s ease; }
.bracket.tl { top: 22px; left: 22px; border-top: 1.5px solid var(--accent); border-left: 1.5px solid var(--accent); }
.bracket.tr { top: 22px; right: 22px; border-top: 1.5px solid var(--accent); border-right: 1.5px solid var(--accent); }
.bracket.bl { bottom: 56px; left: 22px; border-bottom: 1.5px solid var(--accent); border-left: 1.5px solid var(--accent); }
.bracket.br { bottom: 56px; right: 22px; border-bottom: 1.5px solid var(--accent); border-right: 1.5px solid var(--accent); }

/* NAV */
nav {
  position: fixed; top: 0; left: 0; right: 0; height: 64px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 68px; z-index: 70;
  background: linear-gradient(to bottom, rgba(0,0,0,0.6) 0%, transparent 100%);
}
.nav-logo { font-family: 'Bebas Neue', sans-serif; font-size: 26px; letter-spacing: 0.18em; color: var(--accent); transition: color 0.7s ease; text-decoration: none; }
.nav-links { display: flex; gap: 36px; list-style: none; }
.nav-links a { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(255,255,255,0.5); text-decoration: none; transition: color 0.3s ease; }
.nav-links a:hover { color: var(--accent); }
.nav-slide-counter { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 0.15em; color: rgba(255,255,255,0.35); }
.nav-slide-counter span { color: var(--accent); transition: color 0.7s ease; }

/* BG TRACK */
#bg-track {
  position: fixed; top: 0; left: 0; height: 100vh; display: flex;
  transition: transform 0.95s cubic-bezier(0.77,0,0.175,1);
  will-change: transform; z-index: 0;
}
.bg-slide { flex: 0 0 100vw; height: 100vh; position: relative; overflow: hidden; }
.bg-slide-inner { width: 100%; height: 100%; background-size: cover; background-position: center; animation: slowZoom 20s ease-in-out infinite alternate; transition: opacity 1s ease-in-out; filter: brightness(1.05) contrast(1.15) saturate(1.2); }
.bg-slide:first-child .bg-slide-inner { opacity: 1; }
@keyframes slowZoom { from { transform: scale(1); } to { transform: scale(1.09); } }
.bg-overlay { position: absolute; inset: 0; transition: background 0.9s ease; }

/* PARALLAX */
#parallax-layer { position: fixed; inset: 0; z-index: 1; pointer-events: none; will-change: transform; }

/* CONTENT */
#content-outer { position: fixed; inset: 0; z-index: 20; overflow: hidden; pointer-events: none; }
.slide-content {
  position: absolute; inset: 0;
  display: flex; align-items: flex-end; justify-content: space-between;
  padding: 0 68px 96px; pointer-events: auto;
}

/* LEFT */
.left-block { max-width: 620px; }
.badge { display: inline-flex; align-items: center; gap: 8px; font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; transition: color 0.7s ease; }
.badge-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--dot); animation: pulse 2s ease-in-out infinite; transition: background 0.7s ease; }
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(240,192,64,0.7); }
  70%  { box-shadow: 0 0 0 9px rgba(240,192,64,0); }
  100% { box-shadow: 0 0 0 0 rgba(240,192,64,0); }
}

.headline { line-height: 0.87; margin-bottom: 18px; }
.hl-solid  { display: block; font-family: 'Bebas Neue', sans-serif; font-size: clamp(58px,8vw,118px); letter-spacing: 0.04em; color: var(--c1); transition: color 0.7s ease; }
.hl-outline{ display: block; font-family: 'Bebas Neue', sans-serif; font-size: clamp(58px,8vw,118px); letter-spacing: 0.04em; -webkit-text-stroke: 1.5px var(--c2); color: transparent; transition: -webkit-text-stroke-color 0.7s ease; }
.hl-gradient{ display: block; font-family: 'Bebas Neue', sans-serif; font-size: clamp(58px,8vw,118px); letter-spacing: 0.04em; -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

.subtitle { font-family: 'Rajdhani', sans-serif; font-size: 14px; font-weight: 300; letter-spacing: 0.17em; text-transform: uppercase; color: rgba(255,255,255,0.5); margin-bottom: 34px; max-width: 430px; line-height: 1.75; }

.cta-row { display: flex; gap: 14px; }
.btn-primary { font-family: 'Rajdhani', sans-serif; font-weight: 700; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; padding: 14px 30px; border: none; cursor: none; background: var(--c2); color: #000; clip-path: polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px)); transition: background 0.7s ease, transform 0.2s ease; }
.btn-primary:hover { transform: translateY(-2px); }
.btn-secondary { font-family: 'Rajdhani', sans-serif; font-weight: 600; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; padding: 14px 30px; background: transparent; cursor: none; border: 1px solid var(--glass-border); color: var(--accent); clip-path: polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px)); transition: border-color 0.7s ease, color 0.7s ease, background 0.3s ease; }
.btn-secondary:hover { background: rgba(255,255,255,0.05); }

/* STATS CARD */
.stats-card { backdrop-filter: blur(20px) saturate(150%); -webkit-backdrop-filter: blur(20px) saturate(150%); background: var(--glass-bg); border: 1px solid var(--glass-border); padding: 30px 34px; min-width: 278px; clip-path: polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,14px 100%,0 calc(100% - 14px)); transition: background 0.7s ease, border-color 0.7s ease; }
.card-label { font-family: 'Space Mono', monospace; font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--accent); margin-bottom: 26px; opacity: 0.65; transition: color 0.7s ease; }
.stat-row { margin-bottom: 22px; }
.stat-row:last-child { margin-bottom: 0; }
.stat-number { font-family: 'Bebas Neue', sans-serif; font-size: 42px; letter-spacing: 0.04em; color: var(--c1); line-height: 1; transition: color 0.7s ease; }
.stat-unit { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 0.12em; color: var(--c2); margin-left: 4px; transition: color 0.7s ease; }
.stat-desc { font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 400; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(255,255,255,0.32); margin-top: 2px; }
.stat-divider { height: 1px; background: var(--glass-border); margin: 20px 0; transition: background 0.7s ease; }

/* DOTS */
#slide-dots { position: fixed; right: 26px; top: 50%; transform: translateY(-50%); display: flex; flex-direction: column; gap: 10px; z-index: 70; }
.dot { width: 6px; height: 6px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.3); cursor: none; transition: background 0.4s ease, border-color 0.4s ease, transform 0.3s ease; }
.dot.active { background: var(--accent); border-color: var(--accent); transform: scale(1.5); }

/* PROGRESS */
#progress-line { position: fixed; bottom: 40px; left: 0; height: 2px; background: var(--c2); z-index: 71; transition: width 0.95s cubic-bezier(0.77,0,0.175,1), background 0.7s ease; }

/* TICKER */
#ticker { position: fixed; bottom: 0; left: 0; right: 0; height: 40px; background: rgba(0,0,0,0.88); border-top: 1px solid var(--glass-border); z-index: 70; display: flex; align-items: center; overflow: hidden; transition: border-color 0.7s ease; }
.ticker-label { flex-shrink: 0; padding: 0 20px; font-family: 'Space Mono', monospace; font-size: 9px; letter-spacing: 0.25em; color: var(--accent); border-right: 1px solid var(--glass-border); height: 100%; display: flex; align-items: center; transition: color 0.7s ease, border-color 0.7s ease; }
.ticker-track { overflow: hidden; flex: 1; }
.ticker-scroll { display: flex; white-space: nowrap; animation: tickerMove 44s linear infinite; }
.ticker-item { font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 500; letter-spacing: 0.18em; color: rgba(255,255,255,0.32); padding: 0 38px; text-transform: uppercase; }
.ticker-item span { color: var(--accent); transition: color 0.7s ease; }
@keyframes tickerMove { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* OVERLAYS */
#scanlines { position: fixed; inset: 0; z-index: 5; pointer-events: none; opacity: 0.35; background: repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.04) 2px,rgba(0,0,0,0.04) 4px); }
#vignette { position: fixed; inset: 0; z-index: 4; pointer-events: none; background: radial-gradient(ellipse at center,transparent 38%,rgba(0,0,0,0.72) 100%); }

/* BRAND TAG */
#slide-brand { position: fixed; top: 76px; left: 50%; transform: translateX(-50%); font-family: 'Space Mono', monospace; font-size: 9px; letter-spacing: 0.4em; text-transform: uppercase; color: rgba(255,255,255,0.22); z-index: 70; white-space: nowrap; transition: color 0.7s ease; }

/* HINT */
.nav-hint { position: fixed; bottom: 56px; left: 50%; transform: translateX(-50%); z-index: 70; display: flex; flex-direction: column; align-items: center; gap: 5px; opacity: 0.38; transition: opacity 0.6s ease; animation: hintBob 2.8s ease-in-out infinite; }
.nav-hint span { font-family: 'Space Mono', monospace; font-size: 8px; letter-spacing: 0.3em; color: #fff; }
.nav-hint svg { width: 14px; height: 14px; fill: none; stroke: #fff; stroke-width: 1.5; }
@keyframes hintBob { 0%,100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(6px); } }