/* ============================================================
   Homepage editorial theme — TransitionsUK
   Aesthetic adapted from a premium animated portfolio layout:
   dark canvas, Manrope display type, preloader, location/clock
   header, marquee, hover-zoom cards, scroll reveals.
   Loaded IN ADDITION to style.css (reuses .cmp/.badge/.btn).
   Scope: body.home only.
   ============================================================ */
body.home{
  --ink:#0b0b0c;        /* near-black canvas */
  --cream:#ece9e0;      /* editorial text */
  --muted:#8e8f8c;
  --gold:#e7b94d;
  --green:#28c76f;
  --line:#26262a;
  background:var(--ink);
  color:var(--cream);
  font-family:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  overflow-x:hidden;
}
body.home a{color:var(--cream)}
body.home .wrap{max-width:1280px;margin:0 auto;padding:0 28px}

/* hide the default sticky header + agecheck styling carries over but we restyle */
body.home > header.site{display:none}
body.home .agecheck{background:#000;color:#c9cabf;border-bottom:1px solid var(--line)}

/* ---------- Preloader ---------- */
.preloader{position:fixed;inset:0;z-index:1000;background:var(--ink);
  display:flex;align-items:flex-end;justify-content:flex-end;padding:6vw;
  transition:opacity .6s ease,visibility .6s ease}
.preloader.done{opacity:0;visibility:hidden}
.preloader .count{font-size:clamp(4rem,16vw,13rem);font-weight:800;line-height:.8;color:var(--cream);letter-spacing:-.04em}
.preloader .count small{color:var(--gold)}

/* ---------- Editorial header (sticky row below the compliance bar) ---------- */
.mh{position:sticky;top:0;z-index:90;background:rgba(11,11,12,.92);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.mh-inner{display:flex;align-items:center;gap:28px;max-width:1280px;margin:0 auto;
  padding:16px 28px;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase}
.mh .brand{font-weight:800;font-size:1.05rem;letter-spacing:.02em;color:#fff;text-transform:none;white-space:nowrap}
.mh .brand .dot{color:var(--gold)}
.mh .meta{display:flex;gap:20px;color:var(--muted)}
.mh .clock{min-width:80px;color:var(--cream)}
.mh-nav{margin-left:auto;display:flex;gap:18px;align-items:center}
.mh-item{position:relative}
.mh-item > a,.mh-top{color:var(--cream);font-weight:600;letter-spacing:.08em;white-space:nowrap;
  display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.mh-item > a:hover{color:var(--gold);text-decoration:none}
.mh-caret{font-size:.62em;opacity:.7}
.mh-drop{position:absolute;top:100%;left:0;margin-top:0;min-width:232px;background:#11141a;
  border:1px solid var(--line);border-radius:10px;padding:8px;box-shadow:0 18px 44px rgba(0,0,0,.5);
  display:none;flex-direction:column;z-index:95}
.mh-item.mh-has:hover .mh-drop,.mh-item.mh-has:focus-within .mh-drop{display:flex}
.mh-item:last-child .mh-drop{left:auto;right:0}
.mh-drop a{display:block;padding:8px 12px;color:var(--cream);font-weight:600;font-size:.8rem;
  letter-spacing:0;text-transform:none;border-radius:6px;white-space:nowrap}
.mh-drop a:hover{background:var(--surface-2,#222d3b);color:var(--gold);text-decoration:none}
/* hamburger button */
.mh-burger{display:none;margin-left:auto;width:34px;height:24px;background:none;border:0;cursor:pointer;
  flex-direction:column;justify-content:space-between;padding:0}
.mh-burger span{display:block;height:2px;width:100%;background:var(--cream);border-radius:2px;
  transition:transform .3s ease,opacity .25s ease}
.mh-burger.open span:nth-child(1){transform:translateY(11px) rotate(45deg)}
.mh-burger.open span:nth-child(2){opacity:0}
.mh-burger.open span:nth-child(3){transform:translateY(-11px) rotate(-45deg)}
/* slide-down mobile panel with all pages grouped */
.mh-mobile{display:none;background:#0d0e11;border-top:1px solid var(--line);
  max-height:0;overflow:hidden;transition:max-height .35s ease}
.mh-mobile.open{max-height:82vh;overflow:auto}
.mh-mobile .mm-group{padding:14px 22px;border-bottom:1px solid var(--line)}
.mh-mobile .mm-group strong{display:block;color:var(--gold);font-size:.7rem;letter-spacing:.14em;
  text-transform:uppercase;margin-bottom:6px}
.mh-mobile .mm-group a{display:block;color:var(--cream);padding:9px 0;font-weight:600;font-size:1rem;
  border-bottom:1px solid rgba(255,255,255,.05)}
.mh-mobile .mm-group a:last-child{border-bottom:0}
.mh-mobile .mm-group a:hover{color:var(--gold);text-decoration:none}
body.menu-open{overflow:hidden}
@media(max-width:1040px){.mh .meta{display:none}}
@media(max-width:880px){
  .mh-nav{display:none}
  .mh-burger{display:flex}
  .mh-mobile{display:block}
  .mh-inner{padding:14px 18px}
}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- Hero ---------- */
.hero-ed{display:flex;flex-direction:column;justify-content:flex-start;
  padding:56px 0 50px;position:relative}
@media(max-width:880px){.hero-ed{padding:14px 0 34px}}
@media(max-width:680px){.hero-ed{padding:10px 0 30px}.hero-ed .eyebrow{margin-bottom:22px;padding-bottom:10px}}

/* Mobile homepage: bring the affiliate table above the fold — keep only the
   H1, author byline, the marquee and the "Featured Casinos" H2 (+ table).
   Scoped with :not(.hero-inner) so inner-page heroes are unaffected. */
@media(max-width:880px){
  body.home .hero-ed:not(.hero-inner){padding:10px 0 4px}
  body.home .hero-ed:not(.hero-inner) .eyebrow,
  body.home .hero-ed:not(.hero-inner) .sub,
  body.home .hero-ed:not(.hero-inner) .disclosure-ed{display:none}
  body.home .hero-ed:not(.hero-inner) h1{font-size:clamp(2.1rem,8.5vw,3rem);line-height:1.02}
  body.home .hero-ed:not(.hero-inner) .hero-meta{margin-top:10px;font-size:.78rem}
  body.home .marquee{padding:14px 0}
  body.home .marquee .track span{font-size:1.4rem;margin:0 18px}
  body.home .sec{padding:22px 0}
  body.home .sec-head{margin-bottom:6px}
  body.home #featured .sec-tags{display:none}
  /* above-the-fold: don't gate the featured table behind scroll-reveal */
  body.home #featured .reveal{opacity:1;transform:none}
}
.hero-ed .eyebrow{display:flex;justify-content:space-between;font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:34px}
.hero-ed h1{font-size:clamp(2.6rem,9vw,8.4rem);line-height:.92;font-weight:800;letter-spacing:-.03em;margin:0;color:#fff}
.hero-ed h1 .gold{color:var(--gold)}
.hero-ed .sub{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-top:30px;flex-wrap:wrap}
.hero-ed .sub p{max-width:520px;font-size:1.05rem;color:#cfd0c9;font-weight:500;margin:0}
.hero-ed .scroll{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);
  display:flex;align-items:center;gap:10px}
.hero-ed .scroll::before{content:"";width:46px;height:1px;background:var(--gold);display:inline-block}
.disclosure-ed{font-size:.74rem;color:var(--muted);margin-top:26px;max-width:640px;line-height:1.6;
  border-left:2px solid var(--gold);padding-left:14px}

/* Inner-page editorial hero — same font, weight, colours and white+gold
   treatment as the homepage; size slightly capped so the longer two-phrase
   keyword titles stay tidy (they wrap rather than overflow). */
.hero-inner{padding:34px 0 34px}
.hero-inner .eyebrow{margin-bottom:24px}
.hero-inner h1{font-size:clamp(2.3rem,6vw,5.2rem);line-height:.96;font-weight:800;letter-spacing:-.03em}
.hero-inner .sub{margin-top:20px}
.hero-inner .sub p{max-width:760px;color:#cfd0c9;font-size:1.05rem}
.hero-inner .hero-meta{margin-top:16px}
.hero-inner .disclosure{margin-top:18px}

/* Mobile: bring the affiliate table above the fold — show only H1 + author
   + the comparison H2. Hide eyebrow, lede, disclosure and the lead-in
   paragraph (kept in the DOM for crawlers, just not shown). */
@media(max-width:880px){
  body.home .hero-inner{padding:14px 0 10px}
  body.home .hero-inner .eyebrow,
  body.home .hero-inner .sub,
  body.home .hero-inner .disclosure{display:none}
  body.home .hero-inner h1{font-size:clamp(1.7rem,6.6vw,2.3rem);line-height:1.08}
  body.home .hero-inner .hero-meta{margin-top:10px;font-size:.78rem;gap:6px}
  body.home main .wrap > p:first-child,
  body.home main .wrap .intro-lead{display:none}
  body.home main .wrap > h2:first-of-type{margin-top:.2em;padding-top:0}
}

/* ---------- Section scaffolding ---------- */
.sec{padding:90px 0;border-top:1px solid var(--line)}
.sec-head{display:flex;align-items:baseline;gap:18px;margin-bottom:8px}
.sec-head .hg{font-size:clamp(1.8rem,5vw,3.4rem);font-weight:800;letter-spacing:-.02em;color:#fff;line-height:1}
.sec-head .idx{font-size:.8rem;color:var(--gold);font-weight:700}
.sec-tags{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 30px}
.sec-tags span{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);
  border:1px solid var(--line);border-radius:30px;padding:6px 12px}

/* big editorial intro lines */
.bigtype{font-size:clamp(2.2rem,8vw,7rem);font-weight:800;line-height:.98;letter-spacing:-.03em;color:#fff;margin:0}
.bigtype .out{-webkit-text-stroke:1px var(--muted);color:transparent}
.bigtype .gold{color:var(--gold)}
.intro-cap{display:flex;justify-content:flex-end;color:var(--muted);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-top:24px}

/* ---------- Editorial category cards ---------- */
.ed-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin-top:30px}
.ed-card{position:relative;display:block;background:#141417;border:1px solid var(--line);border-radius:14px;
  padding:26px 22px;overflow:hidden;transition:transform .5s cubic-bezier(.16,1,.3,1),border-color .4s}
.ed-card:hover{transform:translateY(-6px);border-color:var(--gold);text-decoration:none}
.ed-card .num{font-size:.72rem;color:var(--gold);font-weight:700}
.ed-card h3{font-size:1.3rem;margin:.5em 0 .3em;color:#fff}
.ed-card p{color:var(--muted);font-size:.9rem;margin:0}
.ed-card .arrow{position:absolute;top:22px;right:22px;color:var(--gold);transition:transform .4s}
.ed-card:hover .arrow{transform:translate(4px,-4px)}

/* ---------- Featured operators (editorial table wrapper) ---------- */
.featured-table{margin-top:24px}
body.home table.cmp{background:#141417;border-radius:14px;overflow:hidden}
body.home table.cmp thead th{background:#0f0f11;color:var(--gold)}
body.home .tablewrap{border-color:var(--line)}
body.home .btn{background:var(--green);border-radius:30px;letter-spacing:.04em}
body.home .btn-ghost{background:transparent;border:1px solid var(--gold);color:var(--gold)}

/* ---------- Marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:26px 0;white-space:nowrap}
.marquee .track{display:inline-block;animation:marq 28s linear infinite}
.marquee .track span{font-size:clamp(1.6rem,5vw,3.2rem);font-weight:800;letter-spacing:-.02em;color:#fff;margin:0 28px}
.marquee .track span .gold{color:var(--gold)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- FAQ tweak on home ---------- */
body.home .faq details{background:#141417;border-color:var(--line)}

/* ---------- Editorial footer ---------- */
.foot-ed{padding:70px 0 30px;border-top:1px solid var(--line)}
.foot-ed .labels{display:flex;justify-content:space-between;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.foot-ed .line{height:1px;background:var(--line);margin:16px 0 28px}
.foot-ed .navs{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:26px}
.foot-ed .navs strong{display:block;color:var(--gold);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.foot-ed .navs a{display:block;color:var(--cream);padding:4px 0;font-weight:600;font-size:.9rem}
.foot-ed .navs a:hover{color:var(--gold);text-decoration:none}
.foot-ed .talk{font-size:clamp(2.4rem,9vw,7rem);font-weight:800;letter-spacing:-.03em;color:#fff;margin:40px 0 10px;line-height:1}
.foot-ed .metabar{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;color:var(--muted);
  font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;border-top:1px solid var(--line);padding-top:20px;margin-top:30px}
.rg-strip{background:#000;color:#c9cabf;text-align:center;padding:14px;font-size:.8rem}
.rg-strip strong{color:var(--gold)}
.rg-strip a{color:var(--gold);text-decoration:underline}

/* ============================================================
   Inner-page harmonisation — applies the editorial canvas/type
   to the standard content pages (pillars, landing, legal) so the
   whole site shares one look. Content structure is unchanged.
   ============================================================ */
body.home main{padding:30px 0 50px}
body.home .hero{background:#0b0b0c;border-bottom:1px solid var(--line);padding:34px 0 30px}
body.home .hero h1{font-size:clamp(1.9rem,4.5vw,3rem);letter-spacing:-.02em;color:#fff}
body.home .hero .lede{color:#cfd0c9}
body.home h2{border-bottom:1px solid var(--line)}
body.home .crumbs{padding-top:16px}
body.home .bylines{border-color:var(--line)}
body.home .opcard,
body.home .callout,
body.home .tile,
body.home .rg-block,
body.home .disclosure,
body.home .faq details{background:#141417;border-color:var(--line)}
body.home .tile:hover{border-color:var(--gold)}
body.home .opcard .logo,
body.home table.cmp .op-logo{background:#fff}

/* ============================================================
   Editorial H2 styling across all pages (excludes the H1, which
   sits in the hero outside <main>). Big bold Manrope + a small
   gold auto-number, matching the homepage section headings.
   ============================================================ */
body.home main{counter-reset:h2c}
body.home main h2{
  counter-increment:h2c;
  display:flex;align-items:baseline;gap:.5em;flex-wrap:wrap;
  font-size:clamp(1.7rem,3.6vw,2.7rem);font-weight:800;letter-spacing:-.02em;
  line-height:1.08;color:#fff;border-bottom:0;padding:0;margin:1.5em 0 .55em;
}
body.home main h2::before{
  content:counter(h2c,decimal-leading-zero);
  color:var(--gold);font-size:.42em;font-weight:700;letter-spacing:0;line-height:1;
}
body.home main h2#faq{margin-top:1.5em}
@media(max-width:680px){
  body.home main h2{font-size:clamp(1.5rem,6.5vw,2rem);gap:.4em}
}
