/* =====================================================================
   PlaysOut — site, built to the official XD design system
   Fonts: NewBlackTypeface (headings) + Red Hat Display (body) — bundled, real.
   Palette sampled from the official design (navy #111129, blue #3D3EFD,
   accent #495CF5, periwinkle #98A3FF, slate #404053).
   Narrative: entertainment-first (mini-games · live · short drama).
   ===================================================================== */

/* ---------------- Fonts ---------------- */
@font-face{
  font-family:"NewBlackTypeface";
  src:url("fonts/NewBlackTypeface-Bold.woff2") format("woff2");
  font-weight:700;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"NewBlackTypeface";
  src:url("fonts/NewBlackTypeface-ExtraBold.woff2") format("woff2");
  font-weight:800;font-style:normal;font-display:swap;
}
@font-face{font-family:"Red Hat Display";src:url("fonts/RedHatDisplay-Regular.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Red Hat Display";src:url("fonts/RedHatDisplay-Medium.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Red Hat Display";src:url("fonts/RedHatDisplay-SemiBold.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"Red Hat Display";src:url("fonts/RedHatDisplay-Bold.woff2") format("woff2");font-weight:700;font-display:swap}
@font-face{font-family:"Red Hat Display";src:url("fonts/RedHatDisplay-ExtraBold.woff2") format("woff2");font-weight:800;font-display:swap}

/* ---------------- Tokens ---------------- */
:root{
  --navy:        #111129;   /* sections, footer, hero base */
  --navy-2:      #0c0c1f;   /* darker bands / dark pills */
  --blue:        #3D3EFD;   /* hero gradient core */
  --blue-deep:   #2822DE;
  --accent:      #495CF5;   /* CTAs, accent card, subscribe */
  --periwinkle:  #98A3FF;   /* light panels */
  --slate:       #404053;   /* game cards, newsletter, dark cards */
  --slate-2:     #2c2c3d;   /* flat feature cards */
  --placeholder: #E6E6E9;   /* image placeholder grey */
  --ink:         #111129;   /* text on light surfaces */

  --white:       #FFFFFF;
  --text:        #ECECF2;
  --text-dim:    #9A9AB5;
  --text-mute:   #6E6E86;
  --line:        rgba(255,255,255,.10);

  /* entertainment accents (drama/live) */
  --pink:#FF4D9D; --lime:#B6FF3C; --cyan:#38E1FF; --gold:#FFC24B;

  --font:        "Red Hat Display", system-ui, -apple-system, "Segoe UI", sans-serif;
  --display:     "NewBlackTypeface", "Red Hat Display", system-ui, sans-serif;

  --maxw: 1280px;
  --pill: 999px;
  --r-card: 18px;
  --r-lg: 30px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------------- Reset ---------------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--navy);color:var(--text);line-height:1.55;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--accent);color:#fff}

/* ---------------- Layout ---------------- */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 40px}
.section{padding:44px 0}
.center{text-align:center}

h1,h2,h3{font-family:var(--display);font-weight:800;letter-spacing:-.01em;color:#fff;line-height:1.02}

.display{font-family:var(--display)}
.title{font-family:var(--display);font-weight:800;font-size:clamp(2rem,3.6vw,3.1rem);line-height:1.06;color:#fff}
.eyebrow{font-family:var(--font);font-weight:500;font-size:clamp(1.05rem,1.8vw,1.45rem);color:var(--text-dim)}
.lead{color:var(--text-dim);font-size:clamp(1rem,1.4vw,1.18rem);max-width:62ch}
.grad-accent{color:#fff}

/* ---------------- Buttons (pills) ---------------- */
.btn{display:inline-flex;align-items:center;gap:16px;padding:11px 12px 11px 28px;border-radius:var(--pill);
  font-family:var(--font);font-weight:600;font-size:.92rem;letter-spacing:.06em;text-transform:uppercase;
  transition:transform .25s var(--ease),box-shadow .25s,background .25s;white-space:nowrap}
.btn .arrow{width:42px;height:42px;border-radius:50%;flex:none;display:grid;place-items:center;font-size:1.05rem;
  background:#fff;color:var(--ink);transition:transform .25s var(--ease)}
.btn:hover{transform:translateY(-2px)}
.btn:hover .arrow{transform:translateX(3px)}
.btn--dark{background:var(--navy-2);color:#fff;box-shadow:0 10px 30px rgba(0,0,0,.35)}
.btn--blue{background:var(--accent);color:#fff;box-shadow:0 12px 34px rgba(73,92,245,.45)}
.btn--sm{padding:9px 10px 9px 22px;font-size:.82rem}
.btn--sm .arrow{width:34px;height:34px;font-size:.9rem}

/* ---------------- Nav ---------------- */
.nav{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:40px 56px;transition:background .3s,padding .3s,backdrop-filter .3s}
.nav.scrolled{background:rgba(12,12,28,.78);backdrop-filter:blur(16px);padding:18px 56px;border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center}
.brand-logo{height:38px;width:auto;display:block}
.nav.scrolled .brand-logo{height:32px;transition:height .3s}
.nav-links{display:flex;gap:38px;align-items:center}
.nav-links a{font-weight:500;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;color:#fff;opacity:.82;transition:opacity .2s}
.nav-links a:hover,.nav-links a.active{opacity:1}
.nav-links a.active{color:var(--periwinkle)}
.nav-cta{display:flex;gap:12px;align-items:center}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:8px}
.nav-burger span{width:24px;height:2px;background:#fff;border-radius:2px}

/* ---- Hub dropdown ---- */
.nav-drop{position:relative;display:inline-flex;align-items:center}
.nav-drop-trigger{display:inline-flex;align-items:center;gap:7px;cursor:pointer}
.nav-drop .caret{font-size:.65em;transition:transform .25s var(--ease);opacity:.8}
.nav-drop:hover .caret{transform:rotate(180deg)}
.nav-drop-menu{position:absolute;top:100%;left:50%;min-width:264px;margin-top:16px;padding:10px;
  background:var(--navy-2);border:1px solid var(--line);border-radius:18px;box-shadow:0 26px 60px rgba(0,0,0,.55);
  display:flex;flex-direction:column;z-index:120;
  opacity:0;visibility:hidden;transform:translate(-50%,8px);transition:opacity .22s var(--ease),transform .22s var(--ease)}
.nav-drop:hover .nav-drop-menu,.nav-drop:focus-within .nav-drop-menu{opacity:1;visibility:visible;transform:translate(-50%,0)}
.nav-drop-menu::before{content:"";position:absolute;top:-18px;left:0;right:0;height:18px} /* hover bridge */
.nav-drop-menu a{display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:12px 15px;border-radius:12px;text-transform:none;letter-spacing:normal;
  font-size:.95rem;font-weight:600;color:#fff;opacity:1;transition:background .2s}
.nav-drop-menu a:hover{background:rgba(255,255,255,.07)}
.nav-drop-menu a + a{border-top:1px solid rgba(255,255,255,.22);border-radius:0}
.nav-drop-menu .drop-arrow{width:30px;height:30px;flex:none;border-radius:50%;background:#fff;color:var(--ink);
  display:grid;place-items:center;font-size:.9rem}

@media(max-width:900px){
  .nav-drop{flex-direction:column;align-items:flex-start;width:100%}
  .nav-drop .caret{display:none}
  .nav-drop-menu{position:static;opacity:1;visibility:visible;transform:none;margin:8px 0 0;min-width:0;width:100%;
    background:none;border:none;box-shadow:none;padding:0 0 0 14px}
  .nav-drop-menu a{padding:10px 0;font-size:1rem}
  .nav-drop-menu a + a{border-top:none}
  .nav-drop-menu .drop-arrow{display:none}
}

/* ---------------- Hero ---------------- */
.hero{min-height:90vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:140px 24px 26px;position:relative;overflow:hidden;
  background:radial-gradient(100% 75% at 50% 8%, var(--blue) 0%, var(--blue-deep) 34%, #1a164f 55%, var(--navy) 82%)}
.hero-eyebrow{font-family:var(--display);font-weight:700;font-size:clamp(1.3rem,2.4vw,1.9rem);color:#eef0fb;opacity:.95;margin-bottom:.5rem;letter-spacing:-.01em;line-height:1}
.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(2.4rem,5.6vw,4.6rem);line-height:1;letter-spacing:-.02em;color:#fff;max-width:18ch}
.hero .sub{margin:30px auto 0;max-width:52ch;color:#dcdcf6;font-size:clamp(1rem,1.4vw,1.15rem)}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:42px}
.hero-formats{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:44px}
.fmt-chip{display:inline-flex;align-items:center;gap:9px;padding:9px 18px;border-radius:var(--pill);
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.20);font-weight:600;font-size:.9rem;backdrop-filter:blur(6px)}
.fmt-chip .dot{width:9px;height:9px;border-radius:50%}
.discover{margin-top:54px;display:flex;flex-direction:column;align-items:center;gap:14px;color:#cdcdf0;
  font-size:.74rem;letter-spacing:.22em;text-transform:uppercase}
.discover::before{content:"";width:1px;height:56px;background:linear-gradient(#ffffff00,#ffffffcc)}

/* ---------------- Section heads ---------------- */
.sec-head{max-width:760px;margin-bottom:52px}
.sec-head.center{margin-inline:auto}
.sec-head .eyebrow{margin-bottom:10px}
.sec-head.center .eyebrow{margin-inline:auto}

/* ---------------- Game card carousel ---------------- */
.marquee{overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee-track{display:flex;gap:16px;width:max-content;animation:scrollx 52s linear infinite}
.marquee-track.rev{animation-direction:reverse}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scrollx{to{transform:translateX(-50%)}}
.gcard{width:184px;flex:none;background:var(--slate);border-radius:16px;padding:12px;transition:transform .3s var(--ease),box-shadow .3s}
.gcard:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(0,0,0,.45)}
.gcard-art{aspect-ratio:1/1;border-radius:14px;background:var(--placeholder);display:grid;place-items:center;font-size:3.2rem;overflow:hidden;position:relative}
.gcard-art .badge{position:absolute;top:10px;left:10px;z-index:2;font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:5px 9px;border-radius:var(--pill);background:rgba(0,0,0,.5);color:#fff;backdrop-filter:blur(4px)}
.gcard-art .badge--drama{background:var(--pink);color:#fff}
.gcard-art img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.gcard-art .g-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.82);width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;z-index:3;color:#fff;font-size:1.05rem;background:rgba(0,0,0,.42);border:1px solid rgba(255,255,255,.55);
  backdrop-filter:blur(6px);opacity:0;transition:opacity .25s var(--ease),transform .25s var(--ease)}
.gcard:hover .g-play{opacity:1;transform:translate(-50%,-50%) scale(1)}
.gcard h4{text-align:center;margin-top:12px;font-family:var(--font);font-weight:700;font-size:.95rem;color:#fff;line-height:1.25}
.gcard span{display:block;text-align:center;margin-top:3px;color:var(--text-dim);font-size:.78rem}
.carousel-cta{display:flex;justify-content:center;margin-top:38px}

/* ---------------- Feature row ("Unlocking…") ---------------- */
.feature-row{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.fcard{border-radius:var(--r-card);background:var(--slate-2);border:1px solid var(--line);padding:26px 22px;min-height:172px;
  display:flex;align-items:flex-end;transition:transform .3s var(--ease),background .3s}
.fcard:hover{transform:translateY(-4px)}
.fcard h4{font-family:var(--font);font-weight:700;font-size:1.12rem;color:#fff}
.fcard--accent{background:var(--accent);border-color:transparent}
.fcard--accent .mini{color:#eaeaff;font-size:.92rem;font-weight:500}
.fcard .mini{color:var(--text-dim)}

/* Feature tiles with icon + accent glow (home "Unlocking…" section) */
.feature-row.tiles{gap:18px}
.feature-row.tiles .fcard{--ac:#98A3FF;--acsoft:rgba(152,163,255,.16);min-height:256px;
  flex-direction:column;align-items:center;justify-content:flex-start;gap:15px;text-align:center;
  padding:34px 22px 30px;cursor:default;position:relative;overflow:hidden;
  background:linear-gradient(170deg,rgba(255,255,255,.05),rgba(255,255,255,.012));
  border:1px solid rgba(255,255,255,.08);transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.feature-row.tiles .fcard:nth-child(1){--ac:#98A3FF;--acsoft:rgba(152,163,255,.16)}
.feature-row.tiles .fcard:nth-child(2){--ac:#38E1FF;--acsoft:rgba(56,225,255,.15)}
.feature-row.tiles .fcard:nth-child(3){--ac:#FF4D9D;--acsoft:rgba(255,77,157,.15)}
.feature-row.tiles .fcard:nth-child(4){--ac:#B6FF3C;--acsoft:rgba(182,255,60,.13)}
.feature-row.tiles .fcard:nth-child(5){--ac:#FFC24B;--acsoft:rgba(255,194,75,.15)}
.feature-row.tiles .fcard::before{content:"";position:absolute;top:-32%;left:50%;transform:translateX(-50%);
  width:150%;height:58%;background:radial-gradient(ellipse at center,var(--ac),transparent 70%);
  opacity:.13;pointer-events:none;transition:opacity .3s}
.feature-row.tiles .fcard:hover{transform:translateY(-6px);border-color:var(--ac);box-shadow:0 22px 52px -26px rgba(0,0,0,.72)}
.feature-row.tiles .fcard:hover::before{opacity:.28}
.tile-ico{width:50px;height:50px;border-radius:15px;display:grid;place-items:center;color:var(--ac);
  background:var(--acsoft);box-shadow:inset 0 0 0 1px var(--ac);transition:transform .3s var(--ease)}
.feature-row.tiles .fcard:hover .tile-ico{transform:translateY(-2px) scale(1.07)}
.tile-ico svg{width:24px;height:24px}
.feature-row.tiles .f-title{font-family:var(--font);font-weight:700;font-size:1.1rem;color:#fff;line-height:1.3;
  min-height:2.6em;display:flex;align-items:center;justify-content:center;text-align:center}
.feature-row.tiles .f-desc{font-family:var(--font);color:var(--text-dim);font-size:.9rem;line-height:1.46;max-width:24ch}

/* ---------------- News ---------------- */
.news-head{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:38px}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ncard{border-radius:var(--r-card);overflow:hidden;background:var(--slate-2);border:1px solid var(--line);
  transition:transform .3s var(--ease),border-color .3s}
.ncard:hover{transform:translateY(-5px);border-color:rgba(73,92,245,.5)}
.ncard-img{aspect-ratio:16/10;position:relative}
.ncard-body{padding:20px 22px}
.ncard-body .tag{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--periwinkle)}
.ncard-body h4{font-family:var(--font);font-weight:700;font-size:1.08rem;line-height:1.32;margin-top:8px;color:#fff}
.ncard-body p{color:var(--text-dim);font-size:.92rem;margin-top:8px}
.ncard-outlet{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:0 18px;
  font-family:var(--display);font-weight:800;font-size:1.45rem;color:#fff;opacity:.96;letter-spacing:.01em}
.ncard .read{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-weight:700;font-size:.86rem;color:var(--periwinkle)}
/* News rail (horizontal carousel w/ arrows) */
.news-rail{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:2px 2px 8px;-ms-overflow-style:none;scrollbar-width:none}
.news-rail::-webkit-scrollbar{display:none}
.news-rail .ncard{flex:0 0 350px;scroll-snap-align:start}
.rail-nav{display:flex;align-items:center;gap:10px}
.rail-btn{width:44px;height:44px;flex:none;border-radius:50%;border:1px solid var(--line);background:var(--slate-2);
  color:#fff;font-size:1.3rem;line-height:1;display:grid;place-items:center;cursor:pointer;transition:background .2s,border-color .2s,transform .2s}
.rail-btn:hover{background:var(--slate);border-color:var(--periwinkle);transform:translateY(-2px)}
@media(max-width:560px){.news-rail .ncard{flex:0 0 82%}}
/* Real article preview image (og:image), with graceful fallback to branded cover */
.ncard-img{position:relative;overflow:hidden}
.ncard-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2;display:block;background:var(--slate-2)}
/* Featured-in logo marquee */
.logo-marquee{overflow:hidden;margin-top:36px;
  -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.logo-track{display:flex;align-items:center;gap:72px;width:max-content;animation:logoscroll 50s linear infinite}
.logo-marquee:hover .logo-track{animation-play-state:paused}
.logo-track.rev{animation-direction:reverse}
@keyframes logoscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logo-chip{flex:none;display:inline-flex;align-items:center;justify-content:center;height:40px}
.logo-chip img{height:40px;width:auto;max-width:190px;object-fit:contain;opacity:.82;transition:opacity .2s}
.logo-chip:hover img{opacity:1}
.logo-text{font-family:var(--display);font-weight:800;font-size:1.45rem;line-height:1;color:#fff;opacity:.8;white-space:nowrap}
/* Audience duo cards (For Creators / For Super Apps) */
.duo{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.duo-card{--ac:#98A3FF;--acsoft:rgba(152,163,255,.20);--acline:rgba(152,163,255,.55);
  position:relative;overflow:hidden;border-radius:26px;padding:46px 42px;display:flex;flex-direction:column;
  background:linear-gradient(165deg,rgba(255,255,255,.055),rgba(255,255,255,.012));
  border:1px solid rgba(255,255,255,.09);transition:transform .3s ease,border-color .3s,box-shadow .3s}
.duo-card.alt{--ac:#38E1FF;--acsoft:rgba(56,225,255,.18);--acline:rgba(56,225,255,.5)}
.duo-card.adv{--ac:#FF4D9D;--acsoft:rgba(255,77,157,.18);--acline:rgba(255,77,157,.5)}
.duo-card::before{content:"";position:absolute;top:-45%;right:-25%;width:65%;height:85%;
  background:radial-gradient(circle,var(--ac),transparent 68%);opacity:.16;pointer-events:none;transition:opacity .3s}
.duo-card:hover{transform:translateY(-6px);border-color:var(--acline);box-shadow:0 26px 64px -28px rgba(0,0,0,.75)}
.duo-card:hover::before{opacity:.3}
.duo-ico{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;color:#0c0c1f;
  background:linear-gradient(145deg,var(--ac),#ffffff);box-shadow:0 10px 26px -10px var(--ac)}
.duo-ico svg{width:28px;height:28px}
.duo-eyebrow{margin:24px 0 7px;font-size:.74rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--ac)}
.duo-card h3{font-family:var(--display);font-weight:800;font-size:2rem;line-height:1.04;color:#fff;margin:0}
.duo-list{list-style:none;margin:24px 0 32px;padding:0;display:flex;flex-direction:column;gap:15px}
.duo-list li{position:relative;padding-left:32px;color:rgba(255,255,255,.82);font-size:1.04rem;line-height:1.45}
.duo-list li::before{content:"";position:absolute;left:0;top:.12em;width:20px;height:20px;border-radius:50%;background:var(--acsoft)}
.duo-list li::after{content:"";position:absolute;left:7px;top:.39em;width:6px;height:6px;border-radius:50%;background:var(--ac)}
.duo-cta{margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:10px;
  font-weight:700;font-size:.98rem;color:#0c0c1f;background:var(--ac);padding:14px 24px;border-radius:100px;
  transition:gap .2s,filter .2s,transform .2s}
.duo-cta:hover{gap:15px;filter:brightness(1.07)}
@media(max-width:1024px){.duo{grid-template-columns:1fr}.duo-card{padding:38px 32px}}
/* Gameplay reels (vertical autoplay footage tiles) */
.reels{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:34px}
.reel{position:relative;aspect-ratio:9/16;border-radius:18px;overflow:hidden;background:var(--slate-2);
  border:1px solid rgba(255,255,255,.08);transition:transform .3s var(--ease),box-shadow .3s,border-color .3s}
.reel:hover{transform:translateY(-6px);border-color:rgba(73,92,245,.5);box-shadow:0 24px 54px -24px rgba(0,0,0,.72)}
.reel video,.reel .reel-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.reel-badge{position:absolute;top:11px;left:11px;z-index:3;display:inline-flex;align-items:center;gap:5px;
  font-size:.6rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:5px 9px;border-radius:var(--pill);
  background:rgba(0,0,0,.5);color:#fff;backdrop-filter:blur(4px)}
.reel-cap{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:30px 14px 13px;font-weight:700;font-size:.9rem;
  color:#fff;line-height:1.2;background:linear-gradient(to top,rgba(0,0,0,.72),transparent)}
@media(max-width:860px){.reels{grid-template-columns:repeat(2,1fr);gap:14px}}
/* IP-featured game cards */
.ip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:8px}
.ipcard{border-radius:22px;overflow:hidden;background:linear-gradient(170deg,rgba(255,255,255,.05),rgba(255,255,255,.012));
  border:1px solid rgba(255,255,255,.09);transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.ipcard:hover{transform:translateY(-6px);border-color:rgba(255,194,75,.55);box-shadow:0 24px 56px -26px rgba(0,0,0,.72)}
.ipcard-img{aspect-ratio:16/10;background:var(--slate-2);position:relative;overflow:hidden}
.ipcard-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ipcard-img--logo img{object-fit:contain;padding:30px}
.ipcard-body{padding:24px 24px 28px}
.ipcard-body h3{font-family:var(--display);font-weight:800;font-size:1.4rem;color:#fff;margin-bottom:8px}
.ipcard-body p{color:var(--text-dim);font-size:.96rem;line-height:1.5}
@media(max-width:860px){.ip-grid{grid-template-columns:1fr}}
/* Final CTA — dark glass with glow (replaces flat panel) */
.cta-final{position:relative;text-align:center;padding:64px 32px;border-radius:28px;overflow:hidden;
  background:linear-gradient(170deg,rgba(255,255,255,.05),rgba(255,255,255,.012));border:1px solid rgba(255,255,255,.09)}
.cta-final::before{content:"";position:absolute;left:50%;top:-10%;transform:translateX(-50%);z-index:0;pointer-events:none;
  width:min(700px,92%);height:260px;background:radial-gradient(ellipse at center,rgba(73,92,245,.38),transparent 70%);filter:blur(22px)}
.cta-final>*{position:relative;z-index:1}
@media(max-width:600px){.cta-final{padding:48px 22px}}
/* App store buttons */
.store-btns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.store-btn{display:inline-flex;align-items:center;gap:12px;padding:9px 9px 9px 18px;border-radius:100px;
  background:var(--accent);color:#fff;transition:transform .2s var(--ease),filter .2s}
.store-btn:hover{transform:translateY(-2px);filter:brightness(1.08)}
.store-ico{width:25px;height:25px;flex:none}
.store-txt{display:flex;flex-direction:column;line-height:1.04;text-align:left}
.store-txt small{font-size:.64rem;opacity:.88;font-weight:500;letter-spacing:.01em}
.store-txt strong{font-size:1.04rem;font-weight:700}
.store-arrow{width:34px;height:34px;flex:none;border-radius:50%;background:#fff;color:#111;display:grid;place-items:center;font-weight:700;margin-left:4px}
/* ===== Hub community page ===== */
.events{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ev-card{position:relative;border-radius:20px;padding:26px;display:flex;flex-direction:column;gap:12px;
  background:linear-gradient(170deg,rgba(255,255,255,.05),rgba(255,255,255,.012));border:1px solid rgba(255,255,255,.09);
  transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.ev-card:hover{transform:translateY(-5px);border-color:rgba(73,92,245,.5);box-shadow:0 22px 50px -26px rgba(0,0,0,.7)}
.ev-badge{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;font-size:.62rem;font-weight:800;
  letter-spacing:.1em;text-transform:uppercase;padding:5px 11px;border-radius:100px}
.ev-badge.live{background:var(--lime);color:#0a0a1c}
.ev-badge.soon{background:rgba(152,163,255,.16);color:var(--periwinkle)}
.ev-card h3{font-family:var(--display);font-weight:800;font-size:1.3rem;color:#fff;line-height:1.15}
.ev-meta{display:flex;gap:18px;flex-wrap:wrap;color:var(--text-dim);font-size:.86rem}
.ev-meta b{color:#fff;font-weight:700}
.ev-card .btn{margin-top:auto;align-self:flex-start}
/* partnership teasers */
.partner-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.pcard{border-radius:18px;overflow:hidden;background:var(--slate-2);border:1px solid rgba(255,255,255,.08);transition:transform .3s var(--ease),border-color .3s}
.pcard:hover{transform:translateY(-5px);border-color:rgba(255,194,75,.5)}
.pcard-img{aspect-ratio:16/10;position:relative;overflow:hidden;background:linear-gradient(150deg,var(--slate),var(--slate-2));display:grid;place-items:center}
.pcard-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pcard-img .soon-txt{font-family:var(--display);font-weight:800;color:var(--periwinkle);font-size:1.1rem;opacity:.85}
.pcard-b{padding:15px 18px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.pcard-b h4{font-size:1rem;font-weight:700;color:#fff}
.pcard-b span{font-size:.6rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);white-space:nowrap}
.pcard-b span.soon{color:var(--periwinkle)}
@media(max-width:860px){.events{grid-template-columns:1fr}.partner-cards{grid-template-columns:repeat(2,1fr)}}
/* community band */
.community{text-align:center;padding:56px 32px;border-radius:26px;position:relative;overflow:hidden;
  background:linear-gradient(170deg,rgba(255,255,255,.05),rgba(255,255,255,.012));border:1px solid rgba(255,255,255,.09)}
.community::before{content:"";position:absolute;left:50%;top:-10%;transform:translateX(-50%);z-index:0;pointer-events:none;
  width:min(640px,90%);height:240px;background:radial-gradient(ellipse at center,rgba(73,92,245,.34),transparent 70%);filter:blur(22px)}
.community>*{position:relative;z-index:1}
.socials-row{display:flex;gap:14px;justify-content:center;margin-top:28px;flex-wrap:wrap}
.soc-btn{display:inline-flex;align-items:center;gap:9px;padding:13px 24px;border-radius:100px;background:var(--slate);
  border:1px solid var(--line);color:#fff;font-weight:700;font-size:.96rem;transition:transform .2s,border-color .2s,background .2s}
.soc-btn:hover{transform:translateY(-2px);border-color:var(--periwinkle);background:var(--slate-2)}
/* Statement headline glow-up */
.statement-wrap{position:relative;max-width:1000px;margin:0 auto;text-align:center;z-index:0}
.statement-wrap::before{content:"";position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);
  width:min(620px,86%);height:300px;z-index:-1;pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(73,92,245,.30),transparent 70%);filter:blur(22px)}
.pill-eyebrow{display:inline-flex;align-items:center;gap:9px;padding:8px 17px;border-radius:100px;margin-bottom:24px;
  border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);backdrop-filter:blur(6px);
  font-size:.82rem;font-weight:600;letter-spacing:.01em;color:var(--periwinkle)}
.pill-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#98A3FF,#38E1FF);
  box-shadow:0 0 10px rgba(56,225,255,.85);animation:pulse-dot 2.4s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.8)}}
.grad-text{background:linear-gradient(100deg,#98A3FF 0%,#7B8CFF 24%,#38E1FF 55%,#FF4D9D 92%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
  background-size:220% auto;animation:gradslide 7s linear infinite}
@keyframes gradslide{to{background-position:220% center}}

/* ---------------- Statement + periwinkle panels ---------------- */
.statement{text-align:center;max-width:18ch;margin:0 auto}
.panels{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:60px}
.panel{background:var(--periwinkle);border-radius:var(--r-lg);padding:48px 46px;color:var(--ink);position:relative;
  display:flex;flex-direction:column;min-height:440px}
.panel h3{font-family:var(--display);font-weight:800;font-size:clamp(1.8rem,3vw,2.5rem);color:var(--ink);margin-bottom:24px}
.panel ul{list-style:none;display:flex;flex-direction:column;gap:20px;margin-bottom:auto}
.panel li{font-weight:600;font-size:1.12rem;color:#1c1c33;line-height:1.4}
.panel .btn{margin-top:34px;align-self:flex-start}

/* ---------------- Partners ---------------- */
.partners{display:flex;flex-wrap:wrap;gap:44px 60px;align-items:center;justify-content:center;margin-top:50px;opacity:.85}
.partners span{font-weight:800;font-size:1.25rem;letter-spacing:.02em;color:#cfcfe0}

/* ---------------- Vertical cards (drama / live) ---------------- */
.vgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.vcard{position:relative;aspect-ratio:9/15;border-radius:18px;overflow:hidden;background:#17172e;border:1px solid var(--line);
  transition:transform .3s var(--ease),box-shadow .3s}
.vcard:hover{transform:translateY(-6px) scale(1.015);box-shadow:0 24px 60px rgba(0,0,0,.5)}
.vcard .v-grad{position:absolute;inset:0}
.vcard .v-meta{position:absolute;inset:auto 0 0 0;padding:18px;background:linear-gradient(transparent,rgba(0,0,0,.85));z-index:2}
.vcard .v-meta .tag{font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--pink)}
.vcard .v-meta h4{font-family:var(--font);font-weight:700;font-size:1.04rem;margin-top:4px}
.vcard .v-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;width:56px;height:56px;border-radius:50%;
  display:grid;place-items:center;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.4);backdrop-filter:blur(8px);opacity:0;transition:opacity .3s}
.vcard:hover .v-play{opacity:1}
.vcard .v-live{position:absolute;top:14px;left:14px;z-index:3;display:flex;align-items:center;gap:6px;font-size:.68rem;font-weight:800;
  letter-spacing:.08em;padding:5px 10px;border-radius:var(--pill);background:var(--pink);color:#fff}
.vcard .v-live .pulse{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1.3s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ---------------- Stats / steps ---------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.stat .num{font-family:var(--display);font-weight:800;font-size:clamp(2.2rem,4vw,3.2rem);color:#fff}
.stat .lbl{color:var(--text-dim);font-size:.94rem;margin-top:4px}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step}
.step{padding:32px;border-radius:var(--r-card);background:var(--slate-2);border:1px solid var(--line)}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--display);font-weight:800;font-size:2.3rem;color:var(--periwinkle);display:block;margin-bottom:10px}
.step h3{font-family:var(--font);font-weight:700;font-size:1.2rem;color:#fff;margin-bottom:8px}
.step p{color:var(--text-dim);font-size:.96rem}

/* ---------------- Hub search/filter ---------------- */
.hub-bar{display:flex;justify-content:center;margin-bottom:18px}
.search{display:flex;align-items:center;gap:10px;padding:14px 24px;border-radius:var(--pill);background:var(--slate);min-width:340px}
.search input{background:none;border:none;outline:none;color:#fff;font-family:inherit;font-size:.98rem;flex:1}
.search input::placeholder{color:var(--text-dim)}
.chips{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:46px}
.chip{padding:10px 20px;border-radius:var(--pill);background:var(--slate-2);border:1px solid var(--line);font-weight:600;font-size:.9rem;color:var(--text-dim);cursor:pointer;transition:.2s}
.chip:hover{color:#fff}
.chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.grid-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.grid-cards .gcard{width:auto}

/* ---------------- Page hero (interior) ---------------- */
.page-hero{padding:170px 0 84px;text-align:center;position:relative;overflow:hidden;
  background:radial-gradient(110% 80% at 50% -10%, var(--blue) 0%, var(--blue-deep) 36%, var(--navy) 78%)}
.page-hero h1{font-family:var(--display);font-weight:800;font-size:clamp(2.6rem,6vw,5rem);color:#fff;line-height:1}
.page-hero p{margin:22px auto 0;max-width:58ch;color:#dcdcf6;font-size:1.12rem}

/* ---------------- Newsletter ---------------- */
.newsletter{background:var(--slate);border-radius:var(--r-lg);padding:clamp(36px,5vw,58px)}
.newsletter .email{display:block;width:100%;background:none;border:none;outline:none;color:#fff;font-family:var(--display);font-weight:700;
  font-size:clamp(1.8rem,4vw,2.8rem);padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.5)}
.newsletter .email::placeholder{color:#b9b9c8}
.newsletter-row{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:26px;flex-wrap:wrap}
.newsletter-row p{color:#cfcfdd;font-size:1.05rem;line-height:1.4}

/* ---------------- Footer ---------------- */
.footer{background:var(--navy);padding:70px 0 44px;border-top:1px solid var(--line)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:54px}
.footer-icon{height:78px;width:auto}
.footer h5{font-family:var(--display);font-weight:800;font-size:1.15rem;letter-spacing:.02em;text-transform:uppercase;color:#fff;margin-bottom:22px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:16px}
.footer li a{color:var(--text-dim);font-size:.95rem;letter-spacing:.06em;text-transform:uppercase;transition:color .2s}
.footer li a:hover{color:#fff}
.footer-bottom{display:flex;align-items:center;gap:40px;flex-wrap:wrap;padding-top:34px;border-top:1px solid var(--line);color:var(--text-dim);font-size:.9rem}
.footer-bottom .spacer{flex:1}
.socials{display:flex;gap:16px}
.socials a{width:30px;height:30px;display:grid;place-items:center;color:#fff;opacity:.85;transition:opacity .2s}
.socials a:hover{opacity:1}

/* ---------------- Reveal ---------------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s 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}

/* ---------------- Responsive ---------------- */
@media(max-width:1080px){
  .feature-row{grid-template-columns:repeat(2,1fr)}
  .vgrid{grid-template-columns:repeat(2,1fr)}
  .grid-cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .nav-links{display:none}
  .nav-burger{display:flex}
  .nav.open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:rgba(12,12,28,.97);padding:24px 40px;gap:18px;border-bottom:1px solid var(--line)}
  .news-grid{grid-template-columns:1fr}
  .panels{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr);gap:30px}
  .steps{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:560px){
  .wrap{padding:0 22px}
  .nav{padding:16px 22px}
  .nav-cta .btn{display:none}
  .feature-row,.grid-cards,.vgrid{grid-template-columns:1fr 1fr;gap:12px}
  .hero-cta{flex-direction:column;width:100%}
  .hero-cta .btn{justify-content:center;width:100%}
  .footer-top{grid-template-columns:1fr}
  .newsletter-row{flex-direction:column;align-items:flex-start}
}
