:root {
  /* palette — editorial: deep navy + crimson + cream */
  --c-ink:        #14213D;
  --c-ink-soft:  #2B3A5C;
  --c-bg:         #F4EFE6;
  --c-paper:      #FBF7EE;
  --c-rule:       #1A2A4A;
  --c-accent:     #B5283A;
  --c-accent-dk:  #8B1C2A;
  --c-mute:       #6E7B95;
  --c-ok:         #2F6B4F;
  --c-warn:       #C68A2D;

  /* typography */
  --f-display: "Crimson Pro", "Source Serif 4", Georgia, "Times New Roman", serif;
  --f-body:    "Inter", "Helvetica Neue", Arial, sans-serif;
  --f-mono:    "JetBrains Mono", ui-monospace, "SFMono-Regular", Consolas, monospace;
  --lh-h:      1.12;
  --lh-b:      1.55;
  --ls-h:      -0.012em;

  /* layout tokens */
  --space-xs:   6px;
  --space-sm:   12px;
  --space-md:   20px;
  --space-lg:   34px;
  --space-xl:   64px;
  --grid-gap:           28px;
  --card-gap:           18px;
  --card-padding-y:     26px;
  --card-padding-x:     28px;
  --card-radius:        4px;
  --card-min-height:    280px;
  --card-min-col-width: 280px;
  --btn-padding-y:      12px;
  --btn-padding-x:      22px;
  --btn-radius:         2px;
  --btn-gap-from-text:  20px;
  --rule-w: 1px;
}

/* ---------- Global reset ---------- */
*, *::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: var(--f-body);
  color: var(--c-ink);
  background: var(--c-bg);
  line-height: var(--lh-b);
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--c-accent); text-decoration: none; border-bottom: 1px solid currentColor; }
a:hover { color: var(--c-accent-dk); }
ul { list-style: none; padding: 0; margin: 0; }
h1, h2, h3, h4 {
  font-family: var(--f-display);
  font-weight: 700;
  line-height: var(--lh-h);
  letter-spacing: var(--ls-h);
  margin: 0 0 var(--space-sm);
  color: var(--c-ink);
}
h1 { font-size: 3.2rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.35rem; }
h4 { font-size: 1.05rem; }
p  { margin: 0 0 var(--space-sm); }

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

/* ---------- Header ---------- */
.site-header {
  background: var(--c-ink);
  color: var(--c-bg);
  padding: var(--space-sm) 0;
  border-bottom: 3px double var(--c-bg);
}
.site-header__row {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-md);
}
.brand {
  display: inline-flex; align-items: baseline; gap: 10px;
  color: var(--c-bg); border-bottom: none;
  font-family: var(--f-display);
}
.brand__no { font-family: var(--f-mono); font-size: .82rem; color: var(--c-warn); letter-spacing: .04em; }
.brand__name { font-size: 1.45rem; font-weight: 700; letter-spacing: -.01em; }
.brand__name em { font-style: normal; color: var(--c-warn); }
.site-nav { display: flex; gap: var(--space-md); flex-wrap: wrap; }
.site-nav a { color: var(--c-bg); border-bottom: none; font-size: .92rem; opacity: .82; }
.site-nav a:hover { opacity: 1; color: var(--c-warn); }
.age-pill {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--c-accent); color: var(--c-paper); font-weight: 700; font-size: .92rem;
}

/* ---------- Hero ---------- */
.hero {
  position: relative; overflow: hidden;
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40'><path d='M0 20h40M20 0v40' stroke='%2314213D' stroke-opacity='0.06' stroke-width='1'/></svg>"),
    linear-gradient(180deg, var(--c-paper) 0%, var(--c-bg) 100%);
  padding: var(--space-xl) 0 var(--space-lg);
  border-bottom: var(--rule-w) solid var(--c-rule);
}
.hero__grid { display: grid; grid-template-columns: minmax(0, 7fr) minmax(0, 5fr); gap: var(--grid-gap); align-items: end; }
.hero__eyebrow {
  font-family: var(--f-mono); font-size: .8rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--c-accent); margin-bottom: var(--space-md);
}
.hero h1 { margin-bottom: var(--space-md); }
.hero h1 em { font-style: normal; color: var(--c-accent); }
.hero__lede { font-size: 1.18rem; color: var(--c-ink-soft); max-width: 60ch; }
.hero__chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: var(--space-md); }
.chip {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--c-paper); border: var(--rule-w) solid var(--c-rule);
  font-family: var(--f-mono); font-size: .78rem; padding: 6px 12px; color: var(--c-ink);
}
.chip::before {
  content: ""; display: inline-block; width: 6px; height: 6px; background: var(--c-ok); border-radius: 50%;
}
.hero__cta { margin-top: var(--space-lg); display: flex; gap: var(--space-sm); flex-wrap: wrap; }
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: var(--btn-padding-y) var(--btn-padding-x);
  border-radius: var(--btn-radius);
  font-weight: 600; font-size: .96rem; cursor: pointer;
  border: var(--rule-w) solid var(--c-rule); background: transparent; color: var(--c-ink);
  text-decoration: none;
  transition: background .15s, color .15s;
}
.btn--primary { background: var(--c-accent); color: var(--c-paper); border-color: var(--c-accent); }
.btn--primary:hover { background: var(--c-accent-dk); border-color: var(--c-accent-dk); color: var(--c-paper); }
.btn--ghost { background: var(--c-paper); }
.btn--ghost:hover { background: var(--c-ink); color: var(--c-paper); }
.btn--small { padding: 8px 14px; font-size: .85rem; }

/* hero side panel — "fact card" */
.hero__panel {
  background: var(--c-ink); color: var(--c-paper);
  padding: var(--space-md) var(--space-md);
  border: var(--rule-w) solid var(--c-rule);
}
.hero__panel-title { font-family: var(--f-mono); font-size: .78rem; letter-spacing: .14em;
                     text-transform: uppercase; color: var(--c-warn); margin-bottom: 10px; }
.hero__panel dl { display: grid; grid-template-columns: 1fr; gap: 8px; margin: 0; }
.hero__panel dt { font-family: var(--f-mono); font-size: .76rem; color: var(--c-mute); letter-spacing: .08em; text-transform: uppercase; }
.hero__panel dd { margin: 0 0 6px; font-size: .96rem; color: var(--c-paper); }

/* ---------- Section base ---------- */
.section { padding: var(--space-xl) 0; border-bottom: var(--rule-w) solid var(--c-rule); }
.section--paper { background: var(--c-paper); }
.section__head {
  display: grid; grid-template-columns: 90px 1fr; gap: var(--space-md); align-items: end;
  margin-bottom: var(--space-lg);
}
.section__num {
  font-family: var(--f-mono); font-size: .82rem; letter-spacing: .08em;
  color: var(--c-accent); border-top: 2px solid var(--c-accent); padding-top: 6px;
}
.section__title { display: flex; flex-direction: column; gap: 6px; }
.section__title h2 { margin: 0; }
.section__title p { color: var(--c-ink-soft); margin: 0; max-width: 65ch; font-size: 1.02rem; }

/* ---------- 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);
  padding: var(--card-padding-y) var(--card-padding-x);
  background: var(--c-paper);
  border: var(--rule-w) solid var(--c-rule);
  border-radius: var(--card-radius);
  min-height: var(--card-min-height);
  position: relative;
  transition: transform .15s ease, box-shadow .15s ease;
}
.brand-card:hover { transform: translateY(-2px); box-shadow: 4px 4px 0 var(--c-rule); }
.brand-card__rank {
  position: absolute; top: -12px; left: -12px;
  width: 38px; height: 38px;
  background: var(--c-ink); color: var(--c-warn);
  font-family: var(--f-mono); font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  border: var(--rule-w) solid var(--c-rule);
}
.brand-card__head {
  display: grid; grid-template-columns: 1fr auto; align-items: center; gap: var(--space-sm);
  padding-bottom: var(--space-sm); border-bottom: var(--rule-w) solid var(--c-rule);
}
.brand-card__logo { max-height: 38px; max-width: 160px; object-fit: contain; }
.brand-card__score {
  font-family: var(--f-display); font-weight: 700; font-size: 1.85rem; color: var(--c-accent); line-height: 1;
  display: flex; align-items: baseline; gap: 4px;
}
.brand-card__score-scale { font-family: var(--f-mono); font-size: .7rem; color: var(--c-mute); letter-spacing: .08em; }
.brand-card__metric { font-family: var(--f-mono); font-size: .72rem; letter-spacing: .12em;
                       color: var(--c-mute); text-transform: uppercase; }
.brand-card__lic {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--f-mono); font-size: .76rem; color: var(--c-ok);
  background: rgba(47, 107, 79, 0.1); padding: 4px 10px; border-radius: 2px; align-self: flex-start;
}
.brand-card__pills { display: flex; flex-wrap: wrap; gap: 6px; }
.brand-card__pills li {
  font-size: .82rem; padding: 4px 10px; background: var(--c-bg);
  border: var(--rule-w) solid rgba(20, 33, 61, 0.16);
}
.brand-card__bonus { font-size: .92rem; color: var(--c-ink-soft); margin-top: auto; }
.brand-card__cta { display: flex; gap: 10px; margin-top: var(--btn-gap-from-text); }
.brand-card__cta .btn { flex: 1; justify-content: center; }

/* ---------- Methodology — flex with grid-template lock ---------- */
.method-list { display: flex; flex-direction: column; gap: var(--card-gap); }
.method-list li {
  display: grid; grid-template-columns: 64px 1fr;
  gap: var(--space-md);
  background: var(--c-paper);
  border-left: 4px solid var(--c-accent);
  padding: var(--card-padding-y) var(--card-padding-x);
}
.method-list__num {
  grid-column: 1; grid-row: 1 / span 2;
  font-family: var(--f-display); font-weight: 700; font-size: 2.4rem; color: var(--c-accent); line-height: 1;
}
.method-list h3 { grid-column: 2; min-width: 0; margin: 0 0 6px; }
.method-list p  { grid-column: 2; min-width: 0; margin: 0; color: var(--c-ink-soft); }

/* ---------- Marco regulatorio ---------- */
.marco { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr); gap: var(--grid-gap); align-items: start; }
.marco p { font-size: 1.04rem; }
.marco__regulators {
  background: var(--c-paper); border: var(--rule-w) solid var(--c-rule);
  padding: var(--card-padding-y) var(--card-padding-x);
}
.marco__regulators h3 { margin: 0 0 var(--space-sm); font-size: 1.05rem;
                        font-family: var(--f-mono); text-transform: uppercase;
                        letter-spacing: .1em; color: var(--c-accent); }
.marco__regulators ul { display: grid; grid-template-columns: 1fr; gap: 8px; }
.marco__regulators li {
  display: grid; grid-template-columns: 110px 1fr; gap: 12px;
  font-size: .92rem; padding: 6px 0;
  border-bottom: 1px dotted rgba(20, 33, 61, 0.18);
}
.marco__regulators li:last-child { border-bottom: none; }
.marco__regulators li b { font-family: var(--f-mono); font-size: .78rem;
                           letter-spacing: .06em; color: var(--c-ink); }

/* ---------- KYC ---------- */
.kyc-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--grid-gap); }
.kyc-card {
  background: var(--c-paper); border: var(--rule-w) solid var(--c-rule);
  padding: var(--card-padding-y) var(--card-padding-x);
  display: flex; flex-direction: column; gap: var(--card-gap);
}
.kyc-card__doc {
  font-family: var(--f-mono); font-size: .8rem; color: var(--c-accent);
  letter-spacing: .08em; text-transform: uppercase;
}
.kyc-card h3 { margin: 0; font-size: 1.15rem; }
.kyc-card p { margin: 0; color: var(--c-ink-soft); font-size: .94rem; }
.kyc-card__time {
  font-family: var(--f-mono); font-size: .82rem; color: var(--c-warn);
  border-top: 1px dashed var(--c-rule); padding-top: 10px; margin-top: auto;
}

/* ---------- FAQ ---------- */
.faq { max-width: 820px; }
.faq details {
  border-top: var(--rule-w) solid var(--c-rule);
  padding: var(--space-md) 0;
}
.faq details:last-child { border-bottom: var(--rule-w) solid var(--c-rule); }
.faq summary {
  cursor: pointer; font-family: var(--f-display);
  font-size: 1.18rem; font-weight: 700; color: var(--c-ink);
  list-style: none; display: flex; justify-content: space-between; gap: var(--space-md);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-family: var(--f-mono); color: var(--c-accent); font-weight: 400; font-size: 1.4rem; }
.faq details[open] summary::after { content: "−"; }
.faq details p { margin: var(--space-sm) 0 0; color: var(--c-ink-soft); }

/* ---------- Compromiso editorial ---------- */
.commit {
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--grid-gap);
  background: var(--c-ink); color: var(--c-paper);
  padding: var(--card-padding-y) var(--card-padding-x);
}
.commit h3 { color: var(--c-warn); margin-bottom: var(--space-sm); }
.commit p { color: var(--c-paper); margin: 0 0 var(--space-sm); }
.commit__line {
  display: flex; align-items: baseline; gap: 8px;
  font-family: var(--f-mono); font-size: .85rem; color: var(--c-warn);
}

/* ---------- Footer ---------- */
.site-footer {
  background: var(--c-ink); color: var(--c-paper);
  padding: var(--space-xl) 0 var(--space-md);
}
.footer__top { display: grid; grid-template-columns: minmax(0, 2fr) minmax(0, 1fr) minmax(0, 1fr); gap: var(--grid-gap); }
.footer__col h4 {
  font-family: var(--f-mono); font-size: .8rem; letter-spacing: .12em;
  color: var(--c-warn); text-transform: uppercase; margin: 0 0 var(--space-sm);
}
.footer__col p, .footer__col li { color: var(--c-paper); font-size: .92rem; }
.footer__col a { color: var(--c-paper); border-bottom-color: rgba(244, 239, 230, 0.2); }
.footer__col a:hover { color: var(--c-warn); }
.footer__col ul { display: flex; flex-direction: column; gap: 6px; }

.footer__rule {
  height: 1px; background: rgba(244, 239, 230, 0.18); margin: var(--space-lg) 0 var(--space-md);
}

.footer-logos {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--space-md);
  align-items: center;
  padding: var(--space-md) 0;
}
.footer-logos a {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 8px; border-radius: 4px;
  border-bottom: none;
  transition: background .15s, transform .15s;
}
.footer-logos a:hover { background: rgba(244, 239, 230, 0.08); transform: translateY(-1px); }
.footer-logos img {
  max-height: 56px; width: auto;
  background: transparent; padding: 0; border: none;
  opacity: 0.92; filter: brightness(1.05);
}
.footer-logos a:hover img { opacity: 1; }

.footer__legal { color: rgba(244, 239, 230, 0.78); font-size: .82rem; line-height: 1.55; }
.footer__legal p { margin: 0 0 6px; }
.footer__legal strong { color: var(--c-warn); }

/* ---------- Age modal ---------- */
.age-modal {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(20, 33, 61, 0.92);
  display: flex; align-items: center; justify-content: center; padding: var(--space-md);
}
.age-modal.hidden { display: none; }
.age-modal__panel {
  background: var(--c-paper); color: var(--c-ink);
  max-width: 480px; width: 100%; padding: var(--space-lg);
  border-top: 6px solid var(--c-accent); text-align: center;
}
.age-modal__pill {
  display: inline-flex; width: 64px; height: 64px; align-items: center; justify-content: center;
  background: var(--c-accent); color: var(--c-paper);
  font-family: var(--f-display); font-weight: 700; font-size: 1.7rem;
  border-radius: 50%; margin-bottom: var(--space-md);
}
.age-modal h2 { margin: 0 0 var(--space-sm); }
.age-modal p  { margin: 0 0 var(--space-md); color: var(--c-ink-soft); }
.age-modal__btns { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.age-modal__law {
  margin-top: var(--space-md); font-family: var(--f-mono); font-size: .76rem;
  color: var(--c-mute); letter-spacing: .04em;
}

/* ---------- Cookie banner ---------- */
.cookie-banner {
  position: fixed; left: var(--space-md); right: var(--space-md); bottom: var(--space-md);
  z-index: 9000;
  background: var(--c-ink); color: var(--c-paper);
  padding: var(--space-md);
  border: var(--rule-w) solid var(--c-warn);
  display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: var(--space-md); align-items: center;
}
.cookie-banner[hidden] { display: none; }
.cookie-banner p { margin: 0; font-size: .92rem; color: var(--c-paper); }
.cookie-banner a { color: var(--c-warn); }
.cookie-banner__btns { display: flex; gap: 8px; flex-wrap: wrap; }

/* ---------- Brand sub-pages ---------- */
.brand-page__hero {
  background: var(--c-ink); color: var(--c-paper);
  padding: var(--space-xl) 0;
  border-bottom: var(--rule-w) solid var(--c-rule);
}
.brand-page__hero h1 { color: var(--c-paper); }
.brand-page__hero h1 em { color: var(--c-warn); font-style: normal; }
.brand-page__lede { color: var(--c-paper); opacity: .85; max-width: 60ch; }
.brand-page__top {
  display: grid; grid-template-columns: minmax(0, 2fr) minmax(0, 1fr); gap: var(--grid-gap); align-items: center;
}
.brand-page__logo {
  max-height: 84px; max-width: 220px; background: var(--c-paper);
  padding: var(--space-md); border: var(--rule-w) solid var(--c-warn);
}
.brand-page__score {
  font-family: var(--f-display); font-weight: 700; font-size: 4rem; color: var(--c-warn); line-height: 1;
  display: flex; align-items: baseline; gap: 8px;
}
.brand-page__score small { font-family: var(--f-mono); font-size: .9rem; color: var(--c-paper); }
.brand-page__body section { padding: var(--space-lg) 0; border-bottom: var(--rule-w) solid var(--c-rule); }
.brand-page__body h2 { margin-top: 0; }
.brand-spec {
  display: grid; grid-template-columns: 200px 1fr; gap: var(--space-md);
  padding: 10px 0; border-bottom: 1px dotted rgba(20, 33, 61, 0.16);
}
.brand-spec b { font-family: var(--f-mono); font-size: .78rem; letter-spacing: .08em;
                color: var(--c-ink); text-transform: uppercase; }
.brand-spec span { color: var(--c-ink-soft); }
.brand-cta { display: flex; gap: var(--space-sm); flex-wrap: wrap; margin-top: var(--space-md); }

/* ---------- Policy pages ---------- */
.policy-body { padding: var(--space-xl) 0; max-width: 820px; margin: 0 auto; }
.policy-body h1 { margin-bottom: var(--space-md); }
.policy-body h2 { margin-top: var(--space-lg); }
.policy-body ul { list-style: disc; padding-left: 1.4em; margin-bottom: var(--space-sm); }
.policy-body ul li { margin-bottom: 6px; }
.policy-body__meta { font-family: var(--f-mono); font-size: .82rem; color: var(--c-mute); margin-bottom: var(--space-md); }

/* ---------- Responsive ---------- */
@media (max-width: 880px) {
  h1 { font-size: 2.4rem; }
  h2 { font-size: 1.55rem; }
  .hero__grid, .marco, .commit, .brand-page__top { grid-template-columns: 1fr; }
  .footer__top { grid-template-columns: 1fr; }
  .section__head { grid-template-columns: 1fr; gap: var(--space-sm); }
  .section__num { padding-top: 4px; }
  .brand-spec { grid-template-columns: 1fr; gap: 4px; }
  .commit { padding: var(--space-md); }
  .site-nav { display: none; }
  .cookie-banner { grid-template-columns: 1fr; }
}
