:root{
  --space-xs:6px;
  --space-sm:13px;
  --space-md:21px;
  --space-lg:38px;
  --space-xl:108px;
  --card-padding-y:23px;
  --card-padding-x:24px;
  --card-gap:19px;
  --card-radius:9px;
  --card-border-width:2px;
  --card-min-height:324px;
  --card-min-col-width:320px;
  --btn-padding-y:15px;
  --btn-padding-x:33px;
  --btn-radius:10px;
  --btn-gap-from-text:20px;
  --grid-gap:22px;
  --lh-heading:1.25;
  --lh-body:1.66;
  --ls-heading:0.030em;

  --accent:#5B2A4D;
  --accent-dark:#3F1D36;
  --gold:#D4AF37;
  --gold-dark:#A8872A;
  --bg:#FAF4ED;
  --bg-alt:#F2EADB;
  --ink:#2C1E2A;
  --ink-soft:#4A3744;
  --muted:#7A6E78;
  --line:#2C1E2A;
  --rule:#7A6E78;
}

*,*::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,body{margin:0;padding:0}
body{
  font-family:'DM Mono',ui-monospace,Menlo,Consolas,monospace;
  background:var(--bg);
  color:var(--ink);
  font-size:15px;
  line-height:var(--lh-body);
  -webkit-font-smoothing:antialiased;
}

a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{color:var(--accent-dark)}

h1,h2,h3,h4{font-family:'DM Mono',monospace;line-height:var(--lh-heading);letter-spacing:var(--ls-heading);color:var(--ink);margin:0 0 var(--space-md);font-weight:700}
h1{font-size:clamp(32px,5vw,48px)}
h2{font-size:clamp(24px,3.2vw,32px)}
h3{font-size:18px;letter-spacing:0.02em}
p{margin:0 0 var(--space-md);overflow-wrap:anywhere}
ul,ol,dl{margin:0 0 var(--space-md);padding:0}

.container{max-width:1180px;margin:0 auto;padding:0 var(--space-md)}

.section{padding:var(--space-xl) 0}
.section--alt{background:var(--bg-alt)}
.section__head{margin-bottom:var(--space-lg);max-width:760px}
.section__lead{color:var(--ink-soft);font-size:15px}

.rule-double{
  border:0;
  border-top:2px solid var(--line);
  border-bottom:2px solid var(--line);
  height:5px;
  margin:0;
  background:transparent;
}

.ascii-tag{
  font-family:'DM Mono',monospace;
  font-size:12px;
  font-weight:500;
  letter-spacing:0.08em;
  color:var(--accent);
  text-transform:uppercase;
  margin-bottom:var(--space-sm);
  display:inline-block;
}

.accent{color:var(--accent)}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-family:'DM Mono',monospace;
  font-weight:500;
  font-size:13px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:var(--btn-padding-y) var(--btn-padding-x);
  border-radius:var(--btn-radius);
  border:2px solid var(--ink);
  cursor:pointer;
  text-decoration:none;
  transition:transform .1s ease, background .15s ease, color .15s ease;
}
.btn--primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn--primary:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--bg)}
.btn--hero{border-color:var(--gold);background:var(--gold);color:var(--ink);margin-top:var(--btn-gap-from-text)}
.btn--hero:hover{background:var(--bg);color:var(--ink);border-color:var(--bg)}
.btn--sm{padding:10px 18px;font-size:12px}

.btn-link{
  font-family:'DM Mono',monospace;
  font-size:13px;
  color:var(--accent);
  text-decoration:none;
  border-bottom:1px solid var(--accent);
  padding-bottom:2px;
  letter-spacing:0.04em;
}
.btn-link:hover{color:var(--accent-dark);border-color:var(--accent-dark)}

/* Header */
.site-header{
  background:var(--bg);
  border-bottom:2px solid var(--line);
  position:sticky;top:0;z-index:20;
}
.header__inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--space-md);
  padding:var(--space-sm) var(--space-md);
  min-height:60px;
}
.brand{display:inline-flex;align-items:center;gap:8px;text-decoration:none;color:var(--ink);font-weight:700}
.brand__prompt{color:var(--gold);font-weight:700}
.brand__name{font-size:15px;letter-spacing:0.04em}
.site-nav{display:flex;gap:var(--space-md);flex-wrap:wrap}
.site-nav a{color:var(--ink);text-decoration:none;font-size:13px;letter-spacing:0.04em}
.site-nav a:hover{color:var(--accent)}
.age-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border:2px solid var(--ink);border-radius:50%;
  font-size:12px;font-weight:700;background:var(--gold);color:var(--ink);
}
@media(max-width:820px){.site-nav{display:none}}

/* Hero */
.hero{
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16'><rect x='0' y='0' width='2' height='2' fill='%235B2A4D' fill-opacity='0.12'/></svg>"),
    linear-gradient(180deg, #5B2A4D 0%, #7A6E78 50%, #FAF4ED 100%);
  padding:var(--space-xl) 0;
  border-bottom:2px solid var(--line);
  color:#fff;
}
.hero__grid{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:var(--space-lg);
  align-items:start;
}
.hero__left h1{color:#fff;font-size:clamp(30px,4.6vw,48px);line-height:1.1}
.hero__left .ascii-tag{color:var(--gold)}
.hero__left .accent{color:var(--gold)}
.hero__sub{color:rgba(255,255,255,.92);font-size:15px;max-width:58ch;margin-bottom:var(--space-md)}
.hero__sub strong{color:var(--gold)}

.hero__right{display:flex;flex-direction:column;gap:var(--space-md)}
.hero__meta{
  border:2px solid rgba(255,255,255,.6);
  padding:var(--space-md);
  background:rgba(44,30,42,.28);
  backdrop-filter:blur(2px);
  border-radius:6px;
}
.meta-row{display:flex;justify-content:space-between;gap:var(--space-sm);padding:8px 0;border-bottom:1px dashed rgba(255,255,255,.25);font-size:13px}
.meta-row:last-child{border-bottom:none}
.meta-key{color:rgba(255,255,255,.7);letter-spacing:0.06em}
.meta-val{color:var(--gold);font-weight:500}
.hero__chips{display:flex;flex-direction:column;gap:var(--space-sm);font-size:13px;color:#fff}
.hero__chips span{border-left:3px solid var(--gold);padding-left:10px}

@media(max-width:820px){.hero__grid{grid-template-columns:1fr}}

/* Trust strip */
.trust-strip{background:var(--bg);padding:var(--space-lg) 0}
.trust-strip__inner{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:var(--grid-gap);
  text-align:center;
}
.trust-strip__inner > div{display:flex;flex-direction:column;gap:6px;padding:var(--space-sm);border:1px solid var(--line);border-radius:6px}
.t-num{font-size:22px;font-weight:700;color:var(--accent)}
.t-lbl{font-size:11px;letter-spacing:0.08em;color:var(--muted);text-transform:uppercase}

/* Brand cards */
.brand-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(var(--card-min-col-width),1fr));
  gap:var(--grid-gap);
}
.brand-card{
  display:flex;
  flex-direction:column;
  gap:var(--card-gap);
  border:var(--card-border-width) solid var(--line);
  border-radius:var(--card-radius);
  background:var(--bg);
  min-height:var(--card-min-height);
  overflow:hidden;
  position:relative;
}
.brand-card__banner{
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);
  padding:var(--space-lg) var(--card-padding-x);
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--card-gap);
  border-bottom:2px solid var(--line);
  min-height:110px;
}
.brand-card__logo{
  max-height:48px;width:auto;
  filter:brightness(0) invert(1);
  opacity:0.95;
}
.brand-card__rank{
  font-family:'DM Mono',monospace;
  font-size:28px;font-weight:700;color:var(--gold);
  letter-spacing:0.04em;
}
.brand-card__body{
  display:flex;flex-direction:column;
  gap:var(--card-gap);
  padding:var(--card-padding-y) var(--card-padding-x);
  flex:1 1 auto;min-width:0;
}
/* Brand-card head: STACK title above rating to avoid wrap-collision when brand
 * names vary in length (BetWarrior > Betsson > bet365). Horizontal layout in
 * narrow grid columns wraps inconsistently — stacked layout is uniform. */
.brand-card__head{display:flex;flex-direction:column;align-items:stretch;gap:var(--space-sm)}
.brand-card__head h3{margin:0;font-size:22px;min-width:0}
.rating{display:flex;flex-direction:row;align-items:baseline;text-align:left;flex-wrap:wrap;gap:6px;min-width:0}
.rating__lbl{flex-basis:100%;margin-top:2px}
.rating__num{font-size:24px;font-weight:700;color:var(--accent)}
.rating__scale{font-size:13px;color:var(--muted);margin-left:2px}
.rating__lbl{font-size:10px;letter-spacing:0.06em;color:var(--muted);text-transform:uppercase;margin-top:3px}

.pills{display:flex;flex-wrap:wrap;gap:6px}
.pill{
  font-size:11px;letter-spacing:0.05em;
  padding:4px 10px;border:1px solid var(--line);border-radius:3px;
  background:transparent;color:var(--ink);text-transform:uppercase;
}
.pill--lic{background:var(--gold);border-color:var(--gold-dark);color:var(--ink);font-weight:500}

.brand-card__blurb{font-size:13.5px;color:var(--ink-soft);margin:0}

.kv{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;font-size:12.5px;margin:0}
.kv dt{color:var(--muted);letter-spacing:0.04em;text-transform:uppercase;font-size:11px;align-self:center}
.kv dd{margin:0;color:var(--ink)}

.brand-card__footer{
  margin-top:auto;
  display:flex;flex-direction:column;gap:var(--space-sm);
  padding-top:var(--space-sm);
  border-top:1px dashed var(--rule);
}
.cta-pair{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-md)}
/* CTA-pair inside brand cards: stack vertically so wrap behaves uniformly across cards regardless of varying body content. */
.brand-card .cta-pair{flex-direction:column;align-items:stretch;gap:var(--space-sm)}
.brand-card .cta-pair .btn,
.brand-card .cta-pair .btn-link{width:100%;text-align:center;justify-content:center;min-width:0}
.brand-card .cta-pair .btn-link{padding:10px 0;border-bottom:none;border-top:1px dashed var(--rule)}
.verify-stamp{
  font-size:11px;letter-spacing:0.05em;color:var(--muted);
  font-family:'DM Mono',monospace;
}
.verify-stamp .cursor{display:inline-block;margin-left:2px;color:var(--accent);animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:0}}

/* Comparison table */
.table-wrap{overflow-x:auto;border:2px solid var(--line);border-radius:var(--card-radius);background:var(--bg)}
.compare{width:100%;border-collapse:collapse;font-size:13px;min-width:720px}
.compare th,.compare td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--rule)}
.compare th{background:var(--ink);color:var(--bg);font-weight:500;letter-spacing:0.04em;text-transform:uppercase;font-size:11px}
.compare tbody tr:last-child td{border-bottom:none}
.compare tbody tr:nth-child(even){background:var(--bg-alt)}
.compare td.num{font-weight:700;color:var(--accent);text-align:right}

/* Methodology */
.method{list-style:none;display:flex;flex-direction:column;gap:var(--space-md)}
.method li{
  border:2px solid var(--line);
  border-radius:var(--card-radius);
  padding:var(--card-padding-y) var(--card-padding-x);
  background:var(--bg);
}
.method__wrap{display:grid;grid-template-columns:70px 1fr;gap:var(--space-md);align-items:start}
.method__num{font-size:32px;font-weight:700;color:var(--accent);line-height:1;font-family:'DM Mono',monospace;grid-column:1;grid-row:1 / span 2}
.method__body{grid-column:2;min-width:0}
.method__body h3{margin:0 0 6px;font-size:16px}
.method__body p{margin:0;font-size:13.5px;color:var(--ink-soft)}

/* Marco regulatorio */
.two-col{display:grid;grid-template-columns:1.3fr 1fr;gap:var(--space-lg);align-items:start}
@media(max-width:820px){.two-col{grid-template-columns:1fr}}
.reg-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:var(--space-sm)}
.reg-list li{padding:10px 14px;border:1px solid var(--line);border-radius:4px;background:var(--bg);display:flex;justify-content:space-between;gap:var(--space-sm);flex-wrap:wrap;font-size:13px}
.tag{font-size:10px;padding:3px 8px;border-radius:3px;background:var(--bg-alt);letter-spacing:0.06em;text-transform:uppercase}
.tag--primary{background:var(--accent);color:#fff}

/* KYC */
.kyc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--grid-gap)}
.kyc-card{border:2px solid var(--line);border-radius:var(--card-radius);background:var(--bg);padding:var(--card-padding-y) var(--card-padding-x);display:flex;flex-direction:column;gap:var(--space-sm)}
.kyc-card__inner{display:flex;flex-direction:column;gap:var(--space-sm)}
.kyc-card h3{margin:0;font-size:16px}
.kyc-card p{margin:0;font-size:13px;color:var(--ink-soft)}
.kyc-note{margin-top:var(--space-lg);padding:var(--space-md);background:var(--gold);border:2px solid var(--line);border-radius:6px;font-size:14px;text-align:center}

/* FAQ */
.faq{display:flex;flex-direction:column;gap:var(--space-sm)}
.faq details{border:2px solid var(--line);border-radius:var(--card-radius);background:var(--bg);padding:var(--space-md) var(--card-padding-x)}
.faq summary{cursor:pointer;font-weight:500;font-size:14.5px;letter-spacing:0.02em;list-style:none}
.faq summary::before{content:"[+] ";color:var(--accent)}
.faq details[open] summary::before{content:"[−] "}
.faq details p{margin:var(--space-sm) 0 0;font-size:13.5px;color:var(--ink-soft)}

/* Commit */
.commit{border:2px solid var(--line);border-radius:var(--card-radius);padding:var(--card-padding-y) var(--card-padding-x);background:var(--bg)}
.commit p:last-child{margin-bottom:0}

/* Footer */
.site-footer{
  background:var(--ink);
  color:var(--bg);
  padding:var(--space-xl) 0 var(--space-lg);
  border-top:2px solid var(--line);
}
.site-footer a{color:var(--gold)}
.footer__top{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-lg)}
@media(max-width:820px){.footer__top{grid-template-columns:1fr}}
.footer__brand .brand{color:var(--bg)}
.footer__brand p{font-size:13px;color:rgba(250,244,237,.78)}
.footer__address{font-size:12.5px;color:rgba(250,244,237,.65)}
.footer__lead{font-size:12px;letter-spacing:0.08em;text-transform:uppercase;color:var(--gold);margin-bottom:var(--space-md)}
.footer-logos{display:flex;flex-wrap:wrap;gap:var(--space-md);align-items:center}
.footer-logos a{padding:6px 10px;border-radius:4px;transition:background .15s ease;display:inline-flex}
.footer-logos a:hover{background:rgba(255,255,255,0.06)}
.footer-logos img{
  max-height:56px;
  width:auto;
  background:transparent;
  padding:0;
  border:none;
  opacity:0.92;
  filter:brightness(1.05);
}
.footer__compliance{border-top:1px dashed rgba(250,244,237,.3);border-bottom:1px dashed rgba(250,244,237,.3);padding:var(--space-md) 0;margin-bottom:var(--space-md);font-size:13px}
.footer__compliance p{margin:0 0 6px}
.footer__compliance p:last-child{margin:0}
.footer__links{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-md);font-size:13px}
.footer__copy{font-size:12px;color:rgba(250,244,237,.55);letter-spacing:0.04em}

/* Age modal */
.age-modal{
  position:fixed;inset:0;z-index:100;
  background:rgba(44,30,42,.88);
  display:flex;align-items:center;justify-content:center;
  padding:var(--space-md);
}
.age-modal__box{
  background:var(--bg);
  border:3px solid var(--line);
  border-radius:var(--card-radius);
  max-width:480px;width:100%;
  padding:var(--space-lg);
}
.age-modal__header{margin-bottom:var(--space-sm)}
.age-modal__box h2{margin:0 0 var(--space-md);font-size:22px}
.age-modal__box p{font-size:14px;color:var(--ink-soft)}
.age-modal__law{font-size:12px;color:var(--accent);border-left:3px solid var(--gold);padding-left:10px}
.age-modal__actions{display:flex;gap:var(--space-sm);margin-top:var(--space-md);flex-wrap:wrap}

/* Cookie banner */
.cookie-banner{
  position:fixed;bottom:var(--space-md);left:var(--space-md);right:var(--space-md);
  background:var(--ink);color:var(--bg);
  border:2px solid var(--gold);border-radius:var(--card-radius);
  padding:var(--space-md);z-index:90;
  box-shadow:6px 6px 0 var(--accent);
}
.cookie-banner a{color:var(--gold)}
.cookie-banner__inner{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap;justify-content:space-between}
.cookie-banner p{margin:0;font-size:13px;flex:1 1 280px;min-width:0}
.cookie-banner__actions{display:flex;gap:var(--space-sm);align-items:center;flex-wrap:wrap}
.cookie-banner .btn--ghost{color:var(--bg);border-color:var(--bg)}
.cookie-banner .btn--ghost:hover{background:var(--bg);color:var(--ink)}

/* Generic page (brand + policy) */
.page{padding:var(--space-xl) 0}
.page h1{margin-bottom:var(--space-md)}
.page .lead{font-size:16px;color:var(--ink-soft);max-width:65ch}
.breadcrumb{font-size:12px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);margin-bottom:var(--space-md)}
.breadcrumb a{color:var(--accent);text-decoration:none}
.back-link{display:inline-block;margin-top:var(--space-lg);font-size:13px}

/* Brand page layout */
.brand-page__header{
  display:grid;grid-template-columns:auto 1fr;gap:var(--space-lg);
  align-items:center;padding:var(--card-padding-y) var(--card-padding-x);
  border:2px solid var(--line);border-radius:var(--card-radius);
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);
  color:#fff;margin-bottom:var(--space-lg);
}
.brand-page__header h1{color:#fff}
.brand-page__header img{max-height:60px;width:auto;filter:brightness(0) invert(1)}
.brand-page__rating{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);padding:var(--space-sm);border-radius:6px;display:inline-flex;gap:var(--space-md);align-items:baseline;margin-top:var(--space-sm)}
.brand-page__rating .n{font-size:28px;font-weight:700;color:var(--gold)}
.brand-page__rating .l{font-size:11px;letter-spacing:0.06em;color:rgba(255,255,255,.8);text-transform:uppercase}

.brand-grid-cols{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-lg);align-items:start}
@media(max-width:820px){.brand-grid-cols{grid-template-columns:1fr}}
.info-box{border:2px solid var(--line);border-radius:var(--card-radius);padding:var(--card-padding-y) var(--card-padding-x);background:var(--bg-alt);display:flex;flex-direction:column;gap:var(--card-gap)}
.info-box h3{margin:0;font-size:15px;letter-spacing:0.04em;text-transform:uppercase;color:var(--accent)}
.info-box dl{margin:0;display:grid;grid-template-columns:1fr;gap:8px}
.info-box dt{font-size:11px;color:var(--muted);letter-spacing:0.06em;text-transform:uppercase}
.info-box dd{margin:0;font-size:13.5px}
.brand-ext-cta{text-align:center;margin:var(--space-lg) 0;padding:var(--space-md);border:2px dashed var(--line);border-radius:var(--card-radius)}

/* Menores page */
.menores-box{max-width:540px;margin:0 auto;text-align:center;border:3px solid var(--line);border-radius:var(--card-radius);padding:var(--space-xl) var(--space-lg);background:var(--bg)}
.menores-box .ascii-tag{color:var(--accent)}

/* 404 */
.notfound{text-align:center;padding:var(--space-xl) 0}
.notfound__code{font-size:clamp(80px,16vw,160px);font-weight:700;color:var(--accent);line-height:1;margin:0}

/* Policy pages */
.policy h2{margin-top:var(--space-lg);font-size:20px;border-top:2px solid var(--line);padding-top:var(--space-md)}
.policy h3{margin-top:var(--space-md);font-size:16px}
.policy ul,.policy ol{padding-left:var(--space-md);color:var(--ink-soft)}
.policy li{margin-bottom:6px}
