/* ============================================================
   FRAXTAL — Artist Landing (preview /landing)
   Self-contained. Loaded via plain <link>, no Vite build needed.
   Identity: abyssal #0A0A0A · amber #D4A574 · cyan #5BBFB5 · cream #E8DCC4
   Fonts: Space Grotesk (display) + Inter (body), self-hosted woff2.
   ============================================================ */

/* ---------- Self-hosted fonts (RGPD: no Google CDN) ---------- */
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/spacegrotesk-400.woff2') format('woff2');}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/spacegrotesk-500.woff2') format('woff2');}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/spacegrotesk-600.woff2') format('woff2');}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/spacegrotesk-700.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/inter-400.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/inter-500.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/inter-600.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/inter-700.woff2') format('woff2');}

/* ---------- Tokens ---------- */
.fx-landing{
  --abyss:#0A0A0A;
  --abyss-2:#0f0d0b;
  --amber:#D4A574;
  --amber-soft:#e6c79e;
  --cyan:#5BBFB5;
  --cream:#E8DCC4;
  --cream-dim:rgba(232,220,196,.66);
  --line:rgba(232,220,196,.10);
  --glass:rgba(232,220,196,.035);
  --display:'Space Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --body:'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --maxw:1200px;
  --ease:cubic-bezier(.16,1,.3,1);
}

/* ---------- Reset within landing scope ---------- */
.fx-landing *,.fx-landing *::before,.fx-landing *::after{box-sizing:border-box;}
.fx-landing{
  font-family:var(--body);
  color:var(--cream);
  background:var(--abyss);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  position:relative;
  min-height:100vh;
  overflow-x:hidden;
}
.fx-landing img{max-width:100%;display:block;}
.fx-landing a{color:inherit;text-decoration:none;}
.fx-container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ============================================================
   LIVING COSMIC BACKGROUND (compositor-only: transform/opacity)
   ============================================================ */
.fx-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;background:
  radial-gradient(120% 90% at 50% -10%, #16110c 0%, var(--abyss) 55%, #060504 100%);}
.fx-blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;will-change:transform;}
.fx-blob.b1{width:46vmax;height:46vmax;left:-8vmax;top:-10vmax;background:radial-gradient(circle,rgba(212,165,116,.55),transparent 62%);animation:fxDrift1 26s var(--ease) infinite alternate;}
.fx-blob.b2{width:40vmax;height:40vmax;right:-10vmax;top:18vmax;background:radial-gradient(circle,rgba(91,191,181,.34),transparent 64%);animation:fxDrift2 32s var(--ease) infinite alternate;}
.fx-blob.b3{width:34vmax;height:34vmax;left:24vmax;bottom:-14vmax;background:radial-gradient(circle,rgba(212,165,116,.30),transparent 66%);animation:fxDrift3 38s var(--ease) infinite alternate;}
@keyframes fxDrift1{from{transform:translate3d(0,0,0) scale(1);}to{transform:translate3d(6vmax,4vmax,0) scale(1.12);}}
@keyframes fxDrift2{from{transform:translate3d(0,0,0) scale(1.05);}to{transform:translate3d(-5vmax,-3vmax,0) scale(.92);}}
@keyframes fxDrift3{from{transform:translate3d(0,0,0) scale(.95);}to{transform:translate3d(4vmax,-5vmax,0) scale(1.1);}}

/* Twinkling starfield via repeating radial dots, two layers drifting */
.fx-stars{position:absolute;inset:-20%;background-repeat:repeat;opacity:.5;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(232,220,196,.9), transparent),
    radial-gradient(1px 1px at 70% 60%, rgba(232,220,196,.7), transparent),
    radial-gradient(1.4px 1.4px at 40% 80%, rgba(212,165,116,.8), transparent),
    radial-gradient(1px 1px at 85% 25%, rgba(232,220,196,.6), transparent),
    radial-gradient(1px 1px at 55% 15%, rgba(91,191,181,.7), transparent),
    radial-gradient(1.2px 1.2px at 10% 70%, rgba(232,220,196,.7), transparent);
  background-size:520px 520px;
  animation:fxStarTwinkle 7s ease-in-out infinite, fxStarPan 120s linear infinite;will-change:opacity,transform;}
.fx-stars.l2{background-size:340px 340px;opacity:.35;animation-duration:9s,180s;animation-direction:alternate,normal;}
@keyframes fxStarTwinkle{0%,100%{opacity:.5;}50%{opacity:.22;}}
@keyframes fxStarPan{from{transform:translate3d(0,0,0);}to{transform:translate3d(-120px,-120px,0);}}

.fx-grain{position:absolute;inset:0;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ============================================================
   HEADER — full-width, transparent over hero, glass on scroll
   ============================================================ */
.fx-header{position:fixed;top:0;left:0;right:0;z-index:50;width:100%;
  transition:background .4s var(--ease),backdrop-filter .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);
  border-bottom:1px solid transparent;}
.fx-header.scrolled{background:rgba(10,10,10,.72);backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);border-bottom-color:var(--line);box-shadow:0 12px 40px -24px rgba(0,0,0,.9);}
.fx-header__inner{display:flex;align-items:center;justify-content:space-between;height:72px;}
.fx-brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:700;letter-spacing:.16em;
  font-size:1.02rem;text-transform:uppercase;color:var(--cream);}
.fx-brand .sigil{color:var(--amber);font-size:1.2em;line-height:1;transform:translateY(1px);}
.fx-nav{display:flex;align-items:center;gap:28px;}
.fx-nav a{font-size:.9rem;color:var(--cream-dim);letter-spacing:.02em;transition:color .25s var(--ease);position:relative;}
.fx-nav a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--amber);transition:width .3s var(--ease);}
.fx-nav a:hover{color:var(--cream);}
.fx-nav a:hover::after{width:100%;}
.fx-nav__cta{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:999px;
  border:1px solid rgba(212,165,116,.4);color:var(--amber-soft)!important;font-weight:600;
  transition:transform .25s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease);}
.fx-nav__cta::after{display:none;}
.fx-nav__cta:hover{transform:translateY(-1px);background:rgba(212,165,116,.1);box-shadow:0 0 0 1px rgba(212,165,116,.5),0 8px 30px -10px rgba(212,165,116,.5);}
.fx-burger{display:none;background:none;border:0;color:var(--cream);padding:8px;cursor:pointer;}

/* ============================================================
   HERO
   ============================================================ */
.fx-hero{position:relative;z-index:1;min-height:100vh;min-height:100svh;display:flex;align-items:center;
  padding:120px 0 80px;overflow:hidden;}
.fx-hero__media{position:absolute;inset:0;z-index:-1;}
.fx-hero__media video,.fx-hero__media img{width:100%;height:100%;object-fit:cover;opacity:.55;}
.fx-hero__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,.45) 0%,rgba(10,10,10,.2) 35%,rgba(10,10,10,.78) 78%,var(--abyss) 100%);}
.fx-hero__inner{max-width:760px;}
.fx-kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--display);font-size:.74rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--amber-soft);margin-bottom:26px;
  padding:7px 14px;border:1px solid var(--line);border-radius:999px;background:var(--glass);backdrop-filter:blur(4px);}
.fx-kicker .dot{width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);animation:fxPulseDot 2.6s ease-in-out infinite;}
@keyframes fxPulseDot{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(.7);}}

.fx-hero h1{font-family:var(--display);font-weight:700;line-height:.98;letter-spacing:-.02em;
  font-size:clamp(2.9rem,8vw,6rem);margin:0 0 22px;}
/* Gradient title WITH visible fallback (@supports) so in-app browsers never show invisible text */
.fx-grad{color:var(--amber-soft);} /* fallback color first */
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  .fx-grad{
    background:linear-gradient(100deg,#f0dcbf 0%,var(--amber) 42%,var(--cyan) 100%);
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
    padding-bottom:.08em; /* room for descenders under background-clip */
  }
}
.fx-hero__lead{font-size:clamp(1.05rem,2.2vw,1.32rem);color:var(--cream-dim);max-width:580px;margin:0 0 38px;}
.fx-hero__lead strong{color:var(--cream);font-weight:600;}

.fx-cta-row{display:flex;flex-wrap:wrap;gap:16px;align-items:center;}
.fx-btn{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:.96rem;
  padding:15px 26px;border-radius:14px;transition:transform .25s var(--ease),box-shadow .35s var(--ease),background .3s var(--ease);will-change:transform;}
.fx-btn svg{width:18px;height:18px;}
.fx-btn--primary{background:linear-gradient(120deg,var(--amber),#c79462);color:#1a120a;
  box-shadow:0 10px 36px -12px rgba(212,165,116,.7);}
.fx-btn--primary:hover{transform:translateY(-2px);box-shadow:0 0 0 1px rgba(212,165,116,.6),0 18px 50px -14px rgba(212,165,116,.9);}
.fx-btn--ghost{border:1px solid var(--line);color:var(--cream);background:var(--glass);}
.fx-btn--ghost:hover{transform:translateY(-2px);border-color:rgba(91,191,181,.5);box-shadow:0 0 0 1px rgba(91,191,181,.4),0 14px 40px -16px rgba(91,191,181,.5);color:#fff;}

.fx-scrollcue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;
  color:var(--cream-dim);font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;animation:fxFloat 2.8s ease-in-out infinite;}
.fx-scrollcue svg{width:18px;height:18px;}
@keyframes fxFloat{0%,100%{transform:translate(-50%,0);}50%{transform:translate(-50%,8px);}}

/* ============================================================
   SECTIONS (shared)
   ============================================================ */
.fx-section{position:relative;z-index:1;padding:96px 0;}
.fx-section--tight{padding:64px 0;}
.fx-sec-head{margin-bottom:48px;max-width:640px;}
.fx-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-size:.72rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--cyan);margin-bottom:16px;}
.fx-eyebrow .sigil{color:var(--amber);}
.fx-sec-head h2{font-family:var(--display);font-weight:600;font-size:clamp(1.9rem,4.5vw,3rem);line-height:1.02;letter-spacing:-.015em;margin:0 0 14px;color:var(--cream);}
.fx-sec-head p{color:var(--cream-dim);font-size:1.04rem;margin:0;}
.fx-sec-head--row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;max-width:none;}
.fx-link-more{display:inline-flex;align-items:center;gap:8px;color:var(--amber-soft);font-weight:600;font-size:.92rem;white-space:nowrap;transition:gap .25s var(--ease),color .25s var(--ease);}
.fx-link-more svg{width:16px;height:16px;}
.fx-link-more:hover{gap:13px;color:#fff;}

/* ---------- Releases grid ---------- */
.fx-releases{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.fx-release{position:relative;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--glass);
  transition:transform .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);will-change:transform;}
.fx-release:hover{transform:translateY(-6px);border-color:rgba(212,165,116,.4);box-shadow:0 24px 60px -28px rgba(212,165,116,.55);}
.fx-release__cover{position:relative;aspect-ratio:1/1;overflow:hidden;background:linear-gradient(135deg,#1a140e,#0d0b08);}
.fx-release__cover img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease),filter .6s var(--ease);}
.fx-release:hover .fx-release__cover img{transform:scale(1.06);filter:saturate(1.1);}
.fx-release__cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(10,10,10,.85) 100%);opacity:.9;}
.fx-release__body{position:absolute;left:0;right:0;bottom:0;padding:18px 18px 16px;z-index:2;}
.fx-release__year{font-family:var(--display);font-size:.72rem;letter-spacing:.18em;color:var(--amber-soft);text-transform:uppercase;margin-bottom:4px;}
.fx-release__name{font-family:var(--display);font-weight:600;font-size:1.12rem;color:var(--cream);line-height:1.15;}
.fx-release__spotify{position:absolute;top:14px;right:14px;z-index:3;width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;background:rgba(10,10,10,.55);backdrop-filter:blur(6px);
  border:1px solid var(--line);color:var(--cream);opacity:0;transform:translateY(-6px);
  transition:opacity .3s var(--ease),transform .3s var(--ease),background .3s var(--ease),color .3s var(--ease);}
.fx-release:hover .fx-release__spotify{opacity:1;transform:translateY(0);}
.fx-release__spotify:hover{background:var(--amber);color:#10100c;}
.fx-release__spotify svg{width:20px;height:20px;}
.fx-release__link{position:absolute;inset:0;z-index:2;}
.fx-releases__empty{grid-column:1/-1;padding:48px;text-align:center;border:1px dashed var(--line);border-radius:18px;color:var(--cream-dim);}

/* ---------- Lyrics teaser ---------- */
.fx-lyrics{position:relative;border:1px solid var(--line);border-radius:24px;overflow:hidden;
  background:linear-gradient(120deg,rgba(212,165,116,.07),rgba(91,191,181,.05));padding:clamp(34px,5vw,64px);}
.fx-lyrics__glow{position:absolute;width:340px;height:340px;border-radius:50%;filter:blur(80px);
  background:radial-gradient(circle,rgba(212,165,116,.4),transparent 70%);top:-120px;right:-80px;pointer-events:none;}
.fx-lyrics__inner{position:relative;z-index:1;max-width:620px;}
.fx-lyrics blockquote{font-family:var(--display);font-weight:500;font-size:clamp(1.4rem,3.4vw,2.2rem);line-height:1.25;
  color:var(--cream);margin:0 0 26px;letter-spacing:-.01em;}
.fx-lyrics blockquote span{color:var(--amber);}

/* ---------- Games ---------- */
.fx-games{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;}
.fx-game{position:relative;border:1px solid var(--line);border-radius:22px;overflow:hidden;min-height:300px;
  display:flex;flex-direction:column;justify-content:flex-end;padding:32px;isolation:isolate;
  transition:transform .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);will-change:transform;}
.fx-game::before{content:"";position:absolute;inset:0;z-index:-2;transition:transform .6s var(--ease),opacity .4s var(--ease);}
.fx-game.fraxtone::before{background:radial-gradient(120% 120% at 20% 10%,rgba(91,191,181,.4),transparent 55%),linear-gradient(160deg,#0e1413,#0a0a0a);}
.fx-game.fraxtanoid::before{background:radial-gradient(120% 120% at 80% 10%,rgba(212,165,116,.42),transparent 55%),linear-gradient(160deg,#14100b,#0a0a0a);}
.fx-game::after{content:"";position:absolute;inset:0;z-index:-1;opacity:0;
  background:radial-gradient(80% 80% at 50% 120%,rgba(232,220,196,.12),transparent 60%);transition:opacity .4s var(--ease);}
.fx-game:hover{transform:translateY(-6px);border-color:rgba(232,220,196,.28);box-shadow:0 30px 70px -34px rgba(0,0,0,.9);}
.fx-game:hover::before{transform:scale(1.08);}
.fx-game:hover::after{opacity:1;}
.fx-game__icon{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);background:rgba(10,10,10,.4);color:var(--cream);margin-bottom:auto;}
.fx-game__icon svg{width:26px;height:26px;}
.fx-game__tag{font-family:var(--display);font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);margin:24px 0 8px;}
.fx-game.fraxtanoid .fx-game__tag{color:var(--amber-soft);}
.fx-game__name{font-family:var(--display);font-weight:700;font-size:1.7rem;color:var(--cream);margin:0 0 8px;letter-spacing:-.01em;}
.fx-game__desc{color:var(--cream-dim);font-size:.96rem;margin:0 0 18px;max-width:34ch;}
.fx-game__play{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.92rem;color:var(--cream);transition:gap .25s var(--ease);}
.fx-game__play svg{width:16px;height:16px;}
.fx-game:hover .fx-game__play{gap:13px;}
.fx-game__link{position:absolute;inset:0;z-index:3;}

/* ---------- Gallery teaser ---------- */
.fx-gallery-cta{position:relative;border:1px solid var(--line);border-radius:24px;overflow:hidden;padding:clamp(36px,5vw,60px);
  display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;
  background:linear-gradient(120deg,rgba(91,191,181,.06),rgba(10,10,10,0));}
.fx-gallery-cta h2{font-family:var(--display);font-weight:600;font-size:clamp(1.7rem,4vw,2.6rem);margin:0 0 10px;color:var(--cream);}
.fx-gallery-cta p{color:var(--cream-dim);margin:0;max-width:46ch;}

/* ============================================================
   FOOTER
   ============================================================ */
.fx-footer{position:relative;z-index:1;border-top:1px solid var(--line);padding:64px 0 40px;margin-top:40px;}
.fx-footer__grid{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;margin-bottom:44px;}
.fx-footer__brand{max-width:320px;}
.fx-footer__brand .fx-brand{margin-bottom:16px;}
.fx-footer__brand p{color:var(--cream-dim);font-size:.94rem;margin:0;}
.fx-footer__cols{display:flex;gap:64px;flex-wrap:wrap;}
.fx-footer__col h4{font-family:var(--display);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--amber-soft);margin:0 0 16px;}
.fx-footer__col a{display:block;color:var(--cream-dim);font-size:.92rem;padding:5px 0;transition:color .2s var(--ease);}
.fx-footer__col a:hover{color:var(--cream);}
.fx-socials{display:flex;gap:12px;margin-top:20px;}
.fx-socials a{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);color:var(--cream-dim);transition:transform .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease),box-shadow .3s var(--ease);}
.fx-socials a svg{width:20px;height:20px;}
.fx-socials a:hover{transform:translateY(-3px);color:var(--cream);border-color:rgba(212,165,116,.5);box-shadow:0 10px 26px -12px rgba(212,165,116,.6);}
.fx-footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  padding-top:24px;border-top:1px solid var(--line);color:var(--cream-dim);font-size:.84rem;}
.fx-footer__legal{display:flex;gap:20px;flex-wrap:wrap;}
.fx-footer__legal a:hover{color:var(--cream);}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
/* JS-on hides reveals (no-JS keeps them visible). GSAP drives them; the IO fallback uses .in */
.fx-js .fx-reveal{opacity:0;transform:translateY(40px);will-change:transform,opacity;}
.fx-js .fx-reveal.in{opacity:1;transform:none;transition:opacity .9s var(--ease),transform .9s var(--ease);}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .fx-releases{grid-template-columns:repeat(2,1fr);}
  .fx-games{grid-template-columns:1fr;}
  .fx-nav{position:fixed;inset:72px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(10,10,10,.96);backdrop-filter:blur(18px);border-bottom:1px solid var(--line);
    padding:12px 24px 22px;transform:translateY(-120%);opacity:0;pointer-events:none;transition:transform .35s var(--ease),opacity .3s var(--ease);}
  .fx-nav.open{transform:translateY(0);opacity:1;pointer-events:auto;}
  .fx-nav a{padding:14px 0;border-bottom:1px solid var(--line);}
  .fx-nav a::after{display:none;}
  .fx-nav__cta{margin-top:14px;justify-content:center;border-bottom:0!important;}
  .fx-burger{display:inline-flex;}
}
@media (max-width:560px){
  .fx-releases{grid-template-columns:1fr;}
  .fx-section{padding:72px 0;}
  .fx-footer__cols{gap:36px;}
  .fx-cta-row{flex-direction:column;align-items:stretch;}
  .fx-btn{justify-content:center;}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  .fx-landing *,.fx-landing *::before,.fx-landing *::after{
    animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;}
  .fx-blob,.fx-stars{animation:none!important;}
  .fx-reveal{opacity:1!important;transform:none!important;}
  .fx-scrollcue{animation:none!important;}
  .fx-hero__media video{display:none;}
}

/* ============================================================
   PARTICLE IMAGO + HERO CINEMATIC LAYERING
   ============================================================ */
.fx-hero__inner{position:relative;z-index:2;}
.fx-particles{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;display:block;}
.fx-hero__vignette{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(62% 58% at 50% 44%, transparent 34%, rgba(10,10,10,.5) 100%);}
/* the particle entity leads; the video/poster is a faint bed beneath it */
.fx-hero__media video,.fx-hero__media img{opacity:.34;}
/* hero copy never clipped by the pin */
.fx-hero{will-change:transform;}
/* headline lines animate as blocks (rise-in on load) */
.fx-hero h1 .fx-line{display:block;}

/* ============================================================
   SCROLLY CINEMATIC (clon arquitectura djfrankgarcia, estilo Fraxtal)
   ============================================================ */
.fx-scrolly{position:relative;height:520vh;z-index:1;}
.fx-sticky{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden;background:#080605;}
.fx-cine{position:absolute;inset:0;width:100%;height:100%;display:block;}
.fx-atmo{pointer-events:none;mix-blend-mode:screen;}
.fx-cine-vignette{position:absolute;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(122% 92% at 50% 40%, transparent 48%, rgba(8,5,6,.82) 100%);}

.fx-beat{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);text-align:center;padding:0 22px;
  opacity:0;pointer-events:none;will-change:opacity,transform;z-index:2;}
.fx-beat .fx-kick{display:inline-flex;align-items:center;gap:10px;font-family:var(--display);font-weight:500;
  font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cyan);margin-bottom:18px;}
.fx-beat .fx-kick .dot{width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);}
.fx-beat h1{font-family:var(--display);font-weight:700;letter-spacing:.06em;line-height:.94;
  font-size:clamp(3.6rem,14vw,9.5rem);margin:0;text-shadow:0 4px 60px rgba(0,0,0,.6);}
.fx-beat h2{font-family:var(--display);font-weight:700;letter-spacing:-.02em;line-height:1.0;
  font-size:clamp(2.1rem,7vw,5rem);margin:0;text-shadow:0 2px 40px rgba(0,0,0,.65);}

.fx-endpanel{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);padding:0 22px;opacity:0;z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;will-change:opacity,transform;}
.fx-endpanel::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:min(1060px,94vw);height:132%;z-index:-1;border-radius:40px;
  background:radial-gradient(ellipse at center, rgba(8,5,6,.84), rgba(8,5,6,.32) 55%, transparent 76%);}
.fx-end-sigil{font-size:2.4rem;line-height:1;color:var(--amber);filter:drop-shadow(0 0 20px rgba(212,165,116,.55));}
.fx-endpanel h2{font-family:var(--display);font-weight:700;font-size:clamp(2rem,5.5vw,3.6rem);margin:0;letter-spacing:-.01em;
  text-shadow:0 2px 34px rgba(0,0,0,.65);}
.fx-end-lead{color:var(--cream-dim);margin:0;max-width:48ch;}
.fx-modcards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;max-width:940px;width:100%;margin-top:6px;}
.fx-mod{display:flex;flex-direction:column;gap:6px;text-align:left;padding:18px 20px;border-radius:16px;
  background:rgba(15,10,8,.55);border:1px solid var(--line);backdrop-filter:blur(12px);
  transition:transform .2s var(--ease),background .2s var(--ease),border-color .2s var(--ease);}
.fx-mod:hover{transform:translateY(-3px);background:rgba(15,10,8,.74);border-color:rgba(212,165,116,.4);}
.fx-mod b{font-family:var(--display);font-weight:600;font-size:1.04rem;color:var(--cream);}
.fx-mod span{color:var(--cream-dim);font-size:.86rem;line-height:1.5;}
.fx-mod .fx-grad{font-weight:600;}
.fx-hint{position:absolute;left:50%;transform:translateX(-50%);bottom:24px;font-family:var(--display);
  font-size:.72rem;color:var(--cream-dim);letter-spacing:.24em;text-transform:uppercase;animation:fxFloat 2.4s ease-in-out infinite;z-index:2;}
@media(max-width:760px){.fx-modcards{grid-template-columns:1fr;}}
@media(prefers-reduced-motion:reduce){.fx-hint{animation:none;}}

/* ============================================================
   SUB-PAGES (letras, galería, juegos…) — Fraxtal 2026 shell
   ============================================================ */
.fx-subpage .fx-header{background:rgba(10,10,10,.72);backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);border-bottom-color:var(--line);}
.fx-page{position:relative;z-index:1;padding-top:104px;min-height:72vh;}
.fx-page-head{padding:36px 0 28px;max-width:760px;}
.fx-page-head h1{font-family:var(--display);font-weight:700;font-size:clamp(2.2rem,5.2vw,3.6rem);letter-spacing:-.02em;line-height:1.02;margin:0 0 12px;color:var(--cream);}
.fx-page-head .fx-grad{font-weight:700;}
.fx-page-head p{color:var(--cream-dim);margin:0;font-size:1.06rem;}
.fx-crumbs{display:flex;gap:9px;align-items:center;font-family:var(--display);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:18px;}
.fx-crumbs a{color:var(--amber-soft);}
.fx-crumbs a:hover{color:var(--cream);}
.fx-crumbs .sep{opacity:.5;}
