/* =========================================================
   GTA6.COMMUNITY — Vice City neon theme
   ========================================================= */
:root{
  --bg:#08060f;
  --bg-2:#0d0a1c;
  --panel:#120e24;
  --panel-2:#171130;
  --line:rgba(255,255,255,.08);
  --text:#f4efff;
  --muted:#a99fc6;
  --pink:#ff2e88;
  --pink-2:#ff6fae;
  --cyan:#22e6ff;
  --purple:#8a4dff;
  --gold:#ffc24d;
  --grad:linear-gradient(90deg,#ff2e88 0%,#ff8a4c 45%,#ffd36e 100%);
  --grad-cool:linear-gradient(120deg,#8a4dff,#22e6ff);
  --glow-pink:0 0 40px rgba(255,46,136,.45);
  --glow-cyan:0 0 40px rgba(34,230,255,.35);
  --maxw:1120px;
  --radius:18px;
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --display:'Anton','Inter',system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font);
  background:radial-gradient(1200px 700px at 50% -10%, #1a1038 0%, var(--bg) 55%) fixed;
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

.grad{
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

.skip-link{position:absolute;left:-999px;top:0;background:var(--pink);color:#fff;padding:10px 16px;border-radius:0 0 10px 0;z-index:200}
.skip-link:focus{left:0}

/* Keyboard focus visibility (WCAG 2.4.7) */
:focus-visible{outline:3px solid var(--cyan);outline-offset:2px;border-radius:6px}
a:focus-visible,.btn:focus-visible,summary:focus-visible{outline:3px solid var(--cyan);outline-offset:3px}
.pins g:focus-visible{outline:none}
.pins g:focus-visible .pin-dot{stroke:#fff;stroke-width:3px;filter:drop-shadow(0 0 10px rgba(34,230,255,1))}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-weight:700;font-size:.98rem;letter-spacing:.2px;
  padding:.8em 1.4em;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:transform .15s ease, box-shadow .25s ease, background .25s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--grad);color:#1a0714;box-shadow:var(--glow-pink)}
.btn--primary:hover{box-shadow:0 0 60px rgba(255,46,136,.7);transform:translateY(-2px)}
.btn--ghost{background:rgba(255,255,255,.04);border-color:var(--line);color:var(--text)}
.btn--ghost:hover{border-color:var(--pink);color:#fff;box-shadow:var(--glow-pink)}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:100;backdrop-filter:blur(14px);
  background:rgba(8,6,15,.72);border-bottom:1px solid var(--line)}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:12px 22px;display:flex;align-items:center;gap:20px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800}
.brand__mark{
  font-family:var(--display);font-size:1.05rem;letter-spacing:1px;
  display:grid;place-items:center;width:38px;height:38px;border-radius:10px;
  background:var(--grad);color:#1a0714;box-shadow:var(--glow-pink)}
.brand__text{font-size:1.15rem;letter-spacing:.3px}
.brand__dim{color:var(--muted);font-weight:600}
.nav__links{display:flex;gap:22px;margin-left:auto;font-weight:600;font-size:.95rem}
.nav__links a{color:var(--muted);transition:color .2s}
.nav__links a:hover{color:#fff}
.nav__cta{margin-left:4px}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__toggle span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:.25s}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;overflow:hidden;padding:90px 20px 60px}
.hero__sky{position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,#0a0618 0%, #241147 30%, #7a2168 58%, #d9466a 76%, #ff8a4c 90%, #ffd36e 100%)}
.hero__sun{position:absolute;left:50%;top:74%;transform:translate(-50%,-50%);
  width:min(440px,72vw);height:min(440px,72vw);border-radius:50%;
  background:linear-gradient(180deg,#fff2b0,#ff8a4c 55%,#ff2e88);
  box-shadow:0 0 120px rgba(255,138,76,.5);opacity:.78}
.hero__sun::after{content:"";position:absolute;left:0;right:0;bottom:0;height:42%;
  background:repeating-linear-gradient(180deg,transparent 0 14px,#0a0618 14px 20px);opacity:.5}
.hero__grid{position:absolute;left:-20%;right:-20%;bottom:0;height:42%;
  background:
    linear-gradient(180deg,transparent, rgba(8,6,15,.9)),
    repeating-linear-gradient(90deg,rgba(34,230,255,.35) 0 2px,transparent 2px 64px),
    repeating-linear-gradient(0deg,rgba(34,230,255,.3) 0 2px,transparent 2px 48px);
  transform:perspective(340px) rotateX(66deg);transform-origin:bottom;opacity:.5}
.hero__palms{position:absolute;inset:0}
.palm-svg{position:absolute;bottom:0;width:100%;height:70%}
.hero__content{position:relative;z-index:2;max-width:900px}
.hero__content::before{content:"";position:absolute;inset:-14% -16% 8%;z-index:-1;
  background:radial-gradient(64% 52% at 50% 34%, rgba(6,4,12,.74), rgba(6,4,12,.32) 52%, rgba(6,4,12,0) 78%);
  filter:blur(10px)}
.hero__eyebrow{text-transform:uppercase;letter-spacing:3px;font-size:.75rem;font-weight:700;
  color:#ffe9c7;opacity:.9;margin-bottom:14px;text-shadow:0 2px 10px rgba(0,0,0,.5)}
.hero__title{font-family:var(--display);font-weight:400;line-height:.94;
  font-size:clamp(2.6rem,7.5vw,6rem);letter-spacing:.5px;text-shadow:0 6px 30px rgba(0,0,0,.45)}
.hero__title .grad{filter:drop-shadow(0 2px 3px rgba(0,0,0,.55)) drop-shadow(0 6px 26px rgba(255,46,136,.4))}
.hero__sub{max-width:620px;margin:20px auto 0;font-size:clamp(1rem,2vw,1.2rem);
  color:#fbeede;text-shadow:0 2px 12px rgba(0,0,0,.5)}

/* Countdown */
.countdown{display:flex;align-items:flex-end;justify-content:center;gap:clamp(6px,2vw,20px);
  margin:34px auto 10px;padding:20px clamp(14px,3vw,34px);width:fit-content;
  background:rgba(8,6,15,.5);border:1px solid rgba(255,255,255,.14);border-radius:20px;
  backdrop-filter:blur(8px);box-shadow:0 20px 60px rgba(0,0,0,.4)}
.cd__unit{display:flex;flex-direction:column;align-items:center;min-width:clamp(52px,12vw,92px)}
.cd__num{font-family:var(--display);font-size:clamp(2rem,7vw,4rem);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  font-variant-numeric:tabular-nums}
.cd__lbl{text-transform:uppercase;letter-spacing:2px;font-size:.62rem;color:var(--muted);margin-top:8px;font-weight:700}
.cd__sep{font-family:var(--display);font-size:clamp(1.4rem,4vw,2.6rem);color:var(--pink-2);opacity:.6;padding-bottom:22px}
.hero__date{margin-top:6px;color:#ffe9c7;font-size:.95rem;text-shadow:0 2px 10px rgba(0,0,0,.5)}
.hero__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:26px}
.hero__scroll{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:3;
  font-size:1.8rem;color:#fff;opacity:.7;animation:bob 2s ease-in-out infinite}
@keyframes bob{50%{transform:translate(-50%,8px)}}
@media (prefers-reduced-motion:reduce){.hero__scroll{animation:none}}

/* ---------- Section shells ---------- */
section .wrap{position:relative;z-index:2}
.section-title{font-family:var(--display);font-weight:400;line-height:1.02;
  font-size:clamp(1.9rem,5vw,3.4rem);letter-spacing:.4px;text-align:center}
.section-lead{text-align:center;color:var(--muted);max-width:620px;margin:14px auto 0;font-size:1.05rem}
.section-kicker{text-transform:uppercase;letter-spacing:3px;font-size:.72rem;color:var(--cyan);font-weight:800}
.hype,.facts,.world,.cast,.trailers,.preorder,.news,.faq,.community{padding:clamp(64px,9vw,110px) 0;position:relative}
.facts,.cast,.news{background:linear-gradient(180deg,transparent,rgba(138,77,255,.05),transparent)}

/* ---------- Hype meter ---------- */
.hype__card{display:grid;grid-template-columns:1.1fr 1fr;gap:30px;align-items:center;
  background:linear-gradient(135deg,rgba(255,46,136,.14),rgba(34,230,255,.1));
  border:1px solid var(--line);border-radius:24px;padding:clamp(26px,4vw,48px);
  box-shadow:0 30px 80px rgba(0,0,0,.4)}
.hype__count{font-family:var(--display);font-size:clamp(3rem,11vw,7rem);line-height:.9;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  font-variant-numeric:tabular-nums;text-shadow:0 0 60px rgba(255,46,136,.3)}
.hype__label{color:var(--muted);text-transform:uppercase;letter-spacing:2px;font-size:.72rem;font-weight:700}
.hype__right{text-align:center}
.hype__prompt{font-size:1.25rem;font-weight:700;margin-bottom:16px}
.btn--hype{font-size:1.15rem;padding:1em 1.8em;background:var(--grad);color:#1a0714;
  box-shadow:var(--glow-pink);border:none;position:relative;overflow:hidden}
.btn--hype:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 0 70px rgba(255,46,136,.75)}
.btn--hype:disabled{opacity:.55;cursor:progress}
.hype__flame{display:inline-block;transition:transform .2s}
.btn--hype.pop .hype__flame{animation:flamepop .45s ease}
@keyframes flamepop{0%{transform:scale(1)}40%{transform:scale(1.6) rotate(-8deg)}100%{transform:scale(1)}}
.hype__hint,.hype__mine{color:var(--muted);font-size:.85rem;margin-top:12px}
.hype__mine strong{color:var(--pink-2)}
/* floating +1 */
.hfloat{position:fixed;pointer-events:none;font-weight:800;color:var(--pink-2);
  font-size:1.4rem;z-index:150;text-shadow:0 0 20px rgba(255,46,136,.8);animation:hfloat 1s ease-out forwards}
@keyframes hfloat{to{transform:translateY(-70px);opacity:0}}

/* ---------- Facts grid ---------- */
.facts__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.fcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;transition:transform .2s, border-color .2s, box-shadow .2s}
.fcard:hover{transform:translateY(-4px);border-color:rgba(255,46,136,.5);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.fcard__icon{font-size:1.8rem;margin-bottom:10px}
.fcard h3{font-size:1.15rem;margin-bottom:8px}
.fcard p{color:var(--muted);font-size:.96rem}
.fcard strong{color:var(--text)}

/* ---------- World / map ---------- */
.world__layout{display:grid;grid-template-columns:1fr 1fr;gap:34px;margin-top:44px;align-items:start}
.map{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px;
  box-shadow:0 30px 80px rgba(0,0,0,.4)}
.map__svg{width:100%;height:auto;border-radius:12px}
.pins circle{cursor:pointer;transition:r .2s, filter .2s}
.pins .pin-dot{fill:var(--pink);filter:drop-shadow(0 0 6px rgba(255,46,136,.9))}
.pins .pin-hit{fill:transparent}
.pins g:hover .pin-dot,.pins g.active .pin-dot{fill:var(--cyan);filter:drop-shadow(0 0 10px rgba(34,230,255,1))}
.pins text{fill:#fff;font-size:11px;font-weight:700;font-family:var(--font);paint-order:stroke;
  stroke:rgba(0,0,0,.7);stroke-width:3px;pointer-events:none;opacity:.9}
.world__info{display:flex;flex-direction:column}
.world__list{list-style:none;display:flex;flex-direction:column;gap:10px}
.world__list li{padding:16px 18px;border-radius:12px;background:var(--panel);
  border:1px solid var(--line);cursor:pointer;transition:.18s}
.world__list li:hover,.world__list li.active{border-color:var(--pink);background:rgba(255,46,136,.1)}
.world__list li strong{font-size:1.05rem;font-weight:700}
.world__list li .world__sub{color:var(--cyan);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:1.5px;display:block;margin:2px 0 6px}
.world__list li p{color:var(--muted);font-size:.92rem;margin:0}

/* ---------- Cast ---------- */
.cast__grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:44px}
.ch{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:30px;
  position:relative;overflow:hidden}
.ch::before{content:"";position:absolute;inset:0;opacity:.14;z-index:0}
.ch--jason::before{background:radial-gradient(400px 200px at 90% 0%,var(--cyan),transparent)}
.ch--lucia::before{background:radial-gradient(400px 200px at 90% 0%,var(--pink),transparent)}
.ch>*{position:relative;z-index:1}
.ch__portrait{width:74px;height:74px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--display);font-size:2rem;margin-bottom:16px;color:#0a0714}
.ch--jason .ch__portrait{background:linear-gradient(135deg,#22e6ff,#8a4dff);box-shadow:var(--glow-cyan)}
.ch--lucia .ch__portrait{background:var(--grad);box-shadow:var(--glow-pink)}
.ch h3{font-size:1.4rem}
.ch__role{color:var(--cyan);font-weight:700;text-transform:uppercase;letter-spacing:1.5px;font-size:.72rem;margin:4px 0 12px}
.ch--lucia .ch__role{color:var(--pink-2)}
.ch p{color:var(--muted)}
.cast__note{text-align:center;color:var(--muted);margin-top:26px;max-width:640px;margin-inline:auto;font-size:1.05rem}

/* ---------- Trailers ---------- */
.trailers__grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:44px}
.tr__frame{position:relative;aspect-ratio:16/9;border-radius:14px;overflow:hidden;
  border:1px solid var(--line);box-shadow:0 20px 60px rgba(0,0,0,.45)}
.tr__frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.tr figcaption{color:var(--muted);margin-top:12px;font-size:.92rem;text-align:center}
.tr figcaption strong{color:var(--text)}

/* ---------- Pre-order ---------- */
.preorder__grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:760px;margin:44px auto 0}
.ed{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:30px;position:relative}
.ed--ultimate{border-color:rgba(255,46,136,.5);box-shadow:var(--glow-pink)}
.ed__flag{position:absolute;top:-12px;right:22px;background:var(--grad);color:#1a0714;
  font-weight:800;font-size:.7rem;text-transform:uppercase;letter-spacing:1px;padding:5px 12px;border-radius:999px}
.ed h3{font-size:1.3rem}
.ed__price{font-family:var(--display);font-size:2.6rem;margin:6px 0 16px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.ed ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.ed li{padding-left:26px;position:relative;color:var(--muted)}
.ed li::before{content:"✦";position:absolute;left:0;color:var(--pink-2)}
.preorder__where{text-align:center;color:var(--muted);margin-top:26px;font-size:.95rem}
.preorder__disclaimer{display:block;font-size:.82rem;opacity:.8;margin-top:6px}

/* ---------- Timeline ---------- */
.timeline{max-width:760px;margin:44px auto 0;list-style:none;position:relative;padding-left:34px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(180deg,var(--pink),var(--purple),var(--cyan))}
.tl{position:relative;padding:0 0 30px 6px}
.tl::before{content:"";position:absolute;left:-30px;top:4px;width:16px;height:16px;border-radius:50%;
  background:var(--bg);border:3px solid var(--pink);box-shadow:0 0 12px rgba(255,46,136,.7)}
.tl.tl--future::before{border-color:var(--cyan);box-shadow:0 0 12px rgba(34,230,255,.7)}
.tl__date{font-weight:800;color:var(--pink-2);font-size:.82rem;text-transform:uppercase;letter-spacing:1px}
.tl.tl--future .tl__date{color:var(--cyan)}
.tl__title{font-size:1.1rem;font-weight:700;margin:2px 0 4px}
.tl p{color:var(--muted);font-size:.95rem}

/* ---------- FAQ ---------- */
.faq__list{max-width:780px;margin:44px auto 0;display:flex;flex-direction:column;gap:12px}
.qa{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.qa__q{width:100%;text-align:left;background:none;border:0;color:var(--text);cursor:pointer;
  padding:20px 22px;font-size:1.05rem;font-weight:700;display:flex;justify-content:space-between;gap:16px;align-items:center}
.qa__q:hover{color:var(--pink-2)}
.qa__icon{flex:none;transition:transform .25s;color:var(--pink-2);font-size:1.3rem;line-height:1}
.qa[open] .qa__icon{transform:rotate(45deg)}
.qa__a{padding:0 22px 20px;color:var(--muted)}

/* ---------- Community ---------- */
.community__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px}
.clink{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;text-align:center;transition:.2s;display:flex;flex-direction:column;gap:6px}
.clink:hover{transform:translateY(-4px);border-color:var(--cyan);box-shadow:var(--glow-cyan)}
.clink__icon{font-size:2rem}
.clink__name{font-weight:800;font-size:1.15rem}
.clink__sub{color:var(--muted);font-size:.88rem}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--line);background:var(--bg-2);padding:50px 0 30px;margin-top:30px}
.footer__inner{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.footer__brand{display:flex;align-items:center;gap:14px}
.footer__name{font-weight:800;font-size:1.1rem}
.footer__tag{color:var(--muted);font-size:.9rem}
.footer__nav{display:flex;gap:20px;flex-wrap:wrap;color:var(--muted);font-weight:600;font-size:.92rem}
.footer__nav a:hover{color:#fff}
.footer__legal{margin-top:30px;padding-top:22px;border-top:1px solid var(--line)}
.footer__legal p{color:var(--muted);font-size:.8rem;max-width:820px}
.footer__copy{margin-top:10px;opacity:.75}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .btn--hype.pop .hype__flame{animation:none}
  .hfloat{animation:none;display:none}
  .btn:hover,.btn--primary:hover,.btn--ghost:hover,.btn--hype:hover,.fcard:hover,.clink:hover,.ed:hover,.tr:hover{transform:none}
}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .facts__grid,.community__grid{grid-template-columns:repeat(2,1fr)}
  .world__layout,.cast__grid,.trailers__grid,.preorder__grid,.hype__card{grid-template-columns:1fr}
  .world__info{position:static}
  .nav__links,.nav__cta{display:none}
  .nav__toggle{display:flex;margin-left:auto}
  .nav.open .nav__links{display:flex;position:absolute;top:63px;left:0;right:0;flex-direction:column;
    gap:0;background:rgba(8,6,15,.97);border-bottom:1px solid var(--line);padding:8px 22px 18px}
  .nav.open .nav__links a{padding:12px 0;border-bottom:1px solid var(--line)}
}
@media (max-width:560px){
  .facts__grid,.community__grid{grid-template-columns:1fr}
  .cd__sep{display:none}
  .countdown{gap:4px;flex-wrap:wrap}
  .hype__card{text-align:center}
}
