/* ============================================================
   RTP PARTNERS — premium iGaming affiliate landing
   Design system + sections. Mobile-first.
   ============================================================ */

/* ---------- Design tokens ---------- */
:root{
  /* color */
  --ink:        #070811;
  --ink-2:      #0a0c15;
  --surface:    #11141e;
  --surface-2:  #161a26;
  --line:       rgba(255,255,255,.07);
  --line-2:     rgba(255,255,255,.13);
  --text:       #ffffff;
  --text-dim:   #a3a7b6;
  --text-mute:  #6a6e80;
  --accent:        #5246ff;
  --accent-bright: #9b8cff;
  --accent-deep:   #1c0c65;
  --accent-2:      #834dff;
  --grad:  linear-gradient(135deg, #5246ff 0%, #834dff 50%, #1c0c65 100%);
  --grad-soft: linear-gradient(135deg, #5246ff 0%, #834dff 100%);
  --on-accent: #ffffff;

  /* type */
  --display: "Clash Display", "Inter", system-ui, -apple-system, sans-serif;
  --sans:    "Satoshi", "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  --fs-hero: clamp(2.9rem, 8.5vw, 7.2rem);
  --fs-h2:   clamp(1.85rem, 3.4vw, 2.8rem);
  --fs-h3:   clamp(1.2rem, 2.4vw, 1.7rem);
  --fs-lg:   clamp(1.02rem, 1.4vw, 1.22rem);
  --fs-sm:   .8125rem;

  /* layout */
  --maxw: 1280px;
  --pad:  clamp(1.25rem, 5vw, 4rem);
  --section-y: clamp(5rem, 12vh, 11rem);
  --head-gap: clamp(2.2rem, 4vw, 3.4rem);
  --radius: 18px;
  --radius-lg: 28px;

  /* motion */
  --ease: cubic-bezier(.22,.65,.25,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ -webkit-text-size-adjust:100%; }
html, body{ overflow-x:clip; }
body{
  font-family:var(--sans);
  font-size:1.0625rem;
  line-height:1.65;
  color:var(--text);
  background:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  position:relative;
}
img,svg{ display:block; max-width:100%; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; padding:0; }
input,select,button,textarea{ font:inherit; }
::selection{ background:var(--accent); color:#ffffff; }

/* ---------- Typography helpers ---------- */
.display{
  font-family:var(--display);
  font-weight:600;
  line-height:1.04;
  letter-spacing:-.025em;
}
.display em{ font-style:normal; color:var(--accent-bright); }

.eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-size:.72rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--text-dim);
}
.eyebrow__dot{ width:6px; height:6px; border-radius:50%; background:var(--grad); box-shadow:0 0 14px 1px rgba(82,70,255,.6); }
.eyebrow--center{ justify-content:center; }

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:var(--section-y); position:relative; }
.section--tight{ padding-block:clamp(3.5rem,8vh,7rem); }

.section-head{ max-width:42rem; margin-bottom:var(--head-gap); }
.section-head--center{ max-width:none; margin-bottom:var(--head-gap); }
.section-head--row{ display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; max-width:none; flex-wrap:wrap; margin-bottom:var(--head-gap); }
.section-head--split{ max-width:none; margin-bottom:var(--head-gap); }
.section-head--full{ max-width:none; margin-bottom:var(--head-gap); }
.section-title{ font-size:var(--fs-h2); margin-top:1rem; }
.section-sub{ color:var(--text-dim); font-size:var(--fs-lg); margin-top:1.4rem; max-width:38rem; }

.link-arrow{ display:inline-flex; align-items:center; gap:.5rem; font-weight:500; color:var(--text-dim); transition:color .3s, gap .3s; }
.link-arrow span{ transition:transform .35s var(--ease); }
.link-arrow:hover{ color:var(--text); gap:.8rem; }
.link-arrow:hover span{ transform:translateX(4px); color:var(--accent); }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--surface-2);
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding:.8rem 1.4rem; border-radius:999px;
  font-weight:500; font-size:.95rem; letter-spacing:.01em;
  border:1px solid var(--line-2);
  transition:transform .35s var(--ease), background .35s, color .35s, border-color .35s, box-shadow .45s;
  will-change:transform;
}
.btn svg{ transition:transform .35s var(--ease); }
.btn--lg{ padding:1.05rem 1.9rem; font-size:1.02rem; }
.btn--block{ width:100%; }
.btn--primary{
  background:var(--grad); color:#ffffff; border-color:transparent;
  box-shadow:0 10px 30px -12px rgba(82,70,255,.5);
}
.btn--primary:hover{ transform:translateY(-2px); box-shadow:0 18px 44px -14px rgba(82,70,255,.7); }
.btn--primary:hover svg{ transform:translateX(4px); }
.btn--ghost{ background:rgba(255,255,255,.02); color:var(--text); }
.btn--ghost:hover{ background:rgba(255,255,255,.06); border-color:var(--line-2); transform:translateY(-2px); }

/* ---------- Grain + progress ---------- */
.grain{
  position:fixed; inset:0; z-index:9000; pointer-events:none; opacity:.1;
  /* dropped mix-blend-mode:overlay + own GPU layer: the blend forced a
     full-viewport re-composite every scroll frame (heavy on Retina). */
  transform:translateZ(0);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.78' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='1 0 0 0 0 0 0.95 0 0 0 0 0 0.86 0 0 0 0 0 1 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.scroll-progress{ position:fixed; top:0; left:0; right:0; height:2px; z-index:9001; background:transparent; }
.scroll-progress span{ display:block; height:100%; width:0%; background:var(--grad); box-shadow:0 0 12px rgba(82,70,255,.7); }

/* ============================================================
   NAV
   ============================================================ */
.nav{ position:fixed; inset:0 0 auto 0; z-index:100; transition:background .4s, border-color .4s, backdrop-filter .4s; border-bottom:1px solid transparent; }
.nav.is-scrolled{ background:rgba(8,8,11,.72); backdrop-filter:blur(14px); border-bottom-color:var(--line); }
.nav__inner{ max-width:var(--maxw); margin-inline:auto; padding:1rem var(--pad); display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }

.brand{ display:inline-flex; align-items:center; color:var(--text); transition:opacity .3s; }
.brand:hover{ opacity:.88; }
.brand__word{ display:inline-flex; align-items:baseline; gap:.6rem; font-family:var(--display); line-height:1; }
.brand__primary{ font-weight:600; font-size:1.18rem; letter-spacing:-.01em; color:#fff;
  text-shadow:0 0 22px rgba(155,140,255,.22); }
.brand__sep{ display:inline-block; width:1px; height:.95em; align-self:center;
  background:linear-gradient(180deg, transparent 0%, rgba(255,255,255,.32) 30%, rgba(255,255,255,.32) 70%, transparent 100%); }
.brand__sub{ font-weight:400; font-size:.7rem; letter-spacing:.32em; text-transform:uppercase;
  color:rgba(255,255,255,.5); padding-bottom:.04em; }
.brand--lg .brand__primary{ font-size:1.5rem; }
.brand--lg .brand__sub{ font-size:.78rem; }
/* full brand logo graphic (assets/logo.svg) — kept at the original lockup footprint */
.brand__logo{ display:block; width:146px; height:auto; }
.brand--lg .brand__logo{ width:188px; }

.nav__links{ display:none; gap:2rem; align-items:center; }
.nav__links a{ font-size:.95rem; color:var(--text-dim); position:relative; transition:color .3s; }
.nav__links > a::after{ content:""; position:absolute; left:0; bottom:-4px; width:0; height:1px; background:var(--accent); transition:width .35s var(--ease); }
.nav__links a:hover{ color:var(--text); }
.nav__links > a:hover::after{ width:100%; }
.nav__links > a.is-active{ color:#fff; }
.nav__links > a.is-active::after{ width:100%; }

/* Nav dropdown (Brand sub-menu) */
.nav__item--has-sub{ position:relative; }
.nav__sub-toggle{ display:inline-flex; align-items:center; gap:.3rem; padding:0;
  background:transparent; border:none; cursor:pointer;
  font-family:inherit; font-size:.95rem; color:var(--text-dim);
  transition:color .3s; }
.nav__sub-toggle:hover{ color:var(--text); }
.nav__sub-toggle.is-active{ color:#fff; }
.nav__sub-toggle svg{ transition:transform .25s var(--ease); }
.nav__sub-toggle[aria-expanded="true"] svg{ transform:rotate(180deg); }
.nav__sub{ position:absolute; top:calc(100% + .9rem); left:-.6rem; min-width:11rem;
  background:var(--surface-2); border:1px solid var(--line-2); border-radius:14px;
  padding:.55rem; display:flex; flex-direction:column; gap:.15rem;
  box-shadow:0 22px 50px -22px rgba(0,0,0,.7), 0 4px 12px rgba(0,0,0,.25);
  opacity:0; transform:translateY(-6px) scale(.97); pointer-events:none;
  transition:opacity .25s var(--ease), transform .25s var(--ease);
  z-index:80; }
.nav__sub-toggle[aria-expanded="true"] + .nav__sub{
  opacity:1; transform:none; pointer-events:auto; }
/* desktop hover-to-open */
@media (hover: hover) and (min-width: 768px){
  .nav__item--has-sub:hover .nav__sub{ opacity:1; transform:none; pointer-events:auto; }
  .nav__item--has-sub:hover .nav__sub-toggle svg{ transform:rotate(180deg); }
}
.nav__sub a{ display:block; padding:.65rem .85rem; border-radius:9px;
  font-size:.92rem; color:var(--text-dim);
  transition:background .25s, color .25s; }
.nav__sub a::after{ display:none; }
.nav__sub a:hover{ background:rgba(82,70,255,.12); color:#fff; }
.nav__sub a.is-active{ color:#fff; background:rgba(82,70,255,.18); }
.nav__cta{ display:none; }

.nav__buttons{ display:none; align-items:center; gap:.6rem; }
.nav__login{ padding:.68rem 1.2rem; font-size:.92rem; }
.nav__cta{ padding:.68rem 1.4rem; font-size:.92rem; }
@media (min-width:768px){ .nav__buttons{ display:inline-flex; } }
.nav__burger{ display:inline-flex; flex-direction:column; gap:5px; padding:.6rem; }
.nav__burger span{ width:24px; height:1.5px; background:var(--text); transition:transform .35s var(--ease), opacity .3s; }
.nav.is-open .nav__burger span:first-child{ transform:translateY(6.5px) rotate(45deg); }
.nav.is-open .nav__burger span:last-child{ transform:translateY(-6.5px) rotate(-45deg); }

/* Mobile menu */
.nav__links.is-mobile-open .nav__item--has-sub{ width:100%; }
.nav__links.is-mobile-open .nav__sub-toggle{ width:100%; justify-content:space-between;
  padding:1rem 0; font-size:1.3rem; font-family:var(--display); color:var(--text);
  border-bottom:1px solid var(--line); }
.nav__links.is-mobile-open .nav__sub{ position:static; background:transparent;
  border:none; padding:0; box-shadow:none; gap:0;
  max-height:0; overflow:hidden;
  opacity:0; transform:none; pointer-events:none;
  transition:max-height .35s var(--ease), opacity .25s; }
.nav__links.is-mobile-open .nav__sub-toggle[aria-expanded="true"]{ border-bottom-color:transparent; }
.nav__links.is-mobile-open .nav__sub-toggle[aria-expanded="true"] + .nav__sub{
  max-height:20rem; opacity:1; pointer-events:auto; padding:.3rem 0 .8rem 1rem;
  border-bottom:1px solid var(--line); }
.nav__links.is-mobile-open .nav__sub a{ font-size:1.1rem; padding:.7rem 0;
  color:var(--text-dim); border-radius:0; }
.nav__links.is-mobile-open .nav__sub a:hover,
.nav__links.is-mobile-open .nav__sub a.is-active{ color:#fff; background:transparent; }

.nav__links.is-mobile-open{
  display:flex; flex-direction:column; gap:0; align-items:stretch;
  position:fixed; inset:64px 0 auto 0; background:rgba(8,8,11,.96); backdrop-filter:blur(16px);
  padding:1rem var(--pad) 2rem; border-bottom:1px solid var(--line);
}
.nav__links.is-mobile-open a{ padding:1rem 0; font-size:1.3rem; font-family:var(--display); color:var(--text); border-bottom:1px solid var(--line); text-align:left; width:100%; }

/* ============================================================
   1. HERO
   ============================================================ */
.hero{ position:relative; min-height:84svh; display:flex; align-items:center; overflow:hidden; }
.hero__canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; }
/* CSS fallback gradient (sits under canvas; shows if WebGL fails) */
.hero::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(60% 50% at 80% 14%, rgba(82,70,255,.20), transparent 68%),
    radial-gradient(66% 60% at 10% 92%, rgba(131,77,255,.14), transparent 70%),
    radial-gradient(120% 85% at 50% 128%, rgba(28,12,101,.55), transparent 72%),
    var(--ink);
}
.hero__veil{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(8,8,11,.55) 0%, rgba(8,8,11,.15) 35%, rgba(8,8,11,.55) 78%, var(--ink) 100%);
}
.hero__inner{ position:relative; z-index:2; width:100%; max-width:var(--maxw); margin-inline:auto; padding:7rem var(--pad) 5rem; }

.hero__eyebrow{ opacity:0; animation:fadeUp .9s var(--ease-out) .15s forwards; }
.hero__title{ font-size:var(--fs-hero); margin:1.4rem 0 1.8rem; max-width:16ch; }
.hero__title .line{ display:block; overflow:hidden; padding-bottom:.04em; }
.hero__title .line > span{ display:block; transform:translateY(110%); }
.hero__lede{ max-width:40rem; font-size:var(--fs-lg); color:var(--text-dim); opacity:0; animation:fadeUp .9s var(--ease-out) .75s forwards; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:3rem; opacity:0; animation:fadeUp .9s var(--ease-out) .9s forwards; }

.hero__stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem 2rem; margin-top:3.5rem; padding-top:2.2rem; border-top:1px solid var(--line); }
.stat__num{ display:block; font-family:var(--display); font-size:clamp(1.7rem,4vw,2.6rem); line-height:1; letter-spacing:-.02em; }
.stat__label{ display:block; margin-top:.5rem; font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-mute); }

.hero__scroll{ position:absolute; left:var(--pad); bottom:2rem; z-index:2; display:none; align-items:center; gap:.9rem;
  font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--text-mute); }
.hero__scroll-line{ width:46px; height:1px; background:var(--line-2); position:relative; overflow:hidden; }
.hero__scroll-line::after{ content:""; position:absolute; inset:0; width:40%; background:var(--accent); animation:scrollLine 2.2s var(--ease) infinite; }

/* hero brand graphic — orbital system, transparent (no panel) */
.hero__content{ min-width:0; }
.hero__visual{ position:relative; display:flex; align-items:center; justify-content:center; margin-top:1rem; min-height:360px; opacity:0; animation:fadeUp 1s var(--ease-out) .6s forwards; }
.brandviz{ position:relative; width:min(520px, 102%); transform:translate(var(--px,0px), var(--py,0px)); transition:transform .5s ease-out; }
.brandviz svg{ width:100%; height:auto; display:block; overflow:visible; }

/* hero entrance (CSS-driven, runs without external JS) */
.js .hero__title .line > span{ animation:lineUp 1s var(--ease-out) forwards; }
.js .hero__title .line:nth-child(1) > span{ animation-delay:.35s; }
.js .hero__title .line:nth-child(2) > span{ animation-delay:.5s; }
@keyframes lineUp{ to{ transform:translateY(0); } }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(22px);} to{ opacity:1; transform:none; } }
@keyframes scrollLine{ 0%{ transform:translateX(-100%);} 100%{ transform:translateX(250%);} }

/* ============================================================
   Reveal-on-scroll (enhancement; visible if JS absent)
   ============================================================ */
.js [data-reveal]{ opacity:0; transform:translateY(30px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.js [data-reveal].is-visible{ opacity:1; transform:none; }

/* ============================================================
   2. BRAND / PRODUCT
   ============================================================ */
.brands{ background:linear-gradient(180deg, var(--ink) 0%, var(--ink-2) 100%); }
.brands__layout{ display:grid; gap:3rem; }
.brands__left{ display:flex; flex-direction:column; }
.brands__cta{ align-self:flex-start; margin-top:1.6rem; }

.product-list{ display:flex; flex-direction:column; }
.product{
  width:100%; display:grid; grid-template-columns:1fr; align-items:start; gap:1rem;
  text-align:left; padding:1.3rem 0; border-top:1px solid var(--line);
  transition:padding-left .4s var(--ease), padding-right .4s var(--ease), opacity .4s; opacity:.55;
}
.product-list li:last-child .product{ border-bottom:1px solid var(--line); }
.product__index{ display:none; }
.product__name{ display:block; font-family:var(--display); font-size:clamp(1.5rem,3vw,2.1rem); line-height:1.05; transition:color .3s; }
.product__desc{ display:block; margin-top:.5rem; color:var(--text-dim); font-size:.92rem; line-height:1.5; max-width:34ch; }
.product:hover, .product.is-active{ opacity:1; padding-left:1rem; }
.product.is-active{ border-image:linear-gradient(90deg,var(--accent),transparent) 1; }
.product:hover .product__name, .product.is-active .product__name{ color:var(--accent-bright); }

/* Device */
.device-wrap{ position:relative; display:flex; justify-content:center; align-items:flex-start; }
.device-glow{ position:absolute; inset:-18% -16%; z-index:0;
  background:radial-gradient(58% 50% at 50% 42%, rgba(82,70,255,.42), rgba(131,77,255,.16) 52%, transparent 74%); filter:blur(34px); }
.device{
  position:relative; z-index:1; width:min(290px, 78vw); aspect-ratio:300/600;
  background:linear-gradient(160deg,#1a1a24,#0b0b10); border-radius:42px; padding:13px;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 40px 80px -26px rgba(0,0,0,.85), 0 26px 70px -28px rgba(82,70,255,.55), inset 0 0 0 1px rgba(255,255,255,.05), inset 0 2px 1px rgba(255,255,255,.12);
}
.device__notch{ position:absolute; top:14px; left:50%; transform:translateX(-50%); width:34%; height:22px; background:#000; border-radius:0 0 14px 14px; z-index:5; }
.screen{ position:absolute; inset:14px; border-radius:30px; overflow:hidden; background:radial-gradient(120% 80% at 50% 0%, #14141b, #0a0a0e); padding:16px;
  display:flex; flex-direction:column; gap:12px; opacity:0; transform:scale(1.04); pointer-events:none; transition:opacity .55s var(--ease), transform .7s var(--ease); }
.screen.is-active{ opacity:1; transform:none; pointer-events:auto; }
.screen__bar{ display:flex; align-items:center; justify-content:space-between; padding-top:2px; }
.screen__brand{ font-family:var(--display); letter-spacing:.04em; font-size:1rem; }
.screen__pill{ font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; padding:.3rem .6rem; border-radius:999px; background:rgba(82,70,255,.14); color:var(--accent-bright); border:1px solid rgba(82,70,255,.25); }

.screen__hero{ border-radius:16px; padding:14px; display:flex; flex-direction:column; gap:6px; position:relative; overflow:hidden; }
.screen__hero--casino{ background:var(--grad); color:#ffffff; }
.screen__hero span{ font-family:var(--display); font-weight:600; font-size:1.25rem; line-height:.98; }
.screen__hero b{ font-size:1.1rem; letter-spacing:.02em; }
.screen__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.screen__grid--mini{ grid-template-columns:repeat(4,1fr); }
.tile{ aspect-ratio:1; border-radius:11px; background:#1a1a22; position:relative; overflow:hidden; }
.tile::after{ content:""; position:absolute; inset:0; opacity:.9; }
.tile.t-a::after{ background:linear-gradient(140deg,#3a2c6e,#8268f0); }
.tile.t-b::after{ background:linear-gradient(140deg,#2a356e,#5a72e8); }
.tile.t-c::after{ background:linear-gradient(140deg,#26456e,#4aa0dd); }
.tile.t-d::after{ background:linear-gradient(140deg,#4a2c7e,#9a64f0); }
.tile.t-e::after{ background:linear-gradient(140deg,#264e6e,#46c0d8); }
.tile.t-f::after{ background:linear-gradient(140deg,#34306e,#6a64ec); }
.tile::before{ content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(160deg,rgba(255,255,255,.18),transparent 45%); }
.screen__row{ display:flex; gap:8px; margin-top:auto; flex-wrap:wrap; }
.screen__row--bet{ margin-top:6px; }
.chip{ font-size:.66rem; padding:.4rem .7rem; border-radius:999px; background:rgba(255,255,255,.05); border:1px solid var(--line); color:var(--text-dim); }
.chip--solid{ background:var(--grad); color:#ffffff; border-color:transparent; font-weight:600; }

.match{ background:#13131a; border:1px solid var(--line); border-radius:16px; padding:14px; display:flex; flex-direction:column; gap:8px; }
.match__top{ display:flex; justify-content:space-between; font-size:.62rem; letter-spacing:.12em; color:var(--accent); }
.match__top span{ display:inline-flex; align-items:center; gap:5px; }
.match__teams{ display:flex; justify-content:space-between; align-items:center; font-size:1rem; }
.match__teams b{ font-family:var(--display); font-size:1.2rem; }
.odds{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.odd{ background:#15151d; border:1px solid var(--line); border-radius:12px; padding:.6rem; display:flex; flex-direction:column; align-items:center; gap:3px; font-size:.7rem; color:var(--text-dim); }
.odd b{ color:var(--text); font-size:.95rem; }
.odd--hot{ border-color:rgba(82,70,255,.4); background:rgba(82,70,255,.08); }
.odd--hot b{ color:var(--accent-bright); }

.crash{ background:#0e0e14; border:1px solid var(--line); border-radius:16px; padding:14px; flex:1; display:flex; flex-direction:column; justify-content:flex-end; position:relative; overflow:hidden; min-height:140px; }
.crash__x{ position:absolute; top:14px; left:14px; font-family:var(--display); font-size:2.2rem; color:var(--accent-bright); }
.crash__chart{ width:100%; height:80px; color:var(--accent); }
.match--es{ background:linear-gradient(160deg,#15131f,#0c0c12); }

/* ============================================================
   3. WHY CHOOSE US
   ============================================================ */
.why{ background:var(--ink-2); }
.why__grid{ display:grid; grid-template-columns:1fr; gap:1.1rem; margin-top:0; align-items:start; }
.why-card{
  position:relative; overflow:hidden; cursor:default; isolation:isolate;
  padding:clamp(1.8rem,2.8vw,2.8rem); border:1px solid var(--line); border-radius:var(--radius-lg);
  background:var(--surface); transition:transform .5s var(--ease), border-color .4s, background .4s, box-shadow .5s;
}
.why-card::before{ content:""; position:absolute; inset:0; z-index:-1; opacity:0; transition:opacity .45s; pointer-events:none;
  background:radial-gradient(340px circle at var(--mx,50%) var(--my,0%), rgba(82,70,255,.18), transparent 60%); }
.why-card:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; }
.why-card:hover, .why-card:focus-within{ transform:translateY(-6px); border-color:rgba(82,70,255,.5);
  background:var(--surface-2); box-shadow:0 30px 60px -28px rgba(82,70,255,.55); }
.why-card:hover::before, .why-card:focus-within::before{ opacity:1; }
.why-card__head{ display:flex; align-items:center; gap:.9rem; }
.why-card__icon{ width:54px; height:54px; flex:none; border-radius:16px; display:grid; place-items:center; color:var(--accent-bright);
  background:linear-gradient(150deg, rgba(82,70,255,.24), rgba(131,77,255,.05));
  border:1px solid rgba(255,255,255,.1); box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
  transition:transform .5s var(--ease), border-color .4s, color .35s, box-shadow .5s; }
.why-card__icon svg{ width:27px; height:27px; }
.why-card:hover .why-card__icon, .why-card:focus-within .why-card__icon{ transform:translateY(-3px); color:#fff;
  border-color:rgba(82,70,255,.6); box-shadow:inset 0 1px 0 rgba(255,255,255,.12), 0 14px 30px -12px rgba(82,70,255,.7); }
.why-card__title{ font-size:clamp(1.12rem,1.7vw,1.55rem); white-space:nowrap; transition:color .3s; }
.why-card:hover .why-card__title, .why-card:focus-within .why-card__title{ color:var(--accent-bright); }
.why-card__desc{ color:var(--text-dim); font-size:.98rem; line-height:1.55;
  max-height:0; opacity:0; overflow:hidden;
  transition:max-height .55s var(--ease), opacity .45s var(--ease), margin-top .45s var(--ease); }
.why-card:hover .why-card__desc, .why-card:focus-within .why-card__desc{ max-height:12rem; opacity:1; margin-top:.9rem; }

/* ============================================================
   4. COMMISSION MODELS
   ============================================================ */
.commission{ background:linear-gradient(180deg,var(--ink-2),var(--ink)); }
.commission__panel{ position:relative; overflow:hidden; border:1px solid var(--line); border-radius:var(--radius-lg);
  background:var(--surface); padding:clamp(1.8rem,3.5vw,3rem); }
.commission__panel::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(48% 70% at 100% 0%, rgba(82,70,255,.12), transparent 62%); }
.commission__head{ position:relative; }

.commission__models{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.cmodel{ position:relative; overflow:hidden; display:flex; flex-direction:column; gap:.55rem; padding:clamp(1.5rem,2.2vw,2rem);
  border:1px solid var(--line); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.012));
  transition:border-color .4s, transform .5s var(--ease), box-shadow .5s; }
.cmodel::before{ content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad); opacity:.5; transition:opacity .4s; }
.cmodel::after{ content:""; position:absolute; inset:0; pointer-events:none; opacity:0; transition:opacity .45s;
  background:radial-gradient(75% 55% at 50% 0%, rgba(82,70,255,.16), transparent 70%); }
.cmodel:hover{ transform:translateY(-6px); border-color:rgba(82,70,255,.55); box-shadow:0 30px 60px -28px rgba(82,70,255,.6); }
.cmodel:hover::before{ opacity:1; }
.cmodel:hover::after{ opacity:1; }
.cmodel__value{ position:relative; display:flex; align-items:baseline; gap:.45em; font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; color:var(--text-mute); }
.cmodel__value strong{ font-family:var(--display); font-weight:600; font-size:clamp(2rem,3vw,2.6rem); line-height:1; letter-spacing:-.02em; text-transform:none;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.cmodel__value strong span{ font-size:.46em; }
.cmodel__name{ position:relative; font-family:var(--display); font-size:1.18rem; padding-top:.7rem; margin-top:.1rem; border-top:1px solid var(--line); }
.cmodel__copy{ position:relative; color:var(--text-dim); font-size:.88rem; line-height:1.55; }

/* ============================================================
   5. TRAFFIC (marquee)
   ============================================================ */
.traffic{ background:var(--ink); overflow:hidden; }
.marquee{ display:flex; overflow:hidden; margin-block:.6rem; -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); }
.marquee__track{ display:flex; gap:1rem; padding-right:1rem; flex:none; animation:marquee 38s linear infinite; }
.marquee--rev .marquee__track{ animation-direction:reverse; animation-duration:46s; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.src{
  flex:none; font-family:var(--display); font-size:clamp(1.6rem,4vw,2.8rem); letter-spacing:-.01em;
  padding:.6rem 1.6rem; border:1px solid var(--line); border-radius:999px; color:var(--text);
  display:inline-flex; align-items:center; gap:.8rem; transition:background .3s, color .3s, border-color .3s;
}
.src::before{ content:""; width:9px; height:9px; border-radius:50%; background:var(--accent); opacity:.5; }
.src--alt{ color:var(--text-mute); -webkit-text-stroke:1px var(--line-2); }
.src--alt::before{ background:var(--text-mute); }
.src:hover{ background:var(--grad); color:#ffffff; border-color:transparent; -webkit-text-stroke:0; }
.src:hover::before{ background:#ffffff; opacity:1; }
.traffic__note{ text-align:center; margin-top:2.6rem; color:var(--text-dim); }
.traffic__note--left{ text-align:left; }
.traffic__note a{ color:var(--accent-bright); border-bottom:1px solid rgba(82,70,255,.4); padding-bottom:1px; }
.traffic__note a:hover{ border-color:var(--accent-bright); }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ============================================================
   6. TESTIMONIALS
   ============================================================ */
.testimonials{ background:var(--ink-2); }
.quotes{ position:relative; min-height:clamp(220px,32vw,300px); }
.quote{ position:absolute; inset:0; opacity:0; transform:translateY(16px); transition:opacity .7s var(--ease), transform .7s var(--ease); pointer-events:none; max-width:60rem; }
.quote.is-active{ position:relative; opacity:1; transform:none; pointer-events:auto; }
.quote__text{ font-size:clamp(1.5rem,3.6vw,2.6rem); font-weight:340; line-height:1.22; }
.quote__by{ display:flex; flex-direction:column; gap:.15rem; margin-top:2rem; }
.quote__name{ font-family:var(--display); font-weight:600; font-size:1.05rem; color:#fff;
  display:inline-flex; align-items:center; gap:.3rem; transition:color .3s; }
a.quote__name:hover{ color:var(--accent-bright); }
.quote__role{ font-size:.85rem; color:var(--text-mute); letter-spacing:.04em; }

.quotes__nav{ display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-top:2.5rem; border-top:1px solid var(--line); padding-top:1.6rem; }
.quotes__dots{ display:flex; gap:.5rem; }
.qdot{ width:28px; height:3px; border-radius:2px; background:var(--line-2); transition:background .35s; }
.qdot.is-active{ background:var(--grad); }
.quotes__btns{ display:flex; gap:.6rem; }
.qbtn{ width:48px; height:48px; border-radius:50%; border:1px solid var(--line-2); color:var(--text); display:inline-flex; align-items:center; justify-content:center; transition:background .3s, transform .3s, border-color .3s; }
.qbtn:hover{ background:var(--surface-2); border-color:var(--accent); transform:translateY(-2px); }

/* ============================================================
   7. BLOG
   ============================================================ */
.blog{ background:var(--ink); padding-block:clamp(3.5rem,8vh,7rem); }
.blog .section-head{ margin-bottom:var(--head-gap); }
.blog__grid{ display:grid; gap:1.1rem; }
.post{ display:flex; flex-direction:column; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; background:var(--surface); transition:transform .5s var(--ease), border-color .4s; }
.post:hover{ transform:translateY(-6px); border-color:var(--line-2); }
.post__art{ position:relative; aspect-ratio:16/9; overflow:hidden; }
.post__art::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(8,8,11,.55)); }
.post__art--1{ background:radial-gradient(120% 120% at 20% 10%, #6a8cff, #1a2236 60%, #0a0e18); }
.post__art--2{ background:radial-gradient(120% 120% at 80% 20%, #5c5cc4, #2c2c5e 60%, #0e0e1a); }
.post__art--3{ background:radial-gradient(120% 120% at 30% 80%, #5cc4a8, #1c4a3c 60%, #0a1612); }
.post__art--4{ background:radial-gradient(120% 120% at 70% 30%, #c45c8f, #5e2c44 60%, #1a0e14); }
.post__cat{ position:absolute; z-index:1; top:1rem; left:1rem; font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; padding:.4rem .75rem; border-radius:999px; background:rgba(8,8,11,.55); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,.18); }
.post__body{ padding:1.35rem; display:flex; flex-direction:column; gap:.55rem; flex:1; }
.post__title{ font-size:clamp(1.1rem,1.8vw,1.45rem); line-height:1.15; transition:color .3s; }
.post:hover .post__title{ color:var(--accent-bright); }
.post__excerpt{ color:var(--text-dim); font-size:.92rem; line-height:1.5; }
.post__meta{ margin-top:auto; font-size:.76rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-mute); }
.post--feature .post__title{ font-size:clamp(1.45rem,2.4vw,1.95rem); }
/* Sample imagery + brand veil that lifts on hover/focus */
.post__art--photo .post__art__img{ position:absolute; inset:0; z-index:0; width:100%; height:100%; object-fit:cover;
  transform:scale(1.05); transition:transform .8s var(--ease), filter .6s var(--ease); filter:saturate(.92) contrast(1.02); }
.post__art__veil{ position:absolute; inset:0; z-index:2;
  background:linear-gradient(150deg, rgba(82,70,255,.82) 0%, rgba(131,77,255,.5) 45%, rgba(7,8,17,.74) 100%);
  transition:opacity .55s var(--ease); }
.post__art--photo .post__cat{ z-index:3; }
.post:hover .post__art__veil,
.post:focus-visible .post__art__veil{ opacity:.12; }
.post:hover .post__art--photo .post__art__img,
.post:focus-visible .post__art--photo .post__art__img{ transform:scale(1.12); filter:saturate(1.06) contrast(1.05); }
@media (prefers-reduced-motion:reduce){
  .post__art--photo .post__art__img,
  .post:hover .post__art--photo .post__art__img{ transform:none; }
}
.blog__more{ display:flex; justify-content:center; margin-top:clamp(1.6rem,3vw,2.6rem); }

/* ============================================================
   8. SIGNUP
   ============================================================ */
.signup{ position:relative; overflow:hidden; background:var(--ink-2); padding-block:clamp(3.5rem,7vh,6.5rem); }
.signup__bg{ position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(40% 50% at 85% 18%, rgba(82,70,255,.20), transparent 70%),
    radial-gradient(45% 55% at 8% 92%, rgba(131,77,255,.16), transparent 70%),
    radial-gradient(90% 70% at 50% 130%, rgba(28,12,101,.5), transparent 72%);
}
.signup__bg::after{ content:""; position:absolute; inset:0; opacity:.5;
  background:conic-gradient(from 0deg at 80% 30%, transparent, rgba(82,70,255,.08), transparent 40%);
  animation:spin 26s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.signup .container{ position:relative; z-index:1; }
.signup__card{ display:grid; gap:2rem; padding:clamp(1.5rem,3.4vw,3rem); border:1px solid var(--line-2); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(22,22,29,.8), rgba(12,12,16,.8)); backdrop-filter:blur(8px); }
.signup__card--cta{ grid-template-columns:1fr; text-align:center; max-width:46rem; margin-inline:auto; }
.signup__cta-inner{ display:flex; flex-direction:column; align-items:center; gap:0; }
.signup__points{ display:flex; flex-direction:column; gap:.9rem; margin-top:1.8rem; }
.signup__card--cta .signup__points{ align-items:center; }
.signup__points li{ display:flex; align-items:center; gap:.7rem; color:var(--text-dim); }
.signup__points svg{ color:var(--accent); flex:none; }
.signup__cta-actions{ display:flex; flex-wrap:wrap; justify-content:center; gap:.8rem; margin-top:2rem; }
.signup__card--cta .signup__fine{ margin-top:1.2rem; }

.signup__form{ display:flex; flex-direction:column; gap:1.1rem; }
.field{ position:relative; }
.field input, .field select{
  width:100%; height:42px; padding:1.05rem .9rem 0; background:rgba(255,255,255,.03); border:1px solid var(--line-2); border-radius:11px;
  color:var(--text); font-size:.92rem; transition:border-color .3s, background .3s; appearance:none;
}
.field input:focus, .field select:focus{ outline:none; border-color:var(--accent); background:rgba(82,70,255,.05); }
.field label{ position:absolute; left:.9rem; top:50%; transform:translateY(-50%); color:var(--text-mute); font-size:.92rem; pointer-events:none; transition:top .25s var(--ease), transform .25s var(--ease), color .25s, font-size .25s; }
.field input:focus + label, .field input:not(:placeholder-shown) + label,
.field select:focus + label, .field select:valid + label{ top:6px; transform:none; font-size:.58rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.label--select{ }
.field__chev{ position:absolute; right:1rem; top:50%; transform:translateY(-50%); color:var(--text-mute); pointer-events:none; }
.signup__fine{ font-size:.78rem; color:var(--text-mute); text-align:center; }
.signup__success{ font-size:.92rem; color:var(--accent-bright); text-align:center; padding:.8rem; border:1px solid rgba(82,70,255,.3); border-radius:12px; background:rgba(82,70,255,.06); }

/* ---- Contact form (homepage) ---- */
.contact{ position:relative; overflow:hidden; }
.contact__bg{ position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(58% 80% at 82% 28%, rgba(82,70,255,.18), transparent 70%); }
.contact .container{ position:relative; z-index:1; }
.contact__grid{ display:grid; grid-template-columns:1fr; gap:clamp(2rem,4vw,3.4rem); align-items:center; }
.contact__main .eyebrow{ margin-bottom:.85rem; }
.contact__lead{ color:var(--text-dim); margin-top:.7rem; max-width:34rem; line-height:1.65; }
.contact__form{ display:flex; flex-direction:column; gap:1rem; margin-top:clamp(1.4rem,2.4vw,2rem); max-width:34rem; }
.field--area textarea{ width:100%; min-height:128px; padding:1.45rem .9rem .7rem; background:rgba(255,255,255,.03);
  border:1px solid var(--line-2); border-radius:11px; color:var(--text); font-size:.92rem; line-height:1.5; resize:vertical;
  transition:border-color .3s, background .3s; }
.field--area textarea:focus{ outline:none; border-color:var(--accent); background:rgba(82,70,255,.05); }
.field--area label{ top:1.2rem; transform:none; }
.field--area textarea:focus + label, .field--area textarea:not(:placeholder-shown) + label{
  top:6px; transform:none; font-size:.58rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.contact__actions{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:.3rem; }
.contact__success{ font-size:.92rem; color:var(--accent-bright); padding:.8rem 1rem;
  border:1px solid rgba(82,70,255,.3); border-radius:12px; background:rgba(82,70,255,.06); }
.contact__success[hidden]{ display:none; }
.contact__visual{ display:none; }
/* Reuses the hero's orbital brand graphic (assets/orbital.svg) for the same animation. */
.contact__visual .brandviz{ position:relative; width:min(440px, 100%); }
.contact__visual .brandviz object{ width:100%; height:auto; display:block; overflow:visible; pointer-events:none; }
@media (min-width:880px){
  .contact__grid{ grid-template-columns:1.05fr .95fr; }
  .contact__visual{ display:grid; place-items:center; min-height:340px; }
}

/* ============================================================
   9. FOOTER
   ============================================================ */
.footer{ background:var(--ink); border-top:1px solid var(--line); padding-block:1.5rem 1.1rem; }
.footer__bar{ display:flex; flex-wrap:wrap; align-items:center; gap:.6rem 1.2rem; padding-bottom:1.5rem; border-bottom:1px solid var(--line); }
.footer__links{ display:flex; flex-wrap:wrap; gap:.8rem 1.4rem; }
.footer__links a{ color:var(--text-dim); font-size:.88rem; transition:color .3s; }
.footer__links a:hover{ color:var(--accent-bright); }
.footer__social{ display:flex; gap:.5rem; margin-left:auto; }
.footer__social a{ width:32px; height:32px; border-radius:50%; border:1px solid var(--line-2); display:inline-flex; align-items:center; justify-content:center; color:var(--text-dim); transition:color .3s, border-color .3s, transform .3s; }
.footer__social a:hover{ color:var(--accent); border-color:var(--accent); transform:translateY(-2px); }
.footer__legal{ display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:.6rem 1.2rem; padding-top:.9rem; color:var(--text-mute); font-size:.8rem; }
.footer__copy{ display:flex; align-items:center; gap:.85rem; }
.footer__age{ font-weight:700; font-size:.7rem; border:1.5px solid var(--text-mute); border-radius:50%; width:28px; height:28px; display:inline-flex; align-items:center; justify-content:center; flex:none; }
/* mobile: stack the legal row with Terms above the copyright, slightly smaller */
@media (max-width:560px){
  .footer__legal{ flex-direction:column; align-items:flex-start; gap:.7rem; }
  .footer__legal .footer__links{ order:-1; }
  .footer__legal .footer__links a{ font-size:.8rem; }
}

/* ============================================================
   Floating CTAs (2 stacked FABs)
   ============================================================ */
.fab-stack{
  position:fixed; right:1.2rem; bottom:1.2rem; z-index:95;
  display:grid; grid-template-columns:max-content; justify-items:end;
  gap:.6rem;
  opacity:0; transform:translateY(120%) scale(.92); pointer-events:none;
  transition:opacity .5s var(--ease), transform .6s var(--ease);
}
.fab-stack .fab{ width:100%; justify-content:center; }
.fab-stack.is-visible{ opacity:1; transform:none; pointer-events:auto; }
.fab{
  display:inline-flex; align-items:center; gap:.55rem; padding:.85rem 1.25rem;
  border-radius:999px; font-weight:600; font-size:.92rem;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
  white-space:nowrap;
}
.fab svg{ flex:none; transition:transform .35s var(--ease); }
.fab:hover{ transform:translateY(-3px); }
.fab--primary{
  background:var(--grad); color:#ffffff;
  box-shadow:0 14px 38px -12px rgba(82,70,255,.7), 0 2px 8px rgba(0,0,0,.25);
}
.fab--primary:hover{ box-shadow:0 20px 46px -14px rgba(82,70,255,.85), 0 2px 8px rgba(0,0,0,.25); }
.fab--primary:hover svg{ transform:translateX(3px); }
.fab--telegram{
  position:relative; overflow:hidden;
  background:linear-gradient(135deg, #38b6f0 0%, #229ed9 55%, #0088cc 100%); color:#ffffff;
  box-shadow:0 14px 36px -10px rgba(34,158,217,.7), 0 2px 8px rgba(0,0,0,.3),
             inset 0 1px 0 rgba(255,255,255,.28);
}
.fab--telegram::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.22) 0%, rgba(255,255,255,0) 55%); }
.fab--telegram > *{ position:relative; z-index:1; }
.fab--telegram:hover{ box-shadow:0 22px 44px -12px rgba(34,158,217,.9), 0 2px 8px rgba(0,0,0,.3),
                                 inset 0 1px 0 rgba(255,255,255,.4); }
.fab--telegram:hover svg{ transform:translateX(1px) translateY(-1px) rotate(-4deg); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (min-width:768px){
  .blog__grid{ grid-template-columns:repeat(3,1fr); }
  .signup__card{ grid-template-columns:1fr 1fr; align-items:center; }
  /* full-width split header (brand section) */
  .section-head--split{ display:grid; grid-template-columns:1.05fr .95fr; column-gap:clamp(2rem,5vw,4.5rem); align-items:end; }
  .section-head--split .eyebrow{ grid-column:1; grid-row:1; }
  .section-head--split .section-title{ grid-column:1; grid-row:2; }
  .section-head--split .section-sub{ grid-column:2; grid-row:1 / 3; align-self:end; max-width:none; margin-top:0; }
}

@media (min-width:960px){
  .nav__links{ display:flex; }
  .nav__cta{ display:inline-flex; }
  .nav__burger{ display:none; }
  .hero__scroll{ display:flex; }
  .brands__layout{ grid-template-columns:1fr auto; gap:clamp(2rem,4vw,4rem); align-items:center; }
  .brands__layout .product-list{ display:flex; flex-direction:column; gap:clamp(1.2rem,2.5vw,2rem); }
  .brands__layout .product-list li{ flex:1; display:flex; }
  .brands__layout .product{ flex:1; align-content:center; }
  .fab-stack{ right:2rem; bottom:2rem; }
}


/* why cards: 2-up bigger cards */
@media (min-width:768px){
  .why__grid{ grid-template-columns:repeat(2,1fr); gap:1.4rem; }
}
@media (min-width:1024px){
  /* hero: text + brand graphic side by side */
  .hero__inner{ display:grid; grid-template-columns:1.05fr .92fr; align-items:center; column-gap:clamp(2rem,4vw,4rem); padding-block:6rem 3.5rem; }
  .hero__content{ grid-column:1; }
  .hero__visual{ grid-column:2; margin-top:0; }
  .hero__stats{ grid-column:1 / -1; }
  .hero__title{ font-size:clamp(2.8rem,5vw,5.3rem); }
}

/* ---- mobile/tablet: hero graphic first + compact, commission fits ---- */
@media (max-width:1023px){
  .hero__inner{ display:flex; flex-direction:column; }
  .hero__visual{ order:-1; margin-top:0; min-height:auto; margin-bottom:1.4rem; }
  .brandviz{ width:min(320px, 74%); }
}
@media (max-width:900px){
  .commission__models{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:560px){
  .commission__models{ grid-template-columns:1fr; }
}

/* ============================================================
   PAGE-LEVEL COMPONENTS (subpages)
   ============================================================ */
.page-hero{ position:relative; padding-block:clamp(5rem,11vh,7rem) clamp(2.5rem,5vh,4rem); overflow:hidden; }
.page-hero__bg{ position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(50% 60% at 80% 14%, rgba(82,70,255,.22), transparent 70%),
    radial-gradient(45% 55% at 18% 90%, rgba(131,77,255,.16), transparent 72%),
    radial-gradient(120% 90% at 50% 130%, rgba(28,12,101,.5), transparent 75%); }
.page-hero__inner{ position:relative; z-index:2; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad);
  display:flex; flex-direction:column; gap:1.2rem; }
.page-hero__content{ position:relative; }
.page-hero__title{ font-family:var(--display); font-weight:600; font-size:clamp(2.3rem,5vw,3.6rem); line-height:1.05; letter-spacing:-.02em;
  opacity:0; animation:pageHeroIn 1s var(--ease-out) .15s forwards; }
.page-hero__title em{ font-style:normal; color:var(--accent-bright); }
.page-hero__title-link, .section-title__link{ color:inherit; display:inline; transition:opacity .3s; }
.page-hero__title-link:hover, .section-title__link:hover{ opacity:.85; }
.page-hero__title-link .ext-arrow, .section-title__link .ext-arrow{
  display:inline-block; vertical-align:.05em; margin-left:.2em;
  color:var(--accent-bright); transition:transform .35s var(--ease); }
.page-hero__title-link:hover .ext-arrow, .section-title__link:hover .ext-arrow{ transform:translate(3px,-3px); }
.page-hero__actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:clamp(2rem,3.5vw,2.8rem);
  opacity:0; animation:pageHeroIn 1s var(--ease-out) .4s forwards; }
.page-hero__visual{ position:relative; display:flex; align-items:center; justify-content:center; min-height:240px;
  opacity:0; animation:pageHeroIn 1.1s var(--ease-out) .55s forwards; }
.page-hero__visual .brandviz{ width:min(420px, 100%); position:relative; }
.page-hero__visual .brandviz object{ width:100%; height:auto; display:block; overflow:visible; pointer-events:none; }
@keyframes pageHeroIn{ from{ opacity:0; transform:translateY(22px); } to{ opacity:1; transform:none; } }
@media (min-width:1024px){
  .page-hero{ padding-block:clamp(6rem,12vh,7.5rem) clamp(3rem,5vh,4rem); }
  .page-hero__inner{ display:grid; grid-template-columns:1.05fr .9fr; column-gap:clamp(2rem,4vw,4rem); align-items:center; gap:0; }
  .page-hero__title{ font-size:clamp(2.5rem,4.4vw,3.6rem); }
  .page-hero__visual{ max-height:340px; overflow:hidden; min-height:auto; }
}
@media (max-width:767px){
  .page-hero{ padding-block:4.5rem 1.2rem; }
  .page-hero__inner{ gap:.2rem; }
  .page-hero__visual{ order:-1; min-height:auto; max-height:200px; overflow:hidden; margin-bottom:.3rem; }
  .page-hero__visual .brandviz{ width:min(320px, 86%); }
  .page-hero__title{ font-size:clamp(2.1rem,8.5vw,2.8rem); }
  .page-hero__actions{ margin-top:1.9rem; gap:.8rem; }
  .page-hero__actions .btn{ font-size:1.02rem; padding-block:.9rem; }
}

/* brand stats — premium gradient band */
.brand-stats{ position:relative; display:grid; grid-template-columns:repeat(2,1fr); gap:0; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.012)); }
.brand-stats::before{ content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad); opacity:.55; }
.bstat{ padding:clamp(1.4rem,2.4vw,2rem); position:relative; }
.bstat:nth-child(odd){ border-right:1px solid var(--line); }
.bstat:nth-child(n+3){ border-top:1px solid var(--line); }
.bstat__num{ display:block; font-family:var(--display); font-weight:600; font-size:clamp(2.2rem,4.4vw,3rem); line-height:1; letter-spacing:-.025em;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.bstat__label{ display:block; margin-top:.6rem; font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-mute); }
@media (min-width:768px){
  .brand-stats{ grid-template-columns:repeat(4,1fr); }
  .bstat:nth-child(n+3){ border-top:none; }
  .bstat:not(:last-child){ border-right:1px solid var(--line); }
}

/* news-post (single article) — back button + image-led layout */
.post-page{ max-width:var(--maxw); margin:0 auto; padding-block:clamp(5rem,9vh,7rem) clamp(2rem,4vw,3rem); padding-inline:var(--pad); }
.post-back{ display:inline-flex; align-items:center; gap:.35rem; font-size:.82rem; color:var(--text-mute);
  transition:color .3s, transform .3s; }
.post-back:hover{ color:#fff; transform:translateX(-2px); }
.post-back svg{ transition:transform .3s; }
.post-back:hover svg{ transform:translateX(-2px); }
.post-img{ position:relative; margin-top:1.4rem; aspect-ratio:21/9; border-radius:var(--radius-lg); overflow:hidden; }
.post-img__img{ position:absolute; inset:0; z-index:0; width:100%; height:100%; object-fit:cover; }
.post-img::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 50%, rgba(7,8,17,.55)); }
.post-img .post__cat{ position:absolute; z-index:1; top:1rem; left:1rem; font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; padding:.4rem .8rem; border-radius:999px; background:rgba(8,8,11,.55); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,.18); }
.post-head{ margin-top:clamp(1.6rem,3vw,2.4rem); }
.post-head h1{ font-family:var(--display); font-weight:600; font-size:clamp(1.9rem,3.6vw,2.7rem); line-height:1.08; letter-spacing:-.02em; }
.post-meta{ font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-mute); margin-top:.85rem; }
.post-page .article{ margin-top:clamp(1.6rem,3vw,2.2rem); max-width:none; }
.post-page .article-tags{ max-width:none; }

/* breadcrumb */
.crumb{ display:inline-flex; align-items:center; gap:.5rem; font-size:.84rem; color:var(--text-mute); margin-bottom:.6rem; }
.crumb a{ color:var(--text-dim); transition:color .3s; }
.crumb a:hover{ color:var(--accent-bright); }

/* testimonial card (listing page) */
.testim-grid{ display:grid; grid-template-columns:1fr; gap:1.2rem; }
.testim-card{ position:relative; display:block; padding:clamp(1.5rem,2.4vw,2rem); border:1px solid var(--line); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  color:inherit; text-decoration:none;
  transition:transform .5s var(--ease), border-color .4s, box-shadow .5s; isolation:isolate; overflow:hidden; }
.testim-card::before{ content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad); opacity:.5; transition:opacity .4s; }
.testim-card:hover{ transform:translateY(-5px); border-color:rgba(82,70,255,.5); box-shadow:0 30px 60px -28px rgba(82,70,255,.55); }
.testim-card:hover::before{ opacity:1; }
.testim-card__mark{ font-family:var(--display); font-size:3rem; line-height:.6; color:var(--accent-bright); opacity:.55; height:1.2rem; }
.testim-card__text{ font-family:var(--display); font-weight:500; font-size:clamp(1.05rem,1.4vw,1.18rem); line-height:1.45; margin-top:.4rem; color:rgba(255,255,255,.87); }
.testim-card__by{ display:flex; flex-direction:column; gap:.1rem; margin-top:1.2rem; padding-top:1rem; border-top:1px solid var(--line); }
.testim-card__name{ font-weight:600; }
.testim-card__role{ font-size:.82rem; color:var(--text-mute); letter-spacing:.04em; }
.testim-card__brand{ font-family:var(--display); font-weight:600; font-size:1.1rem; letter-spacing:.005em;
  margin-bottom:1.1rem; }
.testim-card__brand a{ color:var(--accent-bright); transition:color .3s; word-break:break-word; }
.testim-card__brand a:hover{ color:#fff; }
.testim-card[hidden]{ display:none; }
.testim-more{ display:flex; justify-content:center; margin-top:clamp(1.6rem,3vw,2.6rem); }
.testim-more[hidden]{ display:none; }
.testim-more .btn svg{ transition:transform .4s var(--ease); }
.testim-more .btn:hover svg{ transform:translateY(2px); }
@media (min-width:680px){ .testim-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .testim-grid{ grid-template-columns:repeat(3,1fr); } }

/* ============================================================
   Brand subpage
   ============================================================ */
/* Page-hero modifier: browser-screen mockup + mobile reorder (title → visual → copy/buttons) */
.page-hero--brand .page-hero__inner{ display:flex; flex-direction:column; gap:clamp(1.4rem,3vw,2rem); }
.page-hero--brand .page-hero__visual{ max-height:none; overflow:visible; }
.page-hero--brand .page-hero__title{ margin:0; }
.page-hero--brand .page-hero__sub{ margin-top:0; }
.page-hero--brand .page-hero__actions{ margin-top:1.6rem; }
@media (min-width:768px){
  .page-hero--brand .page-hero__inner{
    display:grid;
    grid-template-columns:1fr 1fr;
    grid-template-areas:
      "title visual"
      "content visual";
    grid-template-rows:auto 1fr;
    column-gap:clamp(2rem,4vw,4rem); row-gap:1rem;
    align-items:start;
  }
  .page-hero--brand .page-hero__title{ grid-area:title; align-self:end; }
  .page-hero--brand .page-hero__visual{ grid-area:visual; align-self:center; max-width:600px; justify-self:end; width:100%; }
  .page-hero--brand .page-hero__content{ grid-area:content; align-self:start; }
}

/* Brand-mock: gentle floating animation */
@keyframes brandFloat{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-8px); } }
.page-hero--brand .brand-mock{ animation:brandFloat 6s ease-in-out infinite; }
@media (prefers-reduced-motion:reduce){ .page-hero--brand .brand-mock{ animation:none; } }

/* Inline icon — flows with first line of heading; text wraps naturally after it */
.section-title{ display:block; }
.section-icon{ display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px; border-radius:12px;
  vertical-align:-.32em; margin-right:.65rem;
  background:linear-gradient(135deg, rgba(82,70,255,.18), rgba(131,77,255,.08));
  border:1px solid rgba(82,70,255,.3); color:var(--accent-bright);
  transition:transform .35s var(--ease), border-color .35s; }
.section-icon svg{ width:22px; height:22px; }
.section-title:hover .section-icon{ transform:rotate(-6deg) scale(1.05); border-color:rgba(82,70,255,.55); }

/* Meta-card icons stay stacked (small chip above value) */
.meta-card{ position:relative; }
.meta-card__icon{ display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:10px;
  background:linear-gradient(135deg, rgba(82,70,255,.16), rgba(131,77,255,.06));
  border:1px solid rgba(82,70,255,.25); color:var(--accent-bright);
  margin-bottom:.85rem; transition:transform .35s var(--ease); }
.meta-card__icon svg{ width:20px; height:20px; }
.meta-card:hover .meta-card__icon{ transform:rotate(-6deg) scale(1.08); }

/* Spec-card: icon inline with the title */
.spec-card{ position:relative; }
.spec-card__title{ display:block; }
.spec-card__icon{ display:inline-flex; align-items:center; justify-content:center;
  width:38px; height:38px; border-radius:11px;
  vertical-align:-.32em; margin-right:.6rem;
  background:linear-gradient(135deg, rgba(82,70,255,.16), rgba(131,77,255,.06));
  border:1px solid rgba(82,70,255,.25); color:var(--accent-bright);
  transition:transform .35s var(--ease); }
.spec-card__icon svg{ width:20px; height:20px; }
.spec-card:hover .spec-card__icon{ transform:rotate(-6deg) scale(1.06); }

/* Pay-card: icon inline with the title */
.pay-card{ position:relative; }
.pay-card__title{ display:block;
  font-family:var(--display); font-weight:600; font-size:clamp(1.1rem,1.6vw,1.35rem); margin-bottom:1.1rem; }
.pay-card__icon{ display:inline-flex; align-items:center; justify-content:center;
  width:38px; height:38px; border-radius:11px;
  vertical-align:-.32em; margin-right:.6rem;
  background:linear-gradient(135deg, rgba(82,70,255,.16), rgba(131,77,255,.06));
  border:1px solid rgba(82,70,255,.25); color:var(--accent-bright);
  transition:transform .35s var(--ease); }
.pay-card__icon svg{ width:20px; height:20px; }
.pay-card__icon--in{ background:linear-gradient(135deg, rgba(40,170,90,.18), rgba(20,120,60,.08)); border-color:rgba(40,170,90,.35); color:#62d394; }
.pay-card__icon--out{ background:linear-gradient(135deg, rgba(82,70,255,.18), rgba(131,77,255,.08)); border-color:rgba(82,70,255,.35); color:var(--accent-bright); }
.pay-card:hover .pay-card__icon{ transform:translateY(-3px) scale(1.05); }

/* Support-card: heading icon inline with title */
.support-card__title{ display:block; }
.support-card__heading-icon{ display:inline-flex; align-items:center; justify-content:center;
  width:38px; height:38px; border-radius:11px;
  vertical-align:-.32em; margin-right:.6rem;
  background:linear-gradient(135deg, rgba(82,70,255,.16), rgba(131,77,255,.06));
  border:1px solid rgba(82,70,255,.25); color:var(--accent-bright);
  transition:transform .35s var(--ease); }
.support-card__heading-icon svg{ width:20px; height:20px; }
.support-card:hover .support-card__heading-icon{ transform:rotate(-6deg) scale(1.06); }

/* Provider chips: hover bounce */
.provider-chip{ transition:border-color .3s, color .3s, background .3s, transform .3s var(--ease); }
.provider-chip:hover{ transform:translateY(-2px) scale(1.05); }

/* Show-more button + collapsible providers */
.show-more{ display:none; align-items:center; gap:.4rem;
  margin-top:1rem; padding:.7rem 1.2rem; border:1px solid var(--line-2); border-radius:999px;
  background:rgba(255,255,255,.03); color:var(--text); font-size:.92rem; font-family:inherit;
  cursor:pointer; transition:border-color .3s, background .3s; }
.show-more:hover{ border-color:rgba(82,70,255,.5); background:rgba(82,70,255,.08); }
.show-more__chev{ transition:transform .3s var(--ease); }
.show-more[aria-expanded="true"] .show-more__chev{ transform:rotate(180deg); }
@media (max-width:767px){
  .show-more{ display:inline-flex; }
  .providers--collapsible .provider-chip:nth-child(n+13){ display:none; }
  .providers--collapsible.is-expanded .provider-chip{ display:inline-flex; }
}

/* Quick info cards (Website / License / Online Since / Products) */

/* Quick info cards (Website / License / Online Since / Products) */
.meta-grid{ display:grid; grid-template-columns:1fr; gap:1rem; }
@media (min-width:560px){ .meta-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .meta-grid{ grid-template-columns:repeat(4,1fr); } }
.meta-card{ padding:clamp(1.2rem,2.2vw,1.6rem); border:1px solid var(--line); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  transition:border-color .4s, transform .4s; }
.meta-card:hover{ border-color:rgba(82,70,255,.4); transform:translateY(-3px); }
.meta-card__label{ font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-mute); }
.meta-card__value{ margin-top:.45rem; font-family:var(--display); font-weight:600; font-size:1.05rem; color:#fff; line-height:1.3; }
.meta-card__value--link{ color:var(--accent-bright); transition:color .3s; }
.meta-card__value--link:hover{ color:#fff; }

/* Browser-frame mockup (placeholder for real screenshots) */
.brand-mock{ position:relative; border-radius:16px; overflow:hidden;
  border:1px solid var(--line-2);
  background:linear-gradient(180deg, #0a0a16, #08080e);
  box-shadow:0 32px 80px -32px rgba(0,0,0,.7), 0 12px 32px -16px rgba(82,70,255,.2); }
.brand-mock__bar{ display:flex; align-items:center; gap:.4rem; padding:.7rem 1rem;
  background:rgba(255,255,255,.04); border-bottom:1px solid var(--line); }
.brand-mock__bar span{ width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.18); }
.brand-mock__body{ position:relative; padding:1.2rem; aspect-ratio:16/9; display:flex; flex-direction:column; gap:1rem;
  background:radial-gradient(120% 80% at 30% 20%, rgba(82,70,255,.15), transparent 60%),
             radial-gradient(140% 100% at 90% 90%, rgba(34,158,89,.12), transparent 65%); }
.brand-mock__promos{ display:grid; grid-template-columns:1fr 1fr; gap:.7rem; }
.brand-mock__promo{ position:relative; overflow:hidden; padding:.9rem 1rem; border-radius:11px;
  display:flex; flex-direction:column; gap:.35rem;
  border:1px solid rgba(255,255,255,.08); min-height:64px; }
.brand-mock__promo--green{ background:linear-gradient(135deg, rgba(40,170,90,.4), rgba(20,90,50,.5)); }
.brand-mock__promo--violet{ background:linear-gradient(135deg, rgba(82,70,255,.45), rgba(28,12,101,.6)); }
.brand-mock__pill{ font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; opacity:.85; }
.brand-mock__promo b{ font-family:var(--display); font-weight:600; font-size:1.05rem; color:#fff; line-height:1.15; }
.brand-mock__grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:.45rem; flex:1; }
.brand-mock__tile{ border-radius:7px; min-height:42px; }
.brand-mock__tile--a{ background:linear-gradient(135deg,#a04032,#5a1818); }
.brand-mock__tile--b{ background:linear-gradient(135deg,#c8602a,#7a2a08); }
.brand-mock__tile--c{ background:linear-gradient(135deg,#3a7fcf,#1a3a78); }
.brand-mock__tile--d{ background:linear-gradient(135deg,#2c8a4a,#143820); }
.brand-mock__tile--e{ background:linear-gradient(135deg,#7a3a8a,#3a164a); }
.brand-mock__tile--f{ background:linear-gradient(135deg,#c5963a,#6a4a18); }
.brand-mock--thumb{ box-shadow:0 12px 30px -16px rgba(0,0,0,.5); }
.brand-mock--thumb .brand-mock__body{ padding:.7rem; gap:.5rem; aspect-ratio:16/10; }
.brand-mock--thumb .brand-mock__grid{ grid-template-columns:repeat(2,1fr); }
.brand-mock--thumb .brand-mock__tile{ min-height:32px; }

/* Quick fact cards (4-up) */
.fact-grid{ display:grid; grid-template-columns:1fr; gap:1.4rem; }
@media (min-width:680px){ .fact-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .fact-grid{ grid-template-columns:repeat(4,1fr); } }
.fact-card{ display:flex; flex-direction:column; gap:.5rem; }
.fact-card .brand-mock{ margin-bottom:.6rem; }
.fact-card__label{ font-family:var(--display); font-weight:600; font-size:1rem; color:#fff; margin-top:.4rem; }
.fact-card__value{ color:var(--text-dim); font-size:.95rem; line-height:1.5; }
.fact-card__link{ color:var(--accent-bright); font-size:.95rem; font-weight:500; transition:color .3s; }
.fact-card__link:hover{ color:#fff; }

/* Spec list (label + comma-separated values, 2-col on desktop) */
.spec-list-grid{ display:grid; grid-template-columns:1fr; row-gap:clamp(1.8rem,3vw,2.4rem); column-gap:clamp(2rem,4vw,4rem); }
@media (min-width:780px){ .spec-list-grid{ grid-template-columns:1fr 1fr; } }
.spec-row__label{ font-family:var(--display); font-weight:600; font-size:clamp(1.4rem,2vw,1.7rem); line-height:1.1; color:#fff; margin-bottom:.5rem; }
.spec-row__value{ color:rgba(255,255,255,.78); font-size:.98rem; line-height:1.65; }
.spec-row__value a{ color:var(--accent-bright); transition:color .3s; }
.spec-row__value a:hover{ color:#fff; }

/* Bonus table: hide the row-label column when not present */
.bonus-table tbody td:first-child:not(:only-child){ font-family:var(--display); font-weight:500; color:#fff; }

/* article (single blog post) */
.article-banner{ position:relative; overflow:hidden; border-radius:var(--radius-lg); aspect-ratio:21/9;
  display:flex; align-items:flex-end; padding:clamp(1.5rem,4vw,3rem); margin-top:1.6rem;
  background:radial-gradient(120% 120% at 30% 20%, #6a8cff, #1a2236 60%, #0a0e18); }
.article-banner::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 40%, rgba(7,8,17,.7)); }
.article-banner__inner{ position:relative; z-index:1; max-width:42rem; }
.article-banner__cat{ display:inline-flex; padding:.4rem .8rem; border-radius:999px; background:rgba(8,8,11,.55); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,.18);
  font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; margin-bottom:1rem; }
.article-banner__title{ font-family:var(--display); font-weight:600; font-size:clamp(1.8rem,4vw,3rem); line-height:1.08; letter-spacing:-.015em; }
.article-banner__meta{ margin-top:.7rem; font-size:.82rem; color:var(--text-dim); letter-spacing:.08em; text-transform:uppercase; }

.article{ max-width:42rem; margin:clamp(2rem,4vw,3rem) auto 0; color:var(--text); font-size:1.05rem; line-height:1.75; }
.article p{ margin:0 0 1.1rem; color:var(--text-dim); }
.article h2{ font-family:var(--display); font-weight:600; font-size:clamp(1.4rem,2.2vw,1.8rem); margin:2rem 0 .9rem; letter-spacing:-.01em; }
.article h3{ font-family:var(--display); font-weight:500; font-size:1.2rem; margin:1.4rem 0 .6rem; }
.article ul{ list-style:none; padding-left:0; margin:0 0 1.1rem; color:var(--text-dim); }
.article ul li{ position:relative; padding-left:1.4rem; margin-bottom:.5rem; }
.article ul li::before{ content:""; position:absolute; left:.2rem; top:.7rem; width:.4rem; height:.4rem; border-radius:50%; background:var(--accent); }
.article blockquote{ margin:1.6rem 0; padding:1.1rem 1.4rem; border-left:3px solid var(--accent); border-radius:0 12px 12px 0;
  background:linear-gradient(90deg, rgba(82,70,255,.08), transparent 70%);
  font-family:var(--display); font-weight:500; font-size:1.1rem; color:var(--text); }
.article a{ color:var(--accent-bright); border-bottom:1px solid rgba(155,140,255,.4); padding-bottom:1px; }
.article a:hover{ border-color:var(--accent-bright); }
.article-tags{ display:flex; flex-wrap:wrap; gap:.5rem; max-width:42rem; margin:2rem auto 0; padding-top:1.4rem; border-top:1px solid var(--line); }
.article-tags span{ font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; padding:.45rem .8rem; border-radius:999px; background:rgba(255,255,255,.04); border:1px solid var(--line); color:var(--text-dim); }

/* values + features grid (about / brand) */
.values{ display:grid; grid-template-columns:1fr; gap:1.1rem; }
.value{ position:relative; padding:clamp(1.4rem,2.2vw,1.9rem); border:1px solid var(--line); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  box-shadow: var(--shx,0) var(--shy,0) 42px -18px rgba(82,70,255,.3), 0 18px 50px -28px rgba(0,0,0,.4);
  transition:transform .45s var(--ease), border-color .4s, background .4s, box-shadow .25s ease; }
.value:hover{ transform:translateY(-5px); border-color:rgba(82,70,255,.5); background:var(--surface-2);
  box-shadow: var(--shx,0) var(--shy,0) 60px -16px rgba(82,70,255,.55), 0 30px 60px -26px rgba(0,0,0,.5); }
.value__icon{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; color:var(--accent-bright);
  background:linear-gradient(150deg, rgba(82,70,255,.22), rgba(131,77,255,.05)); border:1px solid rgba(255,255,255,.08); }
.value__icon svg{ width:24px; height:24px; }
.value__name{ font-family:var(--display); font-size:1.18rem; margin-top:.9rem; }
.value__copy{ color:var(--text-dim); font-size:.95rem; line-height:1.55; margin-top:.4rem; }
@media (min-width:640px){ .values{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .values{ grid-template-columns:repeat(3,1fr); } }

/* about + brand graphic */
.about-art{ position:relative; width:min(440px, 92%); aspect-ratio:1; margin-inline:auto;
  display:grid; place-items:center; }
.about-art__halo{ position:absolute; inset:-12%; pointer-events:none;
  background:radial-gradient(circle at 50% 50%, rgba(82,70,255,.4), rgba(131,77,255,.15) 50%, transparent 72%); filter:blur(36px); }
.about-art__core{ position:relative; width:72%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at 35% 28%, #c4b9ff, #7a6cff 22%, #5246ff 50%, #1c0c65 100%);
  box-shadow:inset -22px -26px 60px rgba(10,5,35,.8), inset 18px 18px 50px rgba(190,180,255,.32), 0 50px 90px -25px rgba(82,70,255,.55);
  animation:orbFloat 8s ease-in-out infinite; }
.about-art__ring{ position:absolute; inset:0; border:1px solid rgba(255,255,255,.16); border-radius:50%; animation:spin 20s linear infinite; }
.about-art__ring--2{ inset:8%; border-color:rgba(57,214,255,.18); animation:spin 14s linear infinite reverse; }
.about-art__mark{ position:absolute; inset:0; margin:auto; width:30%; height:30%; color:#fff; filter:drop-shadow(0 6px 14px rgba(0,0,0,.4)); }

/* phone showcase (brand page) — multiple devices */
.showcase{ display:grid; grid-template-columns:1fr; gap:clamp(2.4rem,5vw,3.6rem); }
.showcase__item{ display:grid; grid-template-columns:1fr; gap:clamp(.8rem,2.2vw,1.4rem); align-items:start; }
.showcase__copy h3{ font-family:var(--display); font-size:clamp(1.6rem,3vw,2.2rem); line-height:1.1; }
.showcase__copy p{ color:var(--text-dim); margin-top:.9rem; max-width:38ch; line-height:1.6; }
.showcase__copy ul{ list-style:none; padding:0; margin-top:1.2rem; display:flex; flex-direction:column; gap:.5rem; color:var(--text-dim); }
.showcase__copy ul li{ display:flex; align-items:center; gap:.6rem; font-size:.95rem; }
.showcase__copy ul li::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--accent); flex:none; }
.showcase__device{ display:flex; justify-content:flex-start; }
@media (min-width:768px){
  .showcase__item{ grid-template-columns:1fr 1fr; gap:clamp(2rem,4vw,3.2rem); }
  .showcase__device{ justify-content:flex-end; }
  .showcase__item--rev .showcase__copy{ order:2; }
  .showcase__item--rev .showcase__device{ order:1; justify-content:flex-start; }
}

/* comparison table (commissions page) */
.compare{ width:100%; border-collapse:separate; border-spacing:0; font-size:.94rem; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; }
.compare th, .compare td{ padding:1rem 1.1rem; text-align:left; border-bottom:1px solid var(--line); }
.compare thead th{ font-family:var(--display); font-weight:500; font-size:.92rem; color:var(--text); background:rgba(255,255,255,.03); }
.compare tbody th{ color:var(--text); font-weight:500; }
.compare td{ color:var(--text-dim); }
.compare tr:last-child td, .compare tr:last-child th{ border-bottom:none; }
.compare-wrap{ overflow-x:auto; }
.compare .yes{ color:var(--accent-bright); font-weight:600; }
.compare .no{ color:var(--text-mute); }

/* news filter chips */
.news-filters{ display:flex; flex-wrap:nowrap; gap:.5rem; justify-content:center; margin-bottom:clamp(1.6rem,3vw,2.4rem); overflow-x:auto; scrollbar-width:none; -webkit-overflow-scrolling:touch; }
.news-filters::-webkit-scrollbar{ display:none; }
.news-filters button, .news-filters a{ font-size:.85rem; padding:.5rem 1rem; border-radius:999px; border:1px solid var(--line); background:transparent; color:var(--text-dim); cursor:pointer; white-space:nowrap; flex:none; transition:border-color .3s, color .3s, background .3s; }
.news-filters button:hover, .news-filters a:hover, .news-filters .is-active{ border-color:var(--accent); color:#fff; background:rgba(82,70,255,.12); }
@media (max-width:767px){
  .news-filters{ justify-content:flex-start; margin-inline:calc(-1 * var(--pad)); padding:0 var(--pad) .35rem; -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%); mask-image:linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%); }
}

/* CTA section reusable */
.cta-band{ position:relative; overflow:hidden; padding:clamp(2.4rem,5vw,4rem) clamp(1.6rem,3vw,3rem); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(22,22,29,.8), rgba(12,12,16,.8)); border:1px solid var(--line-2); text-align:center; }
.cta-band::before{ content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(45% 70% at 80% 20%, rgba(82,70,255,.22), transparent 70%), radial-gradient(45% 55% at 18% 92%, rgba(131,77,255,.16), transparent 72%); }
.cta-band > *{ position:relative; z-index:1; }
.cta-band__title{ font-family:var(--display); font-weight:600; font-size:clamp(1.6rem,3vw,2.3rem); line-height:1.1; }
.cta-band__sub{ color:var(--text-dim); margin-top:.8rem; max-width:40rem; margin-inline:auto; }
.cta-band__actions{ display:flex; flex-wrap:wrap; justify-content:center; gap:1rem; margin-top:1.6rem; }
.cta-band__fine{ font-size:.78rem; color:var(--text-mute); text-align:center; margin-top:1.2rem; }

/* Telegram CTA band variant */
.cta-band--telegram::before{
  background:radial-gradient(50% 70% at 50% 0%, rgba(34,158,217,.22), transparent 65%),
             radial-gradient(50% 60% at 50% 100%, rgba(42,171,238,.15), transparent 70%);
}

/* Manager / contact cards */
.manager-grid{ display:grid; grid-template-columns:1fr; gap:1.4rem; }
@media (min-width:680px){ .manager-grid{ grid-template-columns:repeat(3,1fr); } }
.manager-card{ display:flex; flex-direction:column; align-items:center; text-align:center;
  padding:clamp(1.8rem,3vw,2.4rem) clamp(1.4rem,2.4vw,2rem);
  border:1px solid var(--line); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  transition:transform .5s var(--ease), border-color .4s, box-shadow .5s; }
.manager-card:hover{ transform:translateY(-4px); border-color:rgba(82,70,255,.45);
  box-shadow:0 22px 50px -28px rgba(82,70,255,.55); }
.manager-card__avatar{ width:88px; height:88px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
  background:var(--grad); margin-bottom:1.2rem;
  box-shadow:0 12px 32px -10px rgba(82,70,255,.5); }
.manager-card__avatar--alt{ background:linear-gradient(135deg, #5246ff 0%, #2aabee 100%);
  box-shadow:0 12px 32px -10px rgba(82,128,238,.5); }
.manager-card__avatar--alt2{ background:linear-gradient(135deg, #834dff 0%, #c45c8f 100%);
  box-shadow:0 12px 32px -10px rgba(196,92,143,.5); }
.manager-card__avatar img{ width:100%; height:100%; object-fit:cover; }
.manager-card__initial{ font-family:var(--display); font-size:2.1rem; font-weight:600; color:#fff; line-height:1; }
.manager-card__name{ font-family:var(--display); font-size:1.3rem; font-weight:600; }
.manager-card__role{ color:var(--accent-bright); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; margin-top:.4rem; }
.manager-card__copy{ color:var(--text-dim); font-size:.92rem; line-height:1.55; margin:1rem 0 1.4rem; }

/* Telegram-blue button */
.btn--telegram{ position:relative; overflow:hidden;
  background:linear-gradient(135deg, #38b6f0 0%, #229ed9 55%, #0088cc 100%); color:#fff;
  border-color:transparent;
  box-shadow:0 10px 26px -10px rgba(34,158,217,.55), inset 0 1px 0 rgba(255,255,255,.25); }
.btn--telegram::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.18) 0%, rgba(255,255,255,0) 55%); }
.btn--telegram > *{ position:relative; z-index:1; }
.btn--telegram:hover{ transform:translateY(-2px);
  box-shadow:0 18px 36px -12px rgba(34,158,217,.8), inset 0 1px 0 rgba(255,255,255,.36); }
.btn--telegram:hover svg{ transform:translateX(1px) translateY(-1px) rotate(-4deg); }
.btn--block{ width:100%; }

/* Page-hero subtitle */
.page-hero__sub{ color:var(--text-dim); font-size:var(--fs-lg); line-height:1.55; margin-top:1.4rem; max-width:38rem;
  opacity:0; animation:pageHeroIn 1s var(--ease-out) .3s forwards; }

/* Brand subpage — about block */
.brand-about{ max-width:46rem; }
.brand-about .section-title{ margin-top:1rem; }
.brand-about__copy{ color:var(--text-dim); font-size:1.04rem; line-height:1.75; margin-top:1.2rem; }

/* Brand stat "<" and unit */
.bstat__lt{ font-size:.62em; color:var(--text-dim); margin-right:.05em; vertical-align:.1em; }
.bstat__unit{ font-size:.4em; color:var(--text-dim); margin-left:.1em; vertical-align:.4em; letter-spacing:0; }

/* Payments — chip grid (legacy + new pay-grid) */
.payments{ display:flex; flex-wrap:wrap; gap:.55rem; }
.payment-chip{ display:inline-flex; align-items:center; padding:.65rem 1.05rem;
  border:1px solid var(--line-2); border-radius:999px;
  background:rgba(255,255,255,.03); font-size:.88rem; color:var(--text-dim);
  transition:border-color .3s, color .3s, background .3s, transform .3s; }
.payment-chip:hover{ border-color:rgba(82,70,255,.5); color:#fff; background:rgba(82,70,255,.08); transform:translateY(-2px); }

/* Game providers chip grid */
.providers{ display:flex; flex-wrap:wrap; gap:.5rem; }
.provider-chip{ display:inline-flex; align-items:center; padding:.55rem 1rem;
  border:1px solid var(--line-2); border-radius:10px;
  background:rgba(255,255,255,.025); font-size:.86rem; color:var(--text-dim);
  font-family:var(--display); font-weight:500; letter-spacing:.01em;
  transition:border-color .3s, color .3s, background .3s, transform .3s; }
.provider-chip:hover{ border-color:rgba(82,70,255,.5); color:#fff; background:rgba(82,70,255,.08); transform:translateY(-2px); }

/* Mini provider chip (used inline in product showcase for live casino) */
.provider-mini{ display:flex; flex-wrap:wrap; gap:.4rem; margin-top:1.2rem; }
.provider-mini__chip{ display:inline-flex; padding:.35rem .7rem; font-size:.78rem;
  border:1px solid var(--line); border-radius:7px; color:var(--text-dim);
  background:rgba(255,255,255,.02); letter-spacing:.01em; }

/* Languages & Currencies spec cards */
.spec-grid{ display:grid; grid-template-columns:1fr; gap:1.4rem; }
@media (min-width:780px){ .spec-grid{ grid-template-columns:repeat(2,1fr); } }
.spec-card{ padding:clamp(1.6rem,2.8vw,2.2rem); border:1px solid var(--line); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  transition:border-color .4s; }
.spec-card:hover{ border-color:rgba(82,70,255,.4); }
.spec-card__title{ font-family:var(--display); font-weight:600; font-size:clamp(1.25rem,2vw,1.6rem); line-height:1.15; margin-top:1rem; }
.spec-list{ display:flex; flex-wrap:wrap; gap:.45rem; margin-top:1.3rem; }
.spec-pill{ display:inline-flex; padding:.45rem .85rem; border:1px solid var(--line-2); border-radius:999px;
  background:rgba(255,255,255,.03); font-size:.85rem; color:var(--text-dim); letter-spacing:.02em; }

/* Payments grid (deposit/withdrawal cards) */
.pay-grid{ display:grid; grid-template-columns:1fr; gap:1.4rem; }
@media (min-width:820px){ .pay-grid{ grid-template-columns:1.4fr 1fr; } }
.pay-card{ padding:clamp(1.6rem,2.8vw,2.2rem); border:1px solid var(--line); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  transition:border-color .4s; }
.pay-card:hover{ border-color:rgba(82,70,255,.4); }
.pay-list{ display:flex; flex-wrap:wrap; gap:.45rem; margin-top:1.2rem; }
.pay-card__note{ margin-top:1.4rem; padding-top:1.2rem; border-top:1px solid var(--line);
  color:var(--text-dim); font-size:.92rem; }
.pay-card__note strong{ color:#fff; font-weight:600; }

/* Customer support card */
.support-card{ padding:clamp(1.8rem,3vw,2.4rem); border:1px solid var(--line); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012)); }
.support-card__title{ font-family:var(--display); font-weight:600; font-size:clamp(1.4rem,2.4vw,1.85rem); line-height:1.15; margin-top:1rem; }
.support-card__channels{ display:grid; grid-template-columns:1fr; gap:1.2rem; margin-top:1.6rem; }
@media (min-width:680px){ .support-card__channels{ grid-template-columns:repeat(2,1fr); } }
.support-channel{ display:flex; align-items:flex-start; gap:.9rem; padding:1.1rem; border:1px solid var(--line-2); border-radius:12px;
  background:rgba(255,255,255,.02); }
.support-channel__icon{ display:flex; align-items:center; justify-content:center;
  width:42px; height:42px; flex:none; border-radius:50%; background:var(--grad); color:#fff; }
.support-channel__label{ font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-mute); }
.support-channel__value{ margin-top:.25rem; font-size:1rem; color:#fff; font-weight:500; }
.support-channel__value a{ color:inherit; transition:color .3s; }
.support-channel__value a:hover{ color:var(--accent-bright); }

/* Welcome bonus table */
.bonus-table-wrap{ overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  scrollbar-width:thin; }
.bonus-table{ width:100%; min-width:780px; border-collapse:collapse; font-size:.92rem; }
.bonus-table thead th{ font-family:var(--display); font-weight:500; font-size:.78rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--text-mute);
  padding:1rem 1.2rem; text-align:left; background:rgba(255,255,255,.025);
  border-bottom:1px solid var(--line-2); white-space:nowrap; }
.bonus-table tbody th{ font-family:var(--display); font-weight:600; font-size:.95rem; color:#fff;
  padding:.95rem 1.2rem; text-align:left; background:rgba(255,255,255,.015);
  border-right:1px solid var(--line); border-bottom:1px solid var(--line);
  white-space:nowrap; }
.bonus-table tbody td{ padding:.95rem 1.2rem; color:var(--text-dim); border-bottom:1px solid var(--line); white-space:nowrap; }
.bonus-table tbody tr:hover th, .bonus-table tbody tr:hover td{ background:rgba(82,70,255,.05); color:#fff; }
.bonus-table tbody tr:last-child th, .bonus-table tbody tr:last-child td{ border-bottom:none; }

/* ============ MOBILE (phones) ============ */
@media (max-width:767px){
  :root{ --section-y: clamp(1.9rem, 4.5vh, 2.8rem); --head-gap: clamp(1.3rem, 4vw, 1.9rem); }
  .section--tight{ padding-block:clamp(1.8rem, 4vh, 2.6rem); }

  /* FABs: horizontal bottom bar — Telegram left, Become a Partner right */
  .fab-stack{ left:1rem; right:1rem; bottom:1rem;
    grid-template-columns:1fr 1fr; justify-items:stretch; gap:.6rem; }

  /* hero: compact graphic (cropped negative space) + CTA above the fold */
  .hero{ min-height:auto; }
  .hero__inner{ display:flex; flex-direction:column; padding:4.6rem var(--pad) 2.4rem; }
  .hero__visual{ order:-1; min-height:auto; max-height:218px; overflow:hidden; margin:0 0 .3rem; }
  .brandviz{ width:min(360px, 92%); }
  .hero__title{ font-size:clamp(2.6rem, 10.5vw, 3.4rem); margin:.1rem 0 1rem; }
  .hero__actions{ margin-top:0; gap:1rem; }
  .hero__actions .btn{ font-size:1.05rem; padding-block:1rem; }

  /* brand: 2x2 product tabs above, wider phone below */
  .brands__layout{ display:flex; flex-wrap:wrap; gap:.55rem; align-items:flex-start; }
  .brands__layout .product-list{ display:contents; }
  .brands__layout .product-list li{ flex:1 1 calc(50% - .3rem); display:flex; }
  .brands__layout{ gap:.55rem; }
  .brands__layout .product{ flex:1; display:flex; align-items:center; justify-content:center; text-align:center;
    padding:.8rem .4rem; border:1px solid var(--line-2); border-radius:13px;
    background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.012)); opacity:1;
    transition:background .3s, border-color .3s, box-shadow .3s; }
  .brands__layout .product__index, .brands__layout .product__desc{ display:none; }
  .brands__layout .product__name{ font-size:.92rem; line-height:1; white-space:nowrap; }
  .brands__layout .product.is-active{ background:var(--grad); border-color:transparent; box-shadow:0 10px 22px -12px rgba(82,70,255,.7); }
  .brands__layout .product.is-active .product__name{ color:#fff; }
  /* landing: wide phone, cut mid-screen and faded into the background */
  .brands__layout .device-wrap{ order:9; flex:1 1 100%; margin-top:.7rem; height:clamp(310px, 88vw, 380px); overflow:hidden;
    -webkit-mask-image:linear-gradient(180deg,#000 0,#000 72%,transparent 100%);
    mask-image:linear-gradient(180deg,#000 0,#000 72%,transparent 100%); }
  .brands__layout .device{ width:min(390px, 88vw); }
  .brands__layout .brands__left{ display:contents; }
  .brands__cta{ order:8; flex:1 1 100%; justify-content:center; margin-top:.2rem; }

  /* brand subpage showcase: wide phone cut mid-screen with gradient (matches landing) */
  .showcase__item{ gap:.6rem; }
  .showcase__device{ justify-content:center; }
  .showcase__device .device-wrap{ width:100%; height:clamp(310px, 88vw, 380px); overflow:hidden; justify-content:center;
    -webkit-mask-image:linear-gradient(180deg,#000 0,#000 72%,transparent 100%);
    mask-image:linear-gradient(180deg,#000 0,#000 72%,transparent 100%); }
  .showcase__device .device{ width:min(390px, 88vw); }

  /* brand + why headlines: two lines */
  .section-title .tline{ display:block; }

  /* stacked buttons share the width of the largest one (not full-width) */
  .hero__actions, .page-hero__actions{
    display:grid; grid-template-columns:max-content; justify-content:start; gap:.8rem;
  }
  .cta-band__actions{
    display:grid; grid-template-columns:max-content; justify-content:center; gap:.8rem;
  }
  .hero__actions .btn, .page-hero__actions .btn, .cta-band__actions .btn{ width:100%; justify-content:center; }

  /* tighter card paddings for a cleaner, pro feel */
  .why-card{ padding:1.4rem; }
  .cmodel{ padding:1.4rem; }
  .cmodel__value strong{ font-size:clamp(2.5rem,8.5vw,3.4rem); }
  .cmodel__value{ font-size:.65rem; }
  .signup__card{ padding:1.5rem; }
  .post__body{ padding:1.1rem; }
  /* why: open the first card by default on mobile */
  .why__grid .why-card:first-child{ border-color:rgba(82,70,255,.5); background:var(--surface-2); }
  .why__grid .why-card:first-child .why-card__title{ color:var(--accent-bright); }
  .why__grid .why-card:first-child .why-card__desc{ max-height:12rem; opacity:1; margin-top:.9rem; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto !important; }
  .js .hero__title .line > span{ transform:none; }
  .js [data-reveal]{ opacity:1; transform:none; }
  .hero__eyebrow,.hero__lede,.hero__actions{ opacity:1; animation:none; }
  .marquee__track{ animation:none; }
}
