/* =====================================================================
   Acceso Digital AR, stylesheet
   Palette: rose-mint (accent #E63946, secondary #A8DADC, bg #FFF6F7)
   Type: Zilla Slab (display) + Inter (body)
   Layout: two-column hero-aside with side-rail-right nav
   ===================================================================== */

*, *::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; }

:root {
  --space-xs: 9px;
  --space-sm: 14px;
  --space-md: 26px;
  --space-lg: 43px;
  --space-xl: 66px;
  --card-padding-y: 28px;
  --card-padding-x: 25px;
  --card-gap: 26px;
  --card-radius: 7px;
  --card-border-width: 1px;
  --card-min-height: 324px;
  --card-min-col-width: 269px;
  --btn-padding-y: 12px;
  --btn-padding-x: 19px;
  --btn-radius: 7px;
  --btn-gap-from-text: 24px;
  --grid-gap: 21px;
  --lh-heading: 1.22;
  --lh-body: 1.51;
  --ls-heading: 0.060em;

  --c-accent: #E63946;
  --c-accent-ink: #B01F2B;
  --c-secondary: #A8DADC;
  --c-secondary-ink: #4F8589;
  --c-bg: #FFF6F7;
  --c-surface: #FFFFFF;
  --c-text: #2C2A2D;
  --c-muted: #7C7A7E;
  --c-line: #E8DDE0;
  --c-peach: #FFB4A2;

  --siderail-w: 220px;
}

html, body { margin: 0; padding: 0; background: var(--c-bg); color: var(--c-text); }
body { font-family: 'Inter', system-ui, -apple-system, sans-serif; line-height: var(--lh-body); font-size: 16.5px; -webkit-font-smoothing: antialiased; }

h1, h2, h3, h4 { font-family: 'Zilla Slab', Georgia, serif; font-weight: 700; line-height: var(--lh-heading); letter-spacing: -0.005em; color: var(--c-text); margin: 0 0 var(--space-sm); }
h1 { font-size: clamp(2.1rem, 4.2vw, 3.4rem); }
h2 { font-size: clamp(1.65rem, 2.8vw, 2.35rem); }
h3 { font-size: 1.22rem; }
h4 { font-size: 0.92rem; letter-spacing: var(--ls-heading); text-transform: uppercase; color: var(--c-muted); font-family: 'Inter', sans-serif; font-weight: 600; }
p { margin: 0 0 var(--space-sm); }
a { color: var(--c-accent-ink); text-decoration: underline; text-underline-offset: 3px; }
a:hover { color: var(--c-accent); }
code { font-family: ui-monospace, 'SF Mono', Menlo, monospace; font-size: 0.88em; background: #F4E6E8; padding: 1px 5px; border-radius: 3px; }

/* ---------- Layout shell + siderail ---------- */
.shell { display: block; }

@media (min-width: 980px) {
  .shell { display: grid; grid-template-columns: 1fr var(--siderail-w); align-items: start; }
  .main { grid-column: 1; min-width: 0; }
  .siderail { grid-column: 2; position: sticky; top: 0; height: 100vh; overflow-y: auto; }
}

.siderail {
  background: var(--c-surface);
  border-left: 1px solid var(--c-line);
  padding: var(--space-lg) var(--space-md);
  display: flex; flex-direction: column; gap: var(--space-md);
  font-size: 0.93rem;
}
.siderail__brand { display: flex; align-items: center; gap: 12px; }
.siderail__mark { width: 38px; height: 38px; border-radius: 8px; background: var(--c-accent); color: var(--c-bg); font-family: 'Zilla Slab', serif; font-weight: 700; font-size: 22px; display: grid; place-items: center; }
.siderail__name { font-family: 'Zilla Slab', serif; font-weight: 700; line-height: 1.1; font-size: 1.05rem; }
.siderail__nav { display: flex; flex-direction: column; gap: 4px; border-top: 1px solid var(--c-line); padding-top: var(--space-md); }
.siderail__nav a { text-decoration: none; color: var(--c-text); padding: 8px 10px; border-radius: 5px; font-weight: 500; letter-spacing: 0.01em; transition: background .15s, color .15s; }
.siderail__nav a:hover { background: var(--c-bg); color: var(--c-accent); }
.siderail__chip { margin-top: auto; background: var(--c-secondary); color: var(--c-secondary-ink); padding: 8px 12px; border-radius: 999px; font-weight: 600; font-size: 0.82rem; text-align: center; letter-spacing: 0.04em; text-transform: uppercase; }

@media (max-width: 979px) {
  .siderail { border-left: 0; border-bottom: 1px solid var(--c-line); height: auto; position: static; padding: var(--space-md); }
  .siderail__nav { flex-direction: row; flex-wrap: wrap; padding-top: var(--space-sm); }
  .siderail__chip { align-self: flex-start; }
}

.main { padding: 0 var(--space-md) var(--space-xl); }
@media (min-width: 980px) { .main { padding: 0 var(--space-lg) var(--space-xl); } }

/* ---------- Buttons ---------- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: var(--btn-padding-y) var(--btn-padding-x); border-radius: var(--btn-radius); font-weight: 600; text-decoration: none; border: 1px solid transparent; cursor: pointer; transition: transform .1s ease, box-shadow .15s, background .15s, color .15s; font-size: 0.98rem; line-height: 1.1; }
.btn--primary { background: var(--c-accent); color: #fff; box-shadow: 0 2px 0 rgba(176,31,43,.25), 0 4px 14px rgba(230,57,70,.18); }
.btn--primary:hover { background: var(--c-accent-ink); color: #fff; transform: translateY(-1px); }
.btn--ghost { background: transparent; color: var(--c-text); border-color: var(--c-line); }
.btn--ghost:hover { background: var(--c-surface); border-color: var(--c-accent); }
.btn--text { background: transparent; color: var(--c-accent-ink); padding: 8px 4px; border-radius: 0; border-bottom: 1px solid transparent; }
.btn--text:hover { border-bottom-color: var(--c-accent); color: var(--c-accent); }
.btn--lg { padding: 16px 26px; font-size: 1.02rem; }
.btn--sm { padding: 9px 14px; font-size: 0.9rem; }

/* ---------- Age modal ---------- */
.age-modal { position: fixed; inset: 0; background: rgba(44,42,45,0.72); backdrop-filter: blur(4px); z-index: 1000; display: grid; place-items: center; padding: var(--space-md); }
.age-modal[hidden] { display: none; }
.age-modal__card { background: var(--c-surface); max-width: 480px; width: 100%; border-radius: 12px; padding: var(--space-lg); text-align: center; box-shadow: 0 20px 60px rgba(0,0,0,.25); border: 1px solid var(--c-line); }
.age-modal__badge { display: inline-block; background: var(--c-accent); color: #fff; font-family: 'Zilla Slab', serif; font-weight: 700; font-size: 1.4rem; padding: 6px 18px; border-radius: 999px; margin-bottom: var(--space-sm); letter-spacing: 0.05em; }
.age-modal__fine { font-size: 0.85rem; color: var(--c-muted); margin-top: var(--space-sm); }
.age-modal__actions { display: flex; gap: 12px; justify-content: center; margin-top: var(--space-md); flex-wrap: wrap; }

/* ---------- Cookie banner ---------- */
.cookie-banner { position: fixed; left: 0; right: 0; bottom: 0; z-index: 900; background: var(--c-text); color: var(--c-bg); padding: var(--space-sm) var(--space-md); box-shadow: 0 -4px 20px rgba(0,0,0,.18); }
.cookie-banner__inner { max-width: 1100px; margin: 0 auto; display: flex; gap: var(--space-md); align-items: center; justify-content: space-between; flex-wrap: wrap; }
.cookie-banner p { margin: 0; font-size: 0.9rem; max-width: 640px; }
.cookie-banner a { color: var(--c-secondary); }
.cookie-banner__actions { display: flex; gap: 10px; }
.cookie-banner .btn--ghost { color: var(--c-bg); border-color: rgba(255,255,255,0.35); }
.cookie-banner .btn--ghost:hover { background: rgba(255,255,255,0.08); }

/* ---------- Hero ---------- */
.hero { position: relative; margin: var(--space-md) 0 0; border-radius: 14px; overflow: hidden; }
.hero__bg { position: absolute; inset: 0; background:
  linear-gradient(135deg, #E63946 0%, #FFB4A2 45%, #FFF6F7 100%),
  url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'><g fill='none' stroke='%23E63946' stroke-opacity='0.22' stroke-width='1.2' stroke-linecap='round'><path d='M15 20 l0 10 M10 25 l10 0 M13 22 l4 6 M13 28 l4 -6'/><path d='M85 45 l0 12 M79 51 l12 0 M81 47 l8 8 M81 55 l8 -8'/><path d='M40 85 l0 10 M35 90 l10 0 M38 87 l4 6 M38 93 l4 -6'/><path d='M100 100 l0 10 M95 105 l10 0'/></g></svg>");
  background-blend-mode: multiply, normal;
  background-size: auto, 120px 120px;
}
.hero__inner { position: relative; padding: clamp(var(--space-lg), 7vw, 96px) clamp(var(--space-md), 5vw, var(--space-xl)); max-width: 820px; }
.hero__eyebrow { font-size: 0.82rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--c-accent-ink); font-weight: 600; margin-bottom: var(--space-sm); }
.hero__title { color: var(--c-text); margin-bottom: var(--space-md); }
.hero__title em { font-style: italic; color: var(--c-accent-ink); }
.hero__sub { font-size: 1.08rem; color: var(--c-text); max-width: 620px; margin-bottom: var(--space-md); line-height: 1.55; }
.hero__foot { margin-top: var(--space-md); font-size: 0.82rem; color: var(--c-muted); }

.chips { list-style: none; padding: 0; margin: 0 0 var(--space-md); display: flex; flex-wrap: wrap; gap: 8px; }
.chip { background: var(--c-secondary); color: var(--c-secondary-ink); padding: 7px 14px; border-radius: 999px; font-size: 0.85rem; font-weight: 500; letter-spacing: 0.01em; border: 1px solid rgba(79,133,137,0.18); }

/* ---------- Squiggle divider ---------- */
.squiggle { margin: var(--space-xl) 0; max-width: 100%; opacity: 0.55; }
.squiggle svg { width: 100%; height: 18px; }

/* ---------- Trust strip ---------- */
.trust { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: var(--grid-gap); margin: var(--space-lg) 0; padding: var(--space-md); background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 10px; }
.trust__item { display: flex; flex-direction: column; gap: 6px; align-items: flex-start; padding: var(--space-sm); }
.trust__num { font-family: 'Zilla Slab', serif; font-weight: 700; font-size: 2.1rem; color: var(--c-accent); line-height: 1; }
.trust__lbl { font-size: 0.88rem; color: var(--c-muted); line-height: 1.35; }

/* ---------- Section head ---------- */
.section-head { max-width: 780px; margin-bottom: var(--space-lg); }
.section-head__kicker { display: inline-block; font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-accent-ink); font-weight: 600; margin-bottom: var(--space-sm); }
.section-head h2 { margin-bottom: var(--space-sm); }
.section-head p { color: var(--c-muted); font-size: 1.02rem; max-width: 680px; }
.metric { color: var(--c-accent); font-style: italic; }

/* ---------- Brand cards (hero + 2 mini) ---------- */
.brands { margin-top: var(--space-lg); }

.bcard { background: var(--c-surface); border: var(--card-border-width) solid var(--c-line); border-radius: var(--card-radius); overflow: hidden; box-shadow: 0 1px 0 rgba(44,42,45,0.02), 0 6px 24px rgba(44,42,45,0.06); }

.bcard--hero { display: grid; grid-template-columns: 1fr; margin-bottom: var(--card-gap); min-height: var(--card-min-height); gap: var(--card-gap); }
@media (min-width: 860px) { .bcard--hero { grid-template-columns: 320px 1fr; } }

.bcard__banner { background: linear-gradient(155deg, var(--c-accent) 0%, var(--c-peach) 100%); padding: var(--space-md); display: flex; flex-direction: column; gap: var(--space-sm); justify-content: space-between; color: #fff; position: relative; min-height: 200px; }
.bcard__banner--mint { background: linear-gradient(155deg, var(--c-secondary) 0%, #CFE9EA 100%); color: var(--c-secondary-ink); min-height: 140px; }
.bcard__rank { font-family: 'Zilla Slab', serif; font-size: 1.6rem; font-weight: 700; letter-spacing: 0.04em; }
.bcard__logo { background: #fff; padding: 14px 18px; border-radius: 6px; display: inline-flex; align-items: center; justify-content: center; max-width: 220px; gap: var(--card-gap); }
.bcard__logo img { max-height: 48px; width: auto; }
.bcard__score { display: flex; flex-direction: column; align-items: flex-start; gap: var(--card-gap); }
.score { font-family: 'Zilla Slab', serif; font-size: 2.8rem; font-weight: 700; line-height: 1; }
.score span { font-size: 1rem; opacity: 0.75; margin-left: 4px; }
.score--sm { font-size: 1.8rem; color: var(--c-accent); }
.score--sm span { font-size: 0.8rem; color: var(--c-muted); }
.score__lbl { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.1em; opacity: 0.9; margin-top: 4px; }

.bcard__body { padding: var(--card-padding-y) var(--card-padding-x); display: flex; flex-direction: column; gap: var(--space-sm); }
.bcard__body h3 { margin: 0; }
.bcard__body p { color: var(--c-text); line-height: 1.55; }

.bcard__meta { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: var(--space-xs); }
.tag { display: inline-block; background: var(--c-bg); border: 1px solid var(--c-line); color: var(--c-text); padding: 4px 10px; border-radius: 4px; font-size: 0.8rem; font-weight: 500; }
.tag--license { background: var(--c-secondary); border-color: rgba(79,133,137,0.3); color: var(--c-secondary-ink); font-weight: 600; }

.fact { display: grid; grid-template-columns: 130px 1fr; gap: 6px var(--space-sm); margin: var(--space-sm) 0; font-size: 0.92rem; }
.fact dt { color: var(--c-muted); font-weight: 500; }
.fact dd { margin: 0; color: var(--c-text); }

.bcard__ctas { display: flex; gap: var(--space-sm); align-items: center; margin-top: auto; padding-top: var(--btn-gap-from-text); flex-wrap: wrap; }
.bcard__verified { margin-top: var(--space-xs); font-family: ui-monospace, Menlo, monospace; font-size: 0.78rem; color: var(--c-muted); display: flex; align-items: center; gap: 6px; }
.bcard__verified .dot { width: 7px; min-height: 7px; border-radius: 50%; background: #3CB371; display: inline-block; animation: pulse 2.4s ease-in-out infinite; }
.bcard__verified .ts { color: var(--c-accent-ink); font-weight: 600; transition: color .2s; }
.bcard:hover .bcard__verified .ts { color: var(--c-accent); }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.45; } }

.bcard__grid { display: grid; grid-template-columns: 1fr; gap: var(--card-gap); }
@media (min-width: 760px) { .bcard__grid { grid-template-columns: repeat(2, minmax(var(--card-min-col-width), 1fr)); } }
.bcard--mini { display: flex; flex-direction: column; min-height: var(--card-min-height); gap: var(--card-gap); }
.bcard--mini .bcard__row { display: flex; justify-content: space-between; align-items: baseline; gap: var(--space-sm); margin-bottom: var(--space-xs); }
.bcard--mini .bcard__row h3 { margin: 0; }

.brands__footnote { margin-top: var(--space-md); font-size: 0.88rem; color: var(--c-muted); font-style: italic; max-width: 720px; }

/* ---------- Methodology ---------- */
.method__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-md); }
.method__step { display: grid; grid-template-columns: 80px 1fr; gap: var(--space-md); padding: var(--space-md); background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--card-radius); border-left: 4px solid var(--c-accent); }
.method__num { font-family: 'Zilla Slab', serif; font-weight: 700; font-size: 3rem; color: var(--c-accent); line-height: 1; }
.method__body h3 { margin-bottom: 6px; }
.method__body p { color: var(--c-text); margin: 0; }
@media (max-width: 600px) { .method__step { grid-template-columns: 1fr; } .method__num { font-size: 2.2rem; } }

.worked-example { margin-top: var(--space-lg); padding: var(--space-md); background: var(--c-secondary); border-radius: var(--card-radius); color: var(--c-secondary-ink); }
.worked-example h4 { color: var(--c-secondary-ink); margin-bottom: 8px; }
.worked-example p { margin: 0; color: #2a4e51; }

/* ---------- Marco ---------- */
.marco__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); align-items: start; }
@media (min-width: 820px) { .marco__grid { grid-template-columns: 1.4fr 1fr; } }
.marco__lead p { color: var(--c-text); font-size: 1.02rem; }
.marco__others { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--card-radius); padding: var(--space-md); }
.marco__others h3 { margin-bottom: var(--space-sm); }
.marco__others ul { list-style: none; padding: 0; margin: 0 0 var(--space-sm); display: flex; flex-direction: column; gap: 7px; font-size: 0.94rem; }
.marco__others li { padding-left: 16px; position: relative; }
.marco__others li::before { content: '→'; position: absolute; left: 0; color: var(--c-accent); }
.marco__note { font-size: 0.86rem; color: var(--c-muted); font-style: italic; margin: 0; }

/* ---------- KYC ---------- */
.kyc__list { list-style: none; padding: 0; margin: 0 0 var(--space-lg); display: grid; grid-template-columns: 1fr; gap: var(--space-sm); }
@media (min-width: 760px) { .kyc__list { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.kyc__list li { display: grid; grid-template-columns: 50px 1fr; gap: var(--space-sm); padding: var(--space-md); background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--card-radius); }
.kyc__num { width: 40px; height: 40px; border-radius: 50%; background: var(--c-accent); color: #fff; display: grid; place-items: center; font-family: 'Zilla Slab', serif; font-weight: 700; font-size: 1.2rem; }
.kyc__list h3 { margin-bottom: 4px; font-size: 1.08rem; }
.kyc__list p { margin: 0; color: var(--c-muted); font-size: 0.94rem; }
.kyc__timeline { padding: var(--space-md); background: var(--c-secondary); border-radius: var(--card-radius); color: var(--c-secondary-ink); font-size: 0.96rem; }
.kyc__timeline strong { color: var(--c-text); }
.kyc__timeline code { background: rgba(255,255,255,0.6); color: var(--c-secondary-ink); }

/* ---------- FAQ ---------- */
.faq__tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: var(--space-md); border-bottom: 1px solid var(--c-line); padding-bottom: var(--space-xs); }
.faq__tab { background: transparent; border: 1px solid transparent; padding: 10px 18px; border-radius: 6px 6px 0 0; font-weight: 600; color: var(--c-muted); cursor: pointer; font-size: 0.95rem; letter-spacing: 0.01em; transition: all .15s; }
.faq__tab:hover { color: var(--c-text); }
.faq__tab.is-active { background: var(--c-surface); border-color: var(--c-line); border-bottom-color: var(--c-surface); color: var(--c-accent-ink); margin-bottom: -1px; }
.faq__panels { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 0 var(--card-radius) var(--card-radius) var(--card-radius); padding: var(--space-md); }
.faq__panel { display: none; }
.faq__panel.is-active { display: block; }
.faq__panel dl { margin: 0; }
.faq__panel dt { font-family: 'Zilla Slab', serif; font-weight: 700; font-size: 1.08rem; margin-top: var(--space-md); margin-bottom: 6px; color: var(--c-text); }
.faq__panel dt:first-child { margin-top: 0; }
.faq__panel dd { margin: 0 0 var(--space-sm) 0; color: var(--c-text); line-height: 1.6; padding-left: var(--space-sm); border-left: 2px solid var(--c-secondary); }

/* ---------- Compromiso ---------- */
.commit__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
@media (min-width: 820px) { .commit__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
.commit__grid > div { padding: var(--space-md); background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--card-radius); }
.commit__grid h3 { margin-bottom: var(--space-xs); }
.commit__grid p { color: var(--c-text); margin: 0; font-size: 0.96rem; }
.clean-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: 0.94rem; }
.clean-list li { padding-left: 20px; position: relative; }
.clean-list li::before { content: '✓'; position: absolute; left: 0; color: var(--c-accent); font-weight: 700; }

/* ---------- Footer masthead ---------- */
.masthead { background: #1F1D1F; color: #E8DDE0; padding: var(--space-xl) var(--space-md); margin-top: var(--space-xl); }
.masthead--mini { padding: var(--space-lg) var(--space-md); }
.masthead__top { max-width: 1200px; margin: 0 auto var(--space-lg); border-bottom: 1px solid rgba(255,255,255,0.1); padding-bottom: var(--space-lg); }
.masthead__brand { display: flex; align-items: center; gap: var(--space-sm); margin-bottom: var(--space-sm); }
.masthead__logo { width: 52px; height: 52px; border-radius: 8px; background: var(--c-accent); color: #fff; display: grid; place-items: center; font-family: 'Zilla Slab', serif; font-weight: 700; font-size: 1.8rem; }
.masthead__name { font-family: 'Zilla Slab', serif; font-weight: 700; font-size: 1.5rem; color: #fff; letter-spacing: 0.01em; }
.masthead__tag { font-size: 0.9rem; color: var(--c-secondary); letter-spacing: 0.02em; font-style: italic; }
.masthead__lead { max-width: 700px; color: rgba(232,221,224,0.78); font-size: 0.96rem; margin: var(--space-sm) 0 0; }
.masthead__cols { max-width: 1200px; margin: 0 auto var(--space-lg); display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
@media (min-width: 720px) { .masthead__cols { grid-template-columns: repeat(4, 1fr); } }
.masthead__cols h4 { color: var(--c-secondary); margin-bottom: var(--space-sm); }
.masthead__cols ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.masthead__cols a { color: #E8DDE0; text-decoration: none; font-size: 0.94rem; }
.masthead__cols a:hover { color: var(--c-accent); }
.masthead__cols address { font-style: normal; color: rgba(232,221,224,0.82); font-size: 0.94rem; line-height: 1.6; }

.regulators { max-width: 1200px; margin: 0 auto var(--space-lg); display: flex; flex-wrap: wrap; gap: var(--space-md); align-items: center; justify-content: flex-start; padding: var(--space-md) 0; border-top: 1px solid rgba(255,255,255,0.1); border-bottom: 1px solid rgba(255,255,255,0.1); }
.regulators a { display: inline-flex; align-items: center; padding: 6px 10px; background: transparent; border: none; border-radius: 4px; transition: background .15s; }
.regulators a:hover { background: rgba(255,255,255,0.06); }
.regulators img { max-height: 56px; width: auto; background: transparent; padding: 0; border: none; opacity: 0.92; }
.regulators a:hover img { opacity: 1; }

.masthead__legal { max-width: 1200px; margin: 0 auto; font-size: 0.85rem; color: rgba(232,221,224,0.7); line-height: 1.6; }
.masthead__legal p { margin: 0 0 var(--space-xs); }
.masthead__legal strong { color: #fff; }
.masthead__legal a { color: var(--c-secondary); }

/* ---------- Error / menores ---------- */
.error-page { min-height: 70vh; display: grid; place-items: center; padding: var(--space-xl) var(--space-md); background:
  linear-gradient(135deg, #E63946 0%, #FFB4A2 45%, #FFF6F7 100%);
}
.error-page__inner { max-width: 560px; text-align: center; background: rgba(255,255,255,0.92); backdrop-filter: blur(8px); padding: var(--space-lg); border-radius: 14px; box-shadow: 0 20px 60px rgba(0,0,0,.12); }
.error-page__code { font-family: 'Zilla Slab', serif; font-weight: 700; font-size: 5rem; color: var(--c-accent); line-height: 1; margin-bottom: var(--space-sm); }
.error-page__badge { display: inline-block; background: var(--c-accent); color: #fff; font-family: 'Zilla Slab', serif; font-weight: 700; font-size: 1.4rem; padding: 8px 22px; border-radius: 999px; margin-bottom: var(--space-md); }
.error-page__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: var(--space-md); }

/* ---------- Brand subpage ---------- */
.brand-page { max-width: 920px; margin: 0 auto; padding: var(--space-lg) var(--space-md); }
.breadcrumb { font-size: 0.88rem; color: var(--c-muted); margin-bottom: var(--space-md); }
.breadcrumb a { color: var(--c-muted); }
.brand-hero { display: grid; grid-template-columns: 1fr; gap: var(--space-md); padding: var(--space-lg); background: var(--c-surface); border-radius: var(--card-radius); border: 1px solid var(--c-line); margin-bottom: var(--space-lg); align-items: center; }
@media (min-width: 680px) { .brand-hero { grid-template-columns: 200px 1fr auto; } }
.brand-hero__logo { background: #fff; padding: 20px; border-radius: 6px; display: grid; place-items: center; border: 1px solid var(--c-line); }
.brand-hero__logo img { max-height: 70px; }
.brand-hero__info h1 { font-size: 2.2rem; margin-bottom: 6px; }
.brand-hero__score { text-align: center; background: linear-gradient(155deg, var(--c-accent) 0%, var(--c-peach) 100%); color: #fff; padding: var(--space-md); border-radius: 6px; min-width: 140px; }
.brand-hero__score .score { font-size: 2.4rem; }
.brand-cta-box { margin: var(--space-md) 0; padding: var(--space-md); background: var(--c-secondary); border-radius: var(--card-radius); text-align: center; }
.brand-cta-box p { margin: 0 0 var(--space-sm); color: var(--c-secondary-ink); font-weight: 500; }
.ficha { display: grid; grid-template-columns: 180px 1fr; gap: 10px var(--space-md); margin: var(--space-md) 0; padding: var(--space-md); background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--card-radius); font-size: 0.95rem; }
.ficha dt { color: var(--c-muted); font-weight: 500; }
.ficha dd { margin: 0; color: var(--c-text); }
.contras { padding-left: 20px; }
.contras li { margin-bottom: 8px; color: var(--c-text); }

/* ---------- Policy pages ---------- */
.policy { max-width: 820px; margin: 0 auto; padding: var(--space-lg) var(--space-md); }
.policy h1 { margin-bottom: var(--space-sm); }
.policy .updated { color: var(--c-muted); font-size: 0.9rem; margin-bottom: var(--space-lg); }
.policy h2 { margin-top: var(--space-lg); font-size: 1.4rem; }
.policy h3 { margin-top: var(--space-md); font-size: 1.1rem; }
.policy ul, .policy ol { padding-left: 22px; }
.policy li { margin-bottom: 8px; }

/* ---------- Utility ---------- */
[hidden] { display: none !important; }
