/* ft-hidden-guard v1 */
[hidden]{display:none!important;}
/* ===========================================================
   Lucky Top Choice, The Night Desk
   Dark aubergine reading-room, warm amber pools, mint signal.
   =========================================================== */

*, *::before, *::after { box-sizing: border-box; min-width: 0; }
img, svg, video { max-width: 100%; height: auto; display: block; }
button, input, select, textarea { font: inherit; }
html { scroll-behavior: smooth; }
body { margin: 0; }

:root {
  /* ===== required spacing tokens ===== */
  --space-xs: 8px;
  --space-sm: 13px;
  --space-md: 28px;
  --space-lg: 50px;
  --space-xl: 95px;
  --card-padding-y: 30px;
  --card-padding-x: 27px;
  --card-gap: 20px;
  --card-radius: 13px;
  --card-border-width: 2px;
  --card-min-height: 346px;
  --card-min-col-width: 270px;
  --btn-padding-y: 14px;
  --btn-padding-x: 26px;
  --btn-radius: 11px;
  --btn-gap-from-text: 18px;
  --grid-gap: 25px;
  --lh-heading: 1.14;
  --lh-body: 1.67;
  --ls-heading: -0.010em;

  /* ===== palette ===== */
  --aubergine-900: #1a0e1c;     /* page bg */
  --aubergine-800: #241327;     /* surface */
  --aubergine-700: #2e1933;     /* raised */
  --aubergine-600: #3a2042;     /* hairline base */
  --aubergine-500: #4a2c55;
  --amber-400:    #f3b264;      /* warm pool of light */
  --amber-300:    #ffc98a;
  --mint-400:     #a7e8d2;      /* cold signal, ratings, verified */
  --mint-500:     #74cdb1;
  --ink-100:      #f4ecde;      /* warm cream body text */
  --ink-200:      #d8ccbb;
  --ink-400:      #9a8c84;      /* muted */
  --ink-500:      #6f6064;
  --rule:         rgba(244,236,222,0.16);
  --rule-strong:  rgba(244,236,222,0.34);
}

body {
  background: var(--aubergine-900);
  color: var(--ink-100);
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  font-size: 17px;
  line-height: var(--lh-body);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ----- typography helpers ----- */
.h1, h1.review__h1, .restricted__h1 {
  font-family: "Barlow Condensed", "Oswald", "Inter", sans-serif;
  font-weight: 600;
  font-size: clamp(40px, 6vw, 78px);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-heading);
  text-transform: uppercase;
  color: var(--ink-100);
  margin: 0 0 var(--space-md);
}

.h2 {
  font-family: "Barlow Condensed", "Oswald", "Inter", sans-serif;
  font-weight: 600;
  font-size: clamp(28px, 3.5vw, 44px);
  line-height: 1.1;
  letter-spacing: 0;
  text-transform: uppercase;
  color: var(--ink-100);
  margin: 0 0 var(--space-md);
}

.eyebrow {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mint-400);
  margin: 0 0 var(--space-sm);
}

.lede {
  font-size: 19px;
  line-height: 1.6;
  color: var(--ink-100);
}

a { color: var(--amber-300); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--amber-400); }

/* ===== AGE GATE ===== */
.age-gate {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(10, 5, 12, 0.92);
  backdrop-filter: blur(8px);
  padding: var(--space-md);
}
.age-gate:not([hidden]) {
  display: flex; align-items: center; justify-content: center;
}
.age-gate__panel {
  background: var(--aubergine-800);
  border: 1px solid var(--rule-strong);
  border-radius: var(--card-radius);
  padding: var(--card-padding-y) var(--card-padding-x);
  max-width: 540px;
  width: 100%;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(243,178,100,0.08) inset;
  position: relative;
}
.age-gate__panel::before {
  content:"";
  position: absolute; top:-1px; left:0; right:0; height:3px;
  background: linear-gradient(90deg, var(--amber-400), transparent 60%);
  border-radius: var(--card-radius) var(--card-radius) 0 0;
}
.age-gate__eyebrow {
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--mint-400); margin: 0 0 var(--space-sm);
}
.age-gate h2 {
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 600; font-size: 36px; line-height: 1.1;
  text-transform: uppercase; margin: 0 0 var(--space-sm);
  color: var(--ink-100);
}
.age-gate__body { color: var(--ink-200); margin: 0 0 var(--space-md); }
.age-gate__actions { display: flex; gap: var(--space-sm); flex-wrap: wrap; }
.age-gate__foot {
  margin-top: var(--space-md); font-size: 13px; color: var(--ink-400);
  border-top: 1px solid var(--rule); padding-top: var(--space-sm);
}

/* ===== BUTTONS ===== */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: var(--btn-padding-y) var(--btn-padding-x);
  border-radius: var(--btn-radius);
  font-weight: 600; font-size: 14px;
  letter-spacing: 0.08em; text-transform: uppercase;
  border: 1.5px solid transparent;
  cursor: pointer; text-decoration: none;
  transition: background-color .18s ease, color .18s ease, border-color .18s ease, transform .18s ease;
}
.btn--amber {
  background: var(--amber-400); color: #2a1608; border-color: var(--amber-400);
}
.btn--amber:hover { background: var(--amber-300); border-color: var(--amber-300); color: #2a1608; }
.btn--mint {
  background: transparent; color: var(--mint-400); border-color: var(--mint-500);
}
.btn--mint:hover { background: rgba(167,232,210,0.08); color: var(--mint-400); }
.btn--ghost {
  background: transparent; color: var(--ink-100); border-color: var(--rule-strong);
}
.btn--ghost:hover { border-color: var(--ink-200); }
.btn--lg { padding: 18px 32px; font-size: 15px; }

/* ===== RISK STRIP ===== */
.risk-strip {
  background: #0d0710;
  color: var(--ink-200);
  border-bottom: 1px solid var(--rule-strong);
  padding: 10px var(--space-md);
  display: flex; align-items: center; gap: var(--space-sm); flex-wrap: wrap;
  font-size: 13px;
}
.risk-strip__mark {
  display: inline-block; padding: 3px 8px;
  background: var(--amber-400); color: #2a1608;
  font-weight: 700; font-size: 11px; letter-spacing: 0.1em;
  border-radius: 3px;
}
.risk-strip__text { flex: 1 1 auto; min-width: 200px; }
.risk-strip__link { color: var(--mint-400); margin-left: auto; }

/* ===== MASTHEAD ===== */
.masthead {
  border-bottom: 1px solid var(--rule);
  background: var(--aubergine-900);
}
.masthead__inner {
  max-width: 1240px; margin: 0 auto;
  padding: var(--space-md);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); flex-wrap: wrap;
}
.wordmark {
  display: inline-flex; align-items: baseline; gap: 12px;
  text-decoration: none; color: var(--ink-100);
}
.wordmark__dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--amber-400);
  box-shadow: 0 0 24px rgba(243,178,100,0.55);
  align-self: center;
}
.wordmark__name {
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 600; font-size: 22px;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.wordmark__sub {
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--mint-400); border-left: 1px solid var(--rule-strong); padding-left: 12px;
}
.masthead__nav { display: flex; gap: var(--space-md); flex-wrap: wrap; }
.masthead__nav a {
  color: var(--ink-200);
  font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase;
  text-decoration: none;
}
.masthead__nav a:hover { color: var(--amber-300); }

/* ===== HERO ===== */
.hero {
  position: relative; overflow: hidden;
  background: var(--aubergine-900);
  border-bottom: 1px solid var(--rule);
}
.hero__glow {
  position: absolute; pointer-events: none;
  top: -10%; left: -10%; width: 70%; aspect-ratio: 1;
  background: radial-gradient(circle at center, rgba(243,178,100,0.32), rgba(243,178,100,0.08) 35%, transparent 65%);
  filter: blur(20px);
}
.hero__inner {
  position: relative; z-index: 1;
  max-width: 1240px; margin: 0 auto;
  padding: var(--space-xl) var(--space-md);
}
.hero__meta-top {
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--space-md); flex-wrap: wrap;
  margin-bottom: var(--space-lg);
  font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase;
}
.hero__edition { color: var(--ink-400); }
.hero__verified {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--mint-400);
  border: 1px solid rgba(167,232,210,0.3);
  padding: 7px 14px; border-radius: 999px;
}
.verified-dot {
  width: 7px; height: 7px; background: var(--mint-400); border-radius: 50%;
}
.hero__h1 {
  font-family: "Barlow Condensed", "Oswald", sans-serif;
  font-weight: 600;
  font-size: clamp(46px, 8.2vw, 116px);
  line-height: 0.96;
  letter-spacing: var(--ls-heading);
  text-transform: uppercase;
  margin: 0 0 var(--space-md);
}
.hero__h1-em { color: var(--amber-400); }
.hero__rule {
  border: 0;
  height: 1px;
  background: var(--mint-400);
  width: 120px;
  margin: var(--space-md) 0;
}
.hero__deck {
  max-width: 720px;
  font-size: 19px;
  color: var(--ink-200);
  line-height: 1.65;
  margin: 0 0 var(--space-lg);
}
.hero__strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-md);
  margin: 0;
  padding-top: var(--space-md);
  border-top: 1px solid var(--rule);
}
.hero__strip div { margin: 0; }
.hero__strip dt {
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-400); margin-bottom: 6px;
}
.hero__strip dd {
  margin: 0;
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 600; font-size: 22px; text-transform: uppercase;
  color: var(--ink-100);
}

/* ===== SECTIONS ===== */
.section { padding: var(--space-xl) var(--space-md); }
.section--dim { background: var(--aubergine-800); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.section__inner { max-width: 1240px; margin: 0 auto; }

.two-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
}
@media (min-width: 880px) {
  .two-col { grid-template-columns: 280px 1fr; gap: var(--space-xl); }
}
.col-side .h2 { font-size: clamp(26px, 3vw, 34px); }
.col-main p + p { margin-top: var(--space-md); }

.section-head { max-width: 760px; margin-bottom: var(--space-lg); }
.section-head__deck { color: var(--ink-200); margin: var(--space-sm) 0 0; font-size: 17px; }

/* ===== OPERATOR CARDS ===== */
.op-grid {
  list-style: none; margin: 0; padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--card-min-col-width), 1fr));
  gap: var(--grid-gap);
}
.op-card {
  position: relative;
  background: var(--aubergine-900);
  border: var(--card-border-width) solid var(--aubergine-600);
  border-radius: var(--card-radius);
  padding: var(--card-padding-y) var(--card-padding-x);
  min-height: var(--card-min-height);
  display: flex; flex-direction: column;
  gap: var(--card-gap);
  transition: border-color .25s ease, transform .25s ease, box-shadow .25s ease;
  overflow: hidden;
}
.op-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; min-height: 110px;
  background: radial-gradient(ellipse at 30% 0%, rgba(243,178,100,0.18), transparent 70%);
  pointer-events: none;
}
.op-card:hover { border-color: var(--amber-400); transform: translateY(-2px); }
.op-card__rank {
  position: absolute; top: var(--space-sm); right: var(--space-md);
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 600; font-size: 38px;
  color: var(--aubergine-500);
  letter-spacing: -0.02em;
}
.op-card__head {
  position: relative;
  display: flex; align-items: center; gap: var(--space-sm);
  margin-bottom: var(--space-md);
}
.op-card__logo {
  background: #f7f1e4;
  padding: 8px 10px;
  border-radius: 6px;
  width: 86px; min-height: 48px;
  display: flex; align-items: center; justify-content: center;
  gap: var(--card-gap);
  flex-shrink: 0;
}
.op-card__logo img { max-height: 32px; width: auto; object-fit: contain; }
.op-card__title h3 {
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 600; font-size: 26px; line-height: 1.05;
  text-transform: uppercase;
  margin: 0 0 4px; color: var(--ink-100);
}
.op-card__vibe { margin: 0; font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-400); }
.op-card__score {
  display: flex; align-items: baseline; gap: 10px;
  margin-bottom: var(--space-sm);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--rule);
}
.op-card__stars { color: var(--mint-400); letter-spacing: 2px; font-size: 16px; }
.op-card__num { font-family: "Barlow Condensed", sans-serif; font-size: 24px; font-weight: 600; color: var(--ink-100); }
.op-card__num em { font-style: normal; color: var(--ink-400); font-size: 14px; }
.op-card__blurb { color: var(--ink-200); font-size: 15px; line-height: 1.55; margin: 0 0 var(--space-sm); }
.op-card__feats {
  list-style: none; padding: 0; margin: 0 0 var(--space-sm);
  display: flex; flex-direction: column; gap: 4px;
  font-size: 13px; color: var(--ink-200);
}
.op-card__feats li::before {
  content: "—"; color: var(--mint-400);
  display: inline-block; width: 18px;
}
.op-card__bonus {
  font-size: 13px; color: var(--amber-300);
  border-left: 2px solid var(--amber-400);
  padding: 8px 0 8px 12px;
  margin: 0 0 var(--space-sm);
  font-style: italic;
}
.op-card__licence {
  font-size: 12px; color: var(--ink-400); margin: 0 0 var(--space-md);
  letter-spacing: 0.02em;
}
.op-card__licence a { color: var(--mint-400); }
.op-card__cta {
  margin-top: auto;
  display: flex; flex-wrap: wrap; gap: 10px;
  padding-top: var(--btn-gap-from-text);
}
.op-card__cta .btn { flex: 1 1 auto; }
.op-card__age { margin: 10px 0 0; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-500); text-align: center; }

/* ===== RG LIST ===== */
.rg-list {
  margin: 0; padding: 0;
  display: grid; gap: var(--space-md);
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.rg-list > div {
  border-top: 1px solid var(--rule-strong);
  padding-top: var(--space-sm);
}
.rg-list dt {
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 600; text-transform: uppercase; font-size: 18px;
  letter-spacing: 0.04em; color: var(--ink-100);
  margin-bottom: 6px;
}
.rg-list dd { margin: 0; font-size: 15px; color: var(--ink-200); line-height: 1.55; }

/* ===== FAQ ===== */
.faq { display: grid; gap: var(--space-sm); max-width: 880px; }
.faq details {
  border-top: 1px solid var(--rule-strong);
  padding: var(--space-sm) 0;
}
.faq details:last-child { border-bottom: 1px solid var(--rule-strong); }
.faq summary {
  list-style: none; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-sm);
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 600; font-size: 22px; text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--ink-100);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+"; color: var(--amber-400); font-size: 28px; line-height: 1;
  transition: transform .25s ease;
}
.faq details[open] summary::after { content: "–"; }
.faq p { margin: var(--space-sm) 0 0; color: var(--ink-200); max-width: 760px; }

/* ===== REVIEW PAGES ===== */
.review { max-width: 980px; margin: 0 auto; padding: 0 var(--space-md) var(--space-xl); }
.review__hero {
  position: relative; overflow: hidden;
  margin: 0 0 var(--space-lg);
  border-radius: var(--card-radius);
  background: var(--aubergine-800);
  border: 1px solid var(--rule-strong);
}
.review__hero::before {
  content:"";
  position: absolute; top: -30%; left: -10%; width: 60%; aspect-ratio: 1;
  background: radial-gradient(circle, rgba(243,178,100,0.28), transparent 65%);
  filter: blur(15px);
}
.review__hero-inner { position: relative; padding: var(--space-lg) var(--space-md); max-width: 1240px; margin: 0 auto; }
@media (min-width: 720px) { .review__hero-inner { padding: var(--space-xl) var(--space-lg); } }

.crumb { font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-400); margin: 0 0 var(--space-md); }
.crumb a { color: var(--mint-400); }
.review__hero-flex { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--space-lg); flex-wrap: wrap; }
.review__sub { color: var(--ink-200); font-size: 17px; max-width: 580px; margin: 0 0 var(--space-md); }
.review__score { display: flex; align-items: baseline; gap: 10px; margin: 0 0 var(--space-sm); }
.review__licence { font-size: 13px; color: var(--ink-400); margin: 0 0 var(--space-md); }
.review__licence a { color: var(--mint-400); }
.review__keys { list-style: none; padding: 0; margin: 0 0 var(--space-md); }
.review__keys li { padding: 4px 0; color: var(--ink-200); font-size: 14px; }
.review__keys li::before { content: "·"; color: var(--amber-400); margin-right: 10px; font-weight: 700; }
.review__age { display: block; margin-top: 10px; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-400); }
.review__hero-mark {
  background: #f7f1e4;
  border-radius: var(--btn-radius);
  padding: var(--space-md);
  width: 200px; height: 100px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.review__hero-mark img { max-width: 100%; max-height: 60px; object-fit: contain; }

.review__sec {
  border-top: 1px solid var(--rule);
  padding: var(--space-lg) 0;
}
.review__sec h2 {
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 600; font-size: 32px; line-height: 1.1;
  text-transform: uppercase; margin: 0 0 var(--space-md);
  display: flex; align-items: center; gap: 12px;
}
.review__sec .icon { font-size: 22px; }
.review__sec p { margin: 0 0 var(--space-sm); color: var(--ink-200); }

.chips {
  list-style: none; padding: 0; margin: 0 0 var(--space-sm);
  display: flex; flex-wrap: wrap; gap: 8px;
}
.chips li {
  background: var(--aubergine-800);
  border: 1px solid var(--rule-strong);
  color: var(--ink-100);
  padding: 6px 12px; border-radius: 4px;
  font-size: 13px; letter-spacing: 0.04em;
}

.proscons { display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
@media (min-width: 720px) { .proscons { grid-template-columns: 1fr 1fr; } }
.proscons h3 {
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 600; font-size: 18px; text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 var(--space-sm); padding-bottom: 8px;
  border-bottom: 1px solid var(--rule-strong);
}
.proscons > div:first-child h3 { color: var(--mint-400); border-bottom-color: var(--mint-500); }
.proscons > div:last-child h3 { color: var(--amber-300); border-bottom-color: var(--amber-400); }
.proscons ul { padding-left: 18px; margin: 0; color: var(--ink-200); }
.proscons li { margin-bottom: 6px; }

.rg-tools { padding-left: 18px; margin: 0; color: var(--ink-200); }
.rg-tools li { margin-bottom: 8px; }
.rg-tools strong { color: var(--ink-100); }

.review__final-cta {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: var(--space-lg) 0 0;
  text-align: center;
}

/* ===== POLICY / UNDERAGE ===== */
.policy, .restricted { padding: var(--space-xl) var(--space-md); }
.policy__inner, .restricted__inner { max-width: 760px; margin: 0 auto; }
.policy h1 { margin-bottom: var(--space-sm); }
.policy__updated { font-size: 13px; color: var(--ink-400); letter-spacing: 0.1em; text-transform: uppercase; margin: 0 0 var(--space-lg); }
.policy h2 {
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 600; font-size: 24px; text-transform: uppercase;
  margin: var(--space-lg) 0 var(--space-sm);
  color: var(--ink-100);
}
.policy p { color: var(--ink-200); margin: 0 0 var(--space-sm); }
.policy code {
  background: var(--aubergine-700); padding: 2px 6px; border-radius: 4px;
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 14px; color: var(--amber-300);
}
.restricted__h1 { font-size: clamp(38px, 5.5vw, 64px); }

/* ===== FOOTER ===== */
.site-foot {
  background: #0d0710;
  border-top: 1px solid var(--rule-strong);
  padding: var(--space-xl) var(--space-md) var(--space-lg);
  margin-top: var(--space-xl);
}
.site-foot__inner { max-width: 1240px; margin: 0 auto; }

.trust-panel {
  border: 1px solid var(--rule-strong);
  border-radius: var(--card-radius);
  padding: var(--space-lg) var(--space-md);
  background: linear-gradient(160deg, rgba(243,178,100,0.04), transparent 60%);
  margin-bottom: var(--space-lg);
}
.trust-panel__eyebrow {
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--mint-400); margin: 0 0 var(--space-md); text-align: center;
}
.trust-panel__logos {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-md);
  align-items: center;
  margin-bottom: var(--space-md);
}
.trust-logo {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  text-decoration: none; color: var(--ink-200);
  padding: var(--space-sm);
}
.trust-logo__plate {
  background: #ffffff;
  border-radius: 6px;
  padding: 12px 16px;
  display: flex; align-items: center; justify-content: center;
  min-height: 60px; min-width: 120px;
}
.trust-logo__plate img { max-height: 36px; width: auto; object-fit: contain; }
.trust-logo__label {
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-400); text-align: center;
}
.trust-logo:hover .trust-logo__label { color: var(--mint-400); }
.trust-panel__line {
  border-top: 1px solid var(--rule);
  padding-top: var(--space-md); margin: var(--space-md) 0 0;
  font-size: 13px; color: var(--ink-400); line-height: 1.6;
  max-width: 880px; margin-left: auto; margin-right: auto; text-align: center;
}
.trust-panel__line a { color: var(--amber-300); }

.foot-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-lg);
}
.foot-grid__label {
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--mint-400); margin: 0 0 var(--space-sm);
  border-bottom: 1px solid var(--rule); padding-bottom: 6px;
}
.foot-grid__addr { margin: 0; font-size: 14px; color: var(--ink-200); line-height: 1.6; }
.foot-grid__links { list-style: none; padding: 0; margin: 0; }
.foot-grid__links li { margin-bottom: 6px; }
.foot-grid__links a { color: var(--ink-200); text-decoration: none; font-size: 14px; }
.foot-grid__links a:hover { color: var(--amber-300); }

/* ===== COOKIE BANNER ===== */
.cookie-banner {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 9000;
  background: var(--aubergine-800);
  border-top: 2px solid var(--amber-400);
  padding: var(--space-md);
  box-shadow: 0 -20px 40px rgba(0,0,0,0.5);
}
.cookie-banner:not([hidden]) { display: block; }
.cookie-banner__inner {
  max-width: 1240px; margin: 0 auto;
  display: flex; align-items: center; gap: var(--space-md); flex-wrap: wrap;
  justify-content: space-between;
}
.cookie-banner__copy { flex: 1 1 380px; min-width: 280px; }
.cookie-banner__title {
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 600; font-size: 18px; text-transform: uppercase;
  margin: 0 0 6px; color: var(--ink-100);
}
.cookie-banner__copy p:last-child { font-size: 14px; color: var(--ink-200); margin: 0; }
.cookie-banner__actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* ===== motion (subtle) ===== */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(12px); transition: opacity .6s ease, transform .6s ease; }
  .reveal.is-in { opacity: 1; transform: none; }
}

/* ===== small screens ===== */
@media (max-width: 600px) {
  .hero__inner { padding: var(--space-lg) var(--space-md); }
  .section { padding: var(--space-lg) var(--space-md); }
  .review__hero-mark { display: none; }
  .masthead__nav { gap: var(--space-sm); }
  .wordmark__sub { display: none; }
}

/* ========================================================================
   Post-build operator-CSS patch (manual fix 2026-05-25)
   ======================================================================== */

/* OPERATOR GRID — was auto-fill / minmax(270px) which collapsed to a
   single column on narrower viewports and stretched headings beyond the
   plate. Force exactly 2 columns ≥ 600px, single column on mobile. */
.op-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}
@media (max-width: 600px) {
  .op-grid { grid-template-columns: 1fr !important; }
}
/* prevent long words breaking out of the card on narrow widths */
.op-card,
.op-card__title h3,
.op-card__vibe,
.op-card__blurb,
.op-card__num {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* REGULATOR LOGOS — UKGC / GambleAware / GamCare / Gamstop logos are
   dark glyphs on transparent and need a WHITE plate (already the
   default `.trust-logo__plate { background:#ffffff }`).
   RAiG (Responsible Affiliates in Gambling) ships as a white wordmark
   on white background — without an explicit dark plate it disappears.
   Force a black plate just for the RAiG link. */
.trust-logo__plate:has(img[src*="raig"]) {
  background: #000000 !important;
}
