/* ============================================================
   SNIPER PAINTBALL JORDAN — Landing Page
   Tactical esports aesthetic · gold on black
   ============================================================ */

:root{
  --gold:#FFD700;
  --amber:#FFB800;
  --black:#0B0B0C;
  --panel:#141416;
  --panel-2:#1A1A1D;
  --line:#2A2A2E;
  --white:#FFFFFF;
  --muted:#9A9A9F;
  --muted-dim:#6A6A70;
  --green:#2E7D32;       /* jordan flag accent */
  --red:#C62828;

  --grad-gold:linear-gradient(135deg,#FFE36B 0%,#FFD700 38%,#FFB800 100%);
  --font-display:'Oswald',system-ui,sans-serif;
  --font-num:'Teko',system-ui,sans-serif;
  --font-body:'Barlow',system-ui,sans-serif;

  --ease:cubic-bezier(.2,.7,.2,1);
  --maxw:1280px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--black);
  color:var(--white);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body.locked{overflow:hidden;height:100vh}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--gold);color:#000}

/* ---------- grain + scanline global overlay ---------- */
.fx-grain,.fx-scan{position:fixed;inset:0;pointer-events:none;z-index:9000}
.fx-grain{
  opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.fx-scan{
  opacity:.35;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,0) 0,rgba(0,0,0,0) 2px,rgba(0,0,0,.22) 3px,rgba(0,0,0,0) 4px);
}

/* ---------- typography helpers ---------- */
.eyebrow{
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:.34em;
  text-transform:uppercase;
  font-size:.78rem;
  color:var(--gold);
  display:inline-flex;align-items:center;gap:.7rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);display:inline-block}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--gold);display:inline-block}
.eyebrow.center::before{content:"";width:26px;height:1px;background:var(--gold)}

.section-head{max-width:760px;margin:0 auto 56px;text-align:center}
.section-head .eyebrow{margin-bottom:18px}
h2.title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(2.3rem,5vw,4rem);
  line-height:.98;
  text-transform:uppercase;
  letter-spacing:.01em;
}
.title .hl{color:transparent;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text}
.lead{color:var(--muted);font-size:1.05rem;margin-top:18px;text-wrap:pretty}

.section{padding:120px 32px;position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;position:relative}
.idx{font-family:var(--font-num);color:var(--muted-dim);font-size:1.3rem;letter-spacing:.05em}

/* tactical corner brackets */
.brackets{position:relative}
.brackets::before,.brackets::after{
  content:"";position:absolute;width:18px;height:18px;pointer-events:none;
  border:2px solid var(--gold);opacity:.6;
}
.brackets::before{top:10px;left:10px;border-right:0;border-bottom:0}
.brackets::after{bottom:10px;right:10px;border-left:0;border-top:0}

/* ---------- buttons ---------- */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--font-display);font-weight:600;text-transform:uppercase;
  letter-spacing:.12em;font-size:.92rem;padding:16px 30px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
}
.btn svg{width:18px;height:18px}
.btn-gold{background:var(--grad-gold);color:#0A0A0A;box-shadow:0 0 0 rgba(255,184,0,0)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 34px -10px rgba(255,184,0,.55)}
.btn-ghost{background:transparent;color:#fff;border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.btn-wa{background:#1f8f4e;color:#fff}
.btn-wa:hover{background:#23a259;transform:translateY(-2px)}

/* =========================================================
   LOADING SCREEN
   ========================================================= */
#loader{
  position:fixed;inset:0;z-index:10000;background:var(--black);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;
  transition:opacity .7s ease,visibility .7s;
}
#loader.done{opacity:0;visibility:hidden}
.load-scope{
  width:120px;height:120px;border-radius:50%;position:relative;
  border:2px solid rgba(255,215,0,.25);
  display:grid;place-items:center;
  animation:loadspin 3s linear infinite;
}
.load-scope::before,.load-scope::after{content:"";position:absolute;background:var(--gold)}
.load-scope::before{width:100%;height:1px;left:0;top:50%}
.load-scope::after{height:100%;width:1px;top:0;left:50%}
.load-scope i{
  width:78px;height:78px;border-radius:50%;border:1px solid rgba(255,215,0,.4);
  position:absolute;animation:loadpulse 1.6s ease-in-out infinite;
}
.load-dot{width:8px;height:8px;background:var(--red);border-radius:50%;box-shadow:0 0 14px var(--red);z-index:2}
@keyframes loadspin{to{transform:rotate(360deg)}}
@keyframes loadpulse{0%,100%{transform:scale(.7);opacity:.4}50%{transform:scale(1);opacity:1}}
.load-label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.4em;font-size:.8rem;color:var(--muted)}
.load-bar{width:220px;height:3px;background:#222;overflow:hidden}
.load-bar i{display:block;height:100%;width:0;background:var(--grad-gold);animation:loadbar 2s var(--ease) forwards}
@keyframes loadbar{to{width:100%}}

/* =========================================================
   NAVBAR
   ========================================================= */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:5000;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;transition:background .35s,padding .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
#nav.scrolled{
  background:rgba(10,10,11,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);padding:12px 32px;
}
.brand{display:flex;align-items:center;gap:13px}
.brand .mark{
  width:46px;height:46px;border-radius:50%;overflow:hidden;
  border:1.5px solid var(--gold);box-shadow:0 0 18px -4px rgba(255,215,0,.6);
  flex:0 0 auto;background:#000;
}
.brand .mark img{width:140%;height:140%;object-fit:cover;transform:translate(-14%,-14%)}
.brand b{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:1.05rem;line-height:1}
.brand span{display:block;font-size:.62rem;letter-spacing:.34em;color:var(--gold);font-weight:600}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  font-family:var(--font-display);font-weight:500;text-transform:uppercase;
  letter-spacing:.1em;font-size:.82rem;color:#cfcfd2;padding:9px 14px;position:relative;
}
.nav-links a::after{content:"";position:absolute;left:14px;right:14px;bottom:4px;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-book{
  font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:.12em;
  font-size:.82rem;padding:11px 22px;background:var(--grad-gold);color:#0A0A0A;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
  transition:transform .25s var(--ease),box-shadow .25s;
}
.nav-book:hover{transform:translateY(-2px);box-shadow:0 10px 26px -8px rgba(255,184,0,.6)}
.burger{display:none;flex-direction:column;gap:5px;padding:8px}
.burger span{width:24px;height:2px;background:#fff;transition:.3s}

/* mobile drawer */
#drawer{
  position:fixed;inset:0;z-index:4900;background:rgba(8,8,9,.97);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  opacity:0;visibility:hidden;transition:.35s;
}
#drawer.open{opacity:1;visibility:visible}
#drawer a{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.18em;font-size:1.5rem;color:#ddd;padding:12px}
#drawer a:hover{color:var(--gold)}

/* =========================================================
   HERO
   ========================================================= */
#home{
  position:relative;min-height:100vh;display:flex;align-items:center;
  padding:120px 32px 60px;overflow:hidden;
  cursor:none;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg .grad{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 80% at 80% 10%,rgba(255,184,0,.10),transparent 50%),
    radial-gradient(90% 90% at 15% 90%,rgba(46,125,50,.10),transparent 55%),
    linear-gradient(180deg,#070708 0%,#0B0B0C 55%,#070708 100%);
}
.hero-bg .grid{
  position:absolute;inset:0;opacity:.4;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(120% 100% at 50% 40%,#000 30%,transparent 80%);
}
#fxCanvas{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero-smoke{
  position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background:
    radial-gradient(40% 50% at 20% 80%,rgba(120,120,130,.18),transparent 70%),
    radial-gradient(45% 55% at 85% 75%,rgba(120,120,130,.14),transparent 70%);
  animation:smoke 14s ease-in-out infinite alternate;
}
@keyframes smoke{from{transform:translateX(-3%) scale(1)}to{transform:translateX(3%) scale(1.08)}}
.hero-vignette{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:radial-gradient(120% 100% at 50% 45%,transparent 45%,rgba(0,0,0,.55) 100%)}

.hero-inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;width:100%}
.hero-tag{
  display:inline-flex;align-items:center;gap:10px;margin-bottom:26px;
  padding:8px 16px;border:1px solid var(--line);background:rgba(20,20,22,.6);
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:.2em;font-size:.72rem;color:var(--gold);
  clip-path:polygon(8px 0,100% 0,100% 100%,0 100%,0 8px);
}
.hero-tag .live{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 10px var(--red);animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

h1.hero-title{
  font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  font-size:clamp(2.9rem,8vw,6.6rem);line-height:.92;letter-spacing:.005em;
  max-width:14ch;
}
h1.hero-title .l2{color:transparent;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;
  filter:drop-shadow(0 0 26px rgba(255,184,0,.25))}
.hero-sub{
  margin-top:22px;font-family:var(--font-display);font-weight:500;text-transform:uppercase;
  letter-spacing:.32em;font-size:clamp(.95rem,2vw,1.3rem);color:#e3e3e6;
}
.hero-sub b{color:var(--gold)}
.hero-actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:38px}

.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  margin-top:70px;border:1px solid var(--line);
  clip-path:polygon(16px 0,100% 0,100% calc(100% - 16px),calc(100% - 16px) 100%,0 100%,0 16px);
}
.hero-stats .st{background:rgba(13,13,15,.85);padding:24px 22px;backdrop-filter:blur(4px)}
.hero-stats .num{font-family:var(--font-num);font-weight:600;font-size:3rem;line-height:.9;color:var(--gold)}
.hero-stats .lab{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;color:var(--muted);margin-top:6px}

.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:.3em;font-size:.66rem;color:var(--muted-dim);
  display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue i{width:1px;height:38px;background:linear-gradient(var(--gold),transparent);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* cursor sniper scope (hero only) */
#scope{position:fixed;top:0;left:0;z-index:8000;pointer-events:none;opacity:0;transition:opacity .3s;will-change:transform}
#scope.on{opacity:1}
.scope-ring{width:150px;height:150px;border-radius:50%;border:1.5px solid rgba(255,215,0,.85);
  position:relative;transform:translate(-50%,-50%);box-shadow:0 0 30px rgba(0,0,0,.6),inset 0 0 20px rgba(0,0,0,.5)}
.scope-ring::before{content:"";position:absolute;inset:18px;border-radius:50%;border:1px solid rgba(255,215,0,.3)}
.scope-h,.scope-v{position:fixed;background:rgba(255,215,0,.35);pointer-events:none}
.scope-h{height:1px;left:0;right:0}
.scope-v{width:1px;top:0;bottom:0}
.scope-tick{position:absolute;left:50%;top:50%;width:14px;height:14px;transform:translate(-50%,-50%)}
.scope-tick::before,.scope-tick::after{content:"";position:absolute;background:var(--red)}
.scope-tick::before{width:100%;height:1.5px;top:50%;transform:translateY(-50%)}
.scope-tick::after{height:100%;width:1.5px;left:50%;transform:translateX(-50%)}
.scope-mil{position:absolute;width:1px;height:8px;background:rgba(255,215,0,.6);left:50%;transform:translateX(-50%)}
.scope-mil.t{top:6px}.scope-mil.b{bottom:6px}
.scope-mil.l{width:8px;height:1px;top:50%;left:6px;transform:translateY(-50%)}
.scope-mil.r{width:8px;height:1px;top:50%;right:6px;left:auto;transform:translateY(-50%)}

/* =========================================================
   ACTIVITIES
   ========================================================= */
.act-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.act-card{
  position:relative;padding:34px 30px 30px;min-height:300px;
  background:linear-gradient(180deg,var(--panel) 0%,#0E0E10 100%);
  border:1px solid var(--line);overflow:hidden;
  transform-style:preserve-3d;transition:transform .2s var(--ease),border-color .3s;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 22px),calc(100% - 22px) 100%,0 100%);
}
.act-card:hover{border-color:rgba(255,215,0,.5)}
.act-card .glow{position:absolute;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,184,0,.16),transparent 65%);
  pointer-events:none;opacity:0;transition:opacity .3s;transform:translate(-50%,-50%);z-index:0}
.act-card:hover .glow{opacity:1}
.act-ic{width:58px;height:58px;display:grid;place-items:center;border:1px solid var(--line);
  background:#0C0C0E;margin-bottom:auto;position:relative;z-index:2;transform:translateZ(40px)}
.act-ic svg{width:30px;height:30px;stroke:var(--gold);fill:none;stroke-width:1.6}
.act-card h3{font-family:var(--font-display);text-transform:uppercase;font-weight:700;font-size:1.5rem;
  letter-spacing:.04em;margin-top:24px;position:relative;z-index:2;transform:translateZ(30px)}
.act-card p{color:var(--muted);font-size:.95rem;margin-top:8px;position:relative;z-index:2;transform:translateZ(20px)}
.act-card .more{margin-top:18px;display:inline-flex;align-items:center;gap:8px;color:var(--gold);
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;
  position:relative;z-index:2;transform:translateZ(20px);opacity:0;transform:translateZ(20px) translateX(-6px);transition:.3s}
.act-card:hover .more{opacity:1;transform:translateZ(20px) translateX(0)}
.act-card .bignum{position:absolute;right:18px;top:14px;font-family:var(--font-num);font-size:3.4rem;
  color:rgba(255,255,255,.05);line-height:1;z-index:1}

/* =========================================================
   TOURNAMENT
   ========================================================= */
#tournaments{background:linear-gradient(180deg,#0B0B0C,#0E0E10)}
.tour-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.poster-frame{position:relative;padding:14px;border:1px solid var(--line);background:var(--panel)}
.poster-frame img{width:100%;clip-path:polygon(0 0,100% 0,100% calc(100% - 18px),calc(100% - 18px) 100%,0 100%)}
.poster-frame .tag{position:absolute;top:-1px;left:24px;background:var(--grad-gold);color:#0A0A0A;
  font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  font-size:.74rem;padding:7px 16px;clip-path:polygon(0 0,100% 0,100% 100%,8px 100%,0 calc(100% - 8px))}
.tour-meta{display:flex;flex-direction:column}
.tour-meta h2{font-family:var(--font-display);text-transform:uppercase;font-weight:700;
  font-size:clamp(2rem,4vw,3.1rem);line-height:.95}
.tour-meta .sub{color:var(--gold);font-family:var(--font-display);letter-spacing:.18em;
  text-transform:uppercase;font-size:.9rem;margin-top:10px}

.countdown{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:30px 0}
.cd{background:#0C0C0E;border:1px solid var(--line);padding:16px 8px;text-align:center;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
.cd b{font-family:var(--font-num);font-weight:600;font-size:2.8rem;line-height:.85;color:#fff;display:block}
.cd span{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.18em;font-size:.62rem;color:var(--muted)}

.prize-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px}
.prize{position:relative;padding:20px 16px;background:#0C0C0E;border:1px solid var(--line);text-align:center;overflow:hidden}
.prize .rank{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;
  padding:4px 0;margin-bottom:12px;color:#0A0A0A}
.prize.g .rank{background:var(--grad-gold)}
.prize.s .rank{background:linear-gradient(135deg,#e8e8e8,#a9a9a9)}
.prize.b .rank{background:linear-gradient(135deg,#d6a06a,#9a6b3d);color:#fff}
.prize .amt{font-family:var(--font-num);font-size:1.9rem;color:var(--gold);line-height:.9}
.prize.s .amt,.prize.b .amt{font-size:1.05rem;font-family:var(--font-body);font-weight:600;color:#fff}
.prize .pl{font-size:.74rem;color:var(--muted);margin-top:6px}

.lb{margin-top:26px;border:1px solid var(--line);background:#0C0C0E}
.lb-h{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--line);
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;color:var(--muted)}
.lb-row{display:grid;grid-template-columns:34px 1fr auto;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid #1c1c1f}
.lb-row:last-child{border-bottom:0}
.lb-row .pos{font-family:var(--font-num);font-size:1.5rem;color:var(--muted-dim);text-align:center}
.lb-row.top .pos{color:var(--gold)}
.lb-row .nm{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;font-size:.95rem}
.lb-row .sc{font-family:var(--font-num);font-size:1.5rem;color:#fff}
.lb-row.top .sc{color:var(--gold)}

/* =========================================================
   PACKAGES
   ========================================================= */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.pkg{position:relative;padding:34px 30px;background:var(--panel);border:1px solid var(--line);display:flex;flex-direction:column;
  transition:transform .3s var(--ease),border-color .3s}
.pkg:hover{transform:translateY(-6px);border-color:rgba(255,215,0,.4)}
.pkg.feat{border-color:var(--gold);background:linear-gradient(180deg,#181712,#0E0E10)}
.pkg.feat::before{content:"Most Popular";position:absolute;top:0;right:0;background:var(--grad-gold);color:#0A0A0A;
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;font-size:.64rem;font-weight:700;padding:6px 14px;
  clip-path:polygon(10px 0,100% 0,100% 100%,0 100%)}
.pkg .pname{font-family:var(--font-display);text-transform:uppercase;font-weight:700;letter-spacing:.08em;font-size:1.3rem}
.pkg .price{font-family:var(--font-num);font-size:3.4rem;color:var(--gold);line-height:.9;margin:14px 0 4px}
.pkg .price small{font-family:var(--font-body);font-size:.95rem;color:var(--muted);font-weight:500}
.pkg .per{color:var(--muted);font-size:.86rem;margin-bottom:22px}
.pkg ul{display:flex;flex-direction:column;gap:12px;margin-bottom:26px;flex:1}
.pkg li{display:flex;gap:10px;align-items:flex-start;font-size:.94rem;color:#d6d6da}
.pkg li svg{width:17px;height:17px;stroke:var(--gold);fill:none;stroke-width:2;flex:0 0 auto;margin-top:3px}
.pkg .btn{justify-content:center;width:100%}

/* =========================================================
   EXPERIENCE TIMELINE
   ========================================================= */
#experience{background:linear-gradient(180deg,#0E0E10,#0B0B0C)}
.tl{position:relative;margin-top:30px}
.tl::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;
  background:linear-gradient(var(--line),var(--gold) 50%,var(--line));transform:translateX(-50%)}
.tl-step{display:grid;grid-template-columns:1fr 80px 1fr;align-items:center;margin-bottom:14px}
.tl-step .card{background:var(--panel);border:1px solid var(--line);padding:24px 26px;position:relative;
  transition:border-color .3s,transform .3s}
.tl-step:hover .card{border-color:rgba(255,215,0,.45);transform:translateY(-3px)}
.tl-step .card h4{font-family:var(--font-display);text-transform:uppercase;font-weight:700;font-size:1.25rem;letter-spacing:.04em}
.tl-step .card p{color:var(--muted);font-size:.92rem;margin-top:6px}
.tl-node{grid-column:2;display:grid;place-items:center;position:relative;z-index:2}
.tl-node .dot{width:54px;height:54px;border-radius:50%;background:#0C0C0E;border:2px solid var(--gold);
  display:grid;place-items:center;font-family:var(--font-num);font-size:1.6rem;color:var(--gold);
  box-shadow:0 0 0 6px rgba(11,11,12,1),0 0 22px -4px rgba(255,184,0,.6)}
.tl-step.left .card{grid-column:1;text-align:right}
.tl-step.right .card{grid-column:3;text-align:left}

/* =========================================================
   GALLERY
   ========================================================= */
.gal-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:34px}
.gal-filters button{
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;
  padding:9px 18px;border:1px solid var(--line);color:var(--muted);transition:.25s;
  clip-path:polygon(7px 0,100% 0,100% calc(100% - 7px),calc(100% - 7px) 100%,0 100%,0 7px);
}
.gal-filters button:hover{color:#fff;border-color:#555}
.gal-filters button.active{background:var(--grad-gold);color:#0A0A0A;border-color:transparent}
.masonry{columns:3;column-gap:16px}
.gal-item{break-inside:avoid;margin-bottom:16px;position:relative;overflow:hidden;border:1px solid var(--line);
  cursor:pointer;background:#0C0C0E}
.gal-item image-slot{width:100%;display:block}
.gal-item .cap{position:absolute;left:0;right:0;bottom:0;padding:16px;z-index:3;
  background:linear-gradient(transparent,rgba(0,0,0,.85));transform:translateY(8px);opacity:0;transition:.3s;pointer-events:none}
.gal-item:hover .cap{transform:translateY(0);opacity:1}
.gal-item .cap b{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;font-size:.95rem;display:block}
.gal-item .cap span{color:var(--gold);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em}
.gal-item .zoom{position:absolute;top:12px;right:12px;width:34px;height:34px;border:1px solid rgba(255,255,255,.3);
  background:rgba(0,0,0,.5);display:grid;place-items:center;z-index:3;opacity:0;transition:.3s}
.gal-item:hover .zoom{opacity:1}
.gal-item .zoom svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2}
.gal-item.hide{display:none}

/* lightbox */
#lightbox{position:fixed;inset:0;z-index:9500;background:rgba(5,5,6,.94);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.3s;padding:40px}
#lightbox.open{opacity:1;visibility:visible}
#lightbox .lb-stage{max-width:900px;width:100%;text-align:center}
#lightbox .lb-stage>div{border:1px solid var(--line)}
#lightbox .lb-cap{margin-top:18px;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.16em;color:var(--gold)}
#lightbox .close{position:absolute;top:24px;right:30px;font-family:var(--font-display);font-size:1.4rem;color:#fff;
  width:48px;height:48px;border:1px solid var(--line);display:grid;place-items:center;transition:.25s}
#lightbox .close:hover{border-color:var(--gold);color:var(--gold)}

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.tcar{position:relative;overflow:hidden;margin-top:10px}
.ttrack{display:flex;transition:transform .6s var(--ease)}
.tcard{flex:0 0 100%;padding:0 8px}
.tcard .inner{background:var(--panel);border:1px solid var(--line);padding:42px 44px;position:relative;max-width:840px;margin:0 auto}
.tcard .quote{font-size:1.35rem;line-height:1.5;color:#ededf0;font-weight:500;text-wrap:pretty}
.tcard .stars{display:flex;gap:4px;margin-bottom:20px}
.tcard .stars svg{width:20px;height:20px;fill:var(--gold)}
.tcard .who{display:flex;align-items:center;gap:14px;margin-top:26px}
.tcard .av{width:52px;height:52px;border-radius:50%;overflow:hidden;border:1px solid var(--gold);flex:0 0 auto}
.tcard .who b{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;font-size:1rem;display:block}
.tcard .who span{color:var(--muted);font-size:.82rem}
.tcard .mark-q{position:absolute;top:24px;right:34px;font-family:var(--font-display);font-size:5rem;color:rgba(255,215,0,.12);line-height:1}
.tdots{display:flex;gap:9px;justify-content:center;margin-top:30px}
.tdots i{width:9px;height:9px;border:1px solid var(--muted-dim);cursor:pointer;transition:.25s;transform:rotate(45deg)}
.tdots i.active{background:var(--gold);border-color:var(--gold)}

/* =========================================================
   BOOKING
   ========================================================= */
#book{background:linear-gradient(180deg,#0B0B0C,#0E0E10);position:relative}
.book-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:center}
.book-copy h2{font-family:var(--font-display);text-transform:uppercase;font-weight:700;font-size:clamp(2rem,4vw,3.2rem);line-height:.96}
.book-copy .lead{margin-top:18px}
.book-feats{display:flex;flex-direction:column;gap:16px;margin-top:30px}
.book-feats .bf{display:flex;gap:14px;align-items:flex-start}
.book-feats .bf .bi{width:42px;height:42px;flex:0 0 auto;border:1px solid var(--line);display:grid;place-items:center;background:#0C0C0E}
.book-feats .bf svg{width:20px;height:20px;stroke:var(--gold);fill:none;stroke-width:1.6}
.book-feats .bf b{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;font-size:1rem}
.book-feats .bf p{color:var(--muted);font-size:.88rem}

.glass{
  position:relative;padding:40px;border:1px solid rgba(255,255,255,.1);
  background:rgba(22,22,25,.55);backdrop-filter:blur(16px);
  box-shadow:0 30px 80px -30px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.05);
  clip-path:polygon(20px 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%,0 20px);
}
.glass h3{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;font-size:1.3rem;margin-bottom:6px}
.glass .gsub{color:var(--muted);font-size:.86rem;margin-bottom:24px}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;color:var(--muted);margin-bottom:8px}
.field input,.field select{
  width:100%;padding:13px 14px;background:#0C0C0E;border:1px solid var(--line);color:#fff;font-family:var(--font-body);
  font-size:.95rem;transition:border-color .25s;
}
.field input:focus,.field select:focus{outline:none;border-color:var(--gold)}
.field input::placeholder{color:var(--muted-dim)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.stepper{display:flex;align-items:center;border:1px solid var(--line);background:#0C0C0E}
.stepper button{width:48px;height:48px;font-size:1.4rem;color:var(--gold);font-family:var(--font-num)}
.stepper input{border:none;text-align:center;background:transparent;font-family:var(--font-num);font-size:1.5rem}
.glass .btn{width:100%;justify-content:center;margin-top:8px}
.glass .or{text-align:center;color:var(--muted-dim);font-size:.78rem;margin:14px 0;text-transform:uppercase;letter-spacing:.2em}

/* =========================================================
   CONTACT + FOOTER
   ========================================================= */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:stretch}
.map-wrap{position:relative;border:1px solid var(--line);overflow:hidden;min-height:380px;background:#0C0C0E}
.map-wrap iframe{width:100%;height:100%;min-height:380px;filter:grayscale(1) invert(.9) contrast(.9);border:0}
.map-pin{position:absolute;top:18px;left:18px;z-index:2;background:rgba(11,11,12,.85);border:1px solid var(--line);
  padding:12px 16px;backdrop-filter:blur(6px);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;font-size:.82rem}
.map-pin span{color:var(--gold);display:block;font-size:.66rem;letter-spacing:.2em;margin-top:3px}
.contact-list{display:flex;flex-direction:column;gap:14px}
.cline{display:flex;align-items:center;gap:18px;padding:20px 22px;border:1px solid var(--line);background:var(--panel);transition:.25s}
.cline:hover{border-color:rgba(255,215,0,.45);transform:translateX(4px)}
.cline .ci{width:46px;height:46px;flex:0 0 auto;border:1px solid var(--line);display:grid;place-items:center;background:#0C0C0E}
.cline .ci svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.6}
.cline b{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;font-size:.74rem;color:var(--muted);display:block}
.cline span{font-size:1.02rem;color:#fff}
.socials{display:flex;gap:12px;margin-top:6px}
.socials a{width:48px;height:48px;border:1px solid var(--line);display:grid;place-items:center;transition:.25s}
.socials a:hover{border-color:var(--gold);background:var(--gold);transform:translateY(-3px)}
.socials a:hover svg{stroke:#0A0A0A}
.socials a svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:1.6;transition:.25s}

footer{border-top:1px solid var(--line);background:#070708;padding:70px 32px 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;max-width:var(--maxw);margin:0 auto}
.foot-brand .brand{margin-bottom:18px}
.foot-brand p{color:var(--muted);font-size:.9rem;max-width:30ch}
.foot-col h5{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--gold);margin-bottom:18px}
.foot-col a{display:block;color:var(--muted);font-size:.92rem;padding:6px 0;transition:.2s}
.foot-col a:hover{color:#fff;padding-left:6px}
.foot-bot{max-width:var(--maxw);margin:50px auto 0;padding-top:24px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  color:var(--muted-dim);font-size:.82rem}
.foot-bot .made{font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;font-size:.74rem}

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}

@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation-duration:.001s!important}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1024px){
  .nav-links{display:none}
  .burger{display:flex}
  .tour-grid,.book-grid,.contact-grid{grid-template-columns:1fr;gap:34px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .act-grid,.pkg-grid{grid-template-columns:repeat(2,1fr)}
  .masonry{columns:2}
}
@media(max-width:680px){
  .section{padding:84px 20px}
  #nav,#nav.scrolled{padding:12px 18px}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .hero-stats .num{font-size:2.4rem}
  .act-grid,.pkg-grid,.prize-row,.countdown,.foot-grid{grid-template-columns:1fr 1fr}
  .masonry{columns:1}
  #home{cursor:auto}
  #scope{display:none}
  .tl::before{left:26px}
  .tl-step{grid-template-columns:52px 1fr;gap:16px}
  .tl-node{grid-column:1}
  .tl-step.left .card,.tl-step.right .card{grid-column:2;text-align:left}
  .tcard .inner{padding:30px 24px}
  .tcard .quote{font-size:1.1rem}
  .prize .amt{font-size:1.4rem}
}
@media(max-width:420px){
  .hero-stats{grid-template-columns:1fr 1fr}
  .prize-row{grid-template-columns:1fr}
}
