/* ===== 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; }

:root{
  --space-xs: 6px;
  --space-sm: 16px;
  --space-md: 24px;
  --space-lg: 51px;
  --space-xl: 82px;
  --card-padding-y: 22px;
  --card-padding-x: 22px;
  --card-gap: 27px;
  --card-radius: 9px;
  --card-border-width: 1px;
  --card-min-height: 324px;
  --card-min-col-width: 278px;
  --btn-padding-y: 13px;
  --btn-padding-x: 24px;
  --btn-radius: 10px;
  --btn-gap-from-text: 24px;
  --grid-gap: 30px;
  --lh-heading: 1.19;
  --lh-body: 1.63;
  --ls-heading: 0.020em;

  --c-accent: #A0522D;
  --c-secondary: #264653;
  --c-bg: #FBF7F0;
  --c-text: #1F1A17;
  --c-muted: #736B5F;
  --c-line: #1F1A17;
  --c-paper: #F4EFE6;
}

html, body { background: var(--c-bg); color: var(--c-text); }
body{
  font-family: 'Roboto Mono', ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  line-height: var(--lh-body);
  font-size: 15px;
  margin: 0;
  padding-bottom: 56px; /* leave room for sticky bottom nav */
  overflow-x: hidden;
}

.wrap{ max-width: 1180px; margin: 0 auto; padding: 0 var(--space-md); }
.sr{ position:absolute; left:-9999px; }

/* ===== Typography ===== */
h1,h2,h3,h4{ line-height: var(--lh-heading); letter-spacing: var(--ls-heading); margin: 0 0 var(--space-sm); font-weight: 700; }
h1{ font-size: clamp(28px, 4.6vw, 46px); }
h2{ font-size: clamp(22px, 2.6vw, 30px); }
h3{ font-size: 17px; }
p{ margin: 0 0 var(--space-sm); }
code{ background: rgba(160,82,45,0.10); color: var(--c-accent); padding: 1px 6px; border: 1px dashed rgba(160,82,45,0.4); }
a{ color: var(--c-secondary); text-decoration: underline; text-underline-offset: 3px; }
a:hover{ color: var(--c-accent); }

/* ===== Buttons ===== */
.btn{
  display: inline-block;
  padding: var(--btn-padding-y) var(--btn-padding-x);
  border-radius: 0;
  border: 1px solid var(--c-line);
  background: var(--c-text);
  color: var(--c-bg);
  text-decoration: none;
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: transform .08s, background .15s;
}
.btn:hover{ transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--c-accent); }
.btn--primary{ background: var(--c-accent); color: #fff; border-color: var(--c-accent); }
.btn--primary:hover{ box-shadow: 4px 4px 0 var(--c-text); color:#fff; }
.btn--ghost{ background: transparent; color: var(--c-text); }
.btn--ghost:hover{ box-shadow: 4px 4px 0 var(--c-secondary); }
.btn--sm{ padding: 9px 14px; font-size: 13px; }

/* ===== Tags ===== */
.tag{
  display: inline-block;
  padding: 2px 8px;
  border: 1px solid var(--c-line);
  background: var(--c-paper);
  font-size: 12px;
  letter-spacing: 0.04em;
  margin-right: 4px;
}
.tag--ok{ background: var(--c-secondary); color: #fff; border-color: var(--c-secondary); }

/* ===== Age gate ===== */
.age-gate{
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(31,26,23,0.92);
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-md);
}
.age-gate[hidden]{ display: none; }
.age-gate__panel{
  background: var(--c-bg); border: 2px solid var(--c-accent);
  max-width: 540px; width: 100%; padding: var(--space-lg);
  box-shadow: 10px 10px 0 var(--c-secondary);
}
.age-gate__panel h2{ color: var(--c-accent); margin-top: var(--space-sm); }
.age-gate__actions{ display: flex; gap: var(--space-sm); margin: var(--space-md) 0; flex-wrap: wrap; }
.age-gate__legal{ font-size: 12px; color: var(--c-muted); margin-bottom: 0; }
.ascii{ font-size: 12px; color: var(--c-secondary); margin: 0; white-space: pre; overflow-x: auto; }

/* ===== Cookie banner ===== */
.cookie{
  position: fixed; bottom: 60px; left: 0; right: 0; z-index: 900;
  background: var(--c-text); color: var(--c-bg);
  border-top: 2px solid var(--c-accent);
}
.cookie[hidden]{ display: none; }
.cookie__inner{
  max-width: 1180px; margin: 0 auto; padding: var(--space-sm) var(--space-md);
  display: flex; gap: var(--space-md); align-items: center; justify-content: space-between; flex-wrap: wrap;
}
.cookie__inner p{ margin: 0; font-size: 13px; }
.cookie__inner a{ color: var(--c-bg); }
.cookie__actions{ display: flex; gap: var(--space-xs); }
.cookie .btn--ghost{ color: var(--c-bg); border-color: var(--c-bg); }

/* ===== Masthead ===== */
.masthead{ padding-top: var(--space-md); }
.masthead__inner{ display: flex; flex-direction: column; gap: var(--space-xs); }
.masthead__edition{ display: flex; gap: var(--space-md); font-size: 12px; color: var(--c-muted); flex-wrap: wrap; }
.masthead__brand{ font-size: clamp(28px, 4.4vw, 44px); font-weight: 700; letter-spacing: -0.01em; color: var(--c-text); text-decoration: none; }
.masthead__cursor{ color: var(--c-accent); }
.masthead__dot{ color: var(--c-muted); }
.masthead__sub{ color: var(--c-muted); font-size: 14px; }
.rule{ color: var(--c-line); font-size: 11px; overflow: hidden; white-space: nowrap; margin-top: var(--space-sm); }

/* ===== Hero ===== */
.hero{ padding: var(--space-lg) 0 var(--space-md); }
.hero__grid{ display: grid; grid-template-columns: minmax(0, 1.7fr) minmax(260px, 1fr); gap: var(--grid-gap); align-items: start; }
@media (max-width: 820px){ .hero__grid{ grid-template-columns: 1fr; } }
.hero__eyebrow{ font-size: 13px; color: var(--c-accent); margin-bottom: var(--space-sm); }
.hero__h1{ margin-bottom: var(--space-md); }
.hl{ background: linear-gradient(180deg, transparent 60%, rgba(160,82,45,0.30) 60%); }
.hero__sub{ font-size: 17px; max-width: 60ch; }
.hero__byline{ color: var(--c-muted); font-size: 13px; }
.hero__cta{ display: flex; gap: var(--space-sm); margin-top: var(--btn-gap-from-text); flex-wrap: wrap; }

.hero__rail{
  border: 1px solid var(--c-line);
  background: var(--c-paper);
  padding: var(--space-md);
}
.rail__title, .rail__foot{ font-size: 12px; color: var(--c-muted); }
.rail__list{ list-style: none; padding: 0; margin: var(--space-sm) 0; }
.rail__list li{ font-size: 13px; padding: 6px 0; border-bottom: 1px dashed var(--c-muted); }
.rail__list li:last-child{ border-bottom: 0; }
.check{ color: var(--c-accent); font-weight: 700; margin-right: 6px; }

/* ===== Divider ===== */
.divider{ display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-md) var(--space-md); max-width: 1180px; margin: 0 auto; color: var(--c-muted); font-size: 12px; }
.divider i{ flex: 1; height: 1px; background: var(--c-line); display: block; }
.divider span{ white-space: nowrap; }

/* ===== Section heads ===== */
.sec-head{ margin-bottom: var(--space-md); max-width: 80ch; }
.sec-head__kicker{ font-size: 12px; color: var(--c-accent); margin-bottom: var(--space-xs); }

/* ===== Trust strip ===== */
.trust{ padding: var(--space-md) 0; }
.trust__grid{ display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 0; border: 1px solid var(--c-line); }
@media (max-width: 880px){ .trust__grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 480px){ .trust__grid{ grid-template-columns: 1fr; } }
.trust__cell{ padding: var(--space-md); border-right: 1px solid var(--c-line); }
.trust__cell:last-child{ border-right: 0; }
@media (max-width: 880px){ .trust__cell{ border-bottom: 1px solid var(--c-line); } .trust__cell:nth-child(2n){ border-right:0; } }
.trust__num{ font-size: 12px; color: var(--c-accent); margin-bottom: 4px; }
.trust__cell h3{ margin-bottom: 6px; }
.trust__cell p{ font-size: 13px; margin: 0; color: var(--c-text); }

/* ===== Ranking leaderboard ===== */
.ranking{ padding: var(--space-md) 0 var(--space-lg); }
.board{ border: 1px solid var(--c-line); }
.board__head{
  display: grid;
  grid-template-columns: 56px minmax(280px, 2.4fr) minmax(160px, 1fr) minmax(200px, 1.1fr) minmax(180px, 1fr);
  gap: var(--space-sm);
  padding: 12px var(--space-md);
  background: var(--c-text); color: var(--c-bg);
  font-size: 12px; letter-spacing: 0.06em;
}
.board__row{
  display: grid;
  grid-template-columns: 56px minmax(280px, 2.4fr) minmax(160px, 1fr) minmax(200px, 1.1fr) minmax(180px, 1fr);
  gap: var(--space-sm);
  padding: var(--space-md);
  border-top: 1px solid var(--c-line);
  align-items: start;
  background: var(--c-bg);
  transition: background .15s;
}
.board__row:hover{ background: var(--c-paper); }
@media (max-width: 980px){
  .board__head{ display:none; }
  .board__row{ grid-template-columns: 1fr; }
  .board__row > div + div { border-top: 1px dashed var(--c-muted); padding-top: var(--space-sm); }
}
.board__rank span{ font-size: 22px; color: var(--c-accent); font-weight: 700; }
.board__op{ display: flex; gap: var(--space-sm); align-items: flex-start; }
.board__op img{ width: 90px; height: auto; flex: 0 0 90px; }
.board__op h3{ margin: 0 0 6px; font-size: 18px; }
.board__blurb{ font-size: 13px; margin: 0 0 8px; color: var(--c-text); }
.pills{ list-style: none; padding: 0; margin: 0; display: flex; gap: 4px; flex-wrap: wrap; }
.pills li{ font-size: 11px; border: 1px solid var(--c-muted); padding: 2px 6px; color: var(--c-muted); }
.score__num{ font-size: 28px; font-weight: 700; color: var(--c-accent); line-height: 1; }
.score__num span{ font-size: 13px; color: var(--c-muted); font-weight: 400; }
.bar{ font-size: 10px; color: var(--c-accent); letter-spacing: -1px; margin: 6px 0 4px; position: relative; display: inline-block; }
.bar__track{ color: var(--c-muted); opacity: 0.3; display: block; white-space: nowrap; }
.bar__fill{ position: absolute; left: 0; top: 0; overflow: hidden; white-space: nowrap; display: block; }
.score__cap{ font-size: 11px; color: var(--c-muted); }
.board__lic p{ font-size: 12px; color: var(--c-muted); margin: 6px 0 0; }
.board__cta{ display: flex; flex-direction: column; gap: 8px; }
.board__cta .btn{ text-align: center; }
.note{ font-size: 12px; color: var(--c-muted); margin-top: var(--space-md); }

/* ===== Methodology timeline ===== */
.method{ padding: var(--space-md) 0 var(--space-lg); }
.timeline{
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 0;
  border: 1px solid var(--c-line);
  position: relative;
}
@media (max-width: 880px){ .timeline{ grid-template-columns: 1fr; } }
.timeline__step{ padding: var(--space-md); border-right: 1px solid var(--c-line); position: relative; }
.timeline__step:last-child{ border-right: 0; }
@media (max-width: 880px){ .timeline__step{ border-right: 0; border-bottom: 1px solid var(--c-line); } .timeline__step:last-child{ border-bottom: 0; } }
.timeline__head{ font-size: 12px; color: var(--c-accent); margin-bottom: 8px; }
.timeline__head span{ color: var(--c-muted); }
.timeline__step h3{ margin-bottom: 6px; }
.timeline__step p{ font-size: 13px; margin: 0; }

.example{ margin-top: var(--space-md); padding: var(--space-md); background: var(--c-paper); border-left: 4px solid var(--c-accent); }
.example__h{ font-size: 12px; color: var(--c-accent); margin-bottom: 6px; }
.example p{ margin: 0; }

/* ===== Marco regulatorio ===== */
.marco{ padding: var(--space-md) 0 var(--space-lg); }
.marco__grid{ display: grid; grid-template-columns: minmax(0, 1.8fr) minmax(260px, 1fr); gap: var(--grid-gap); align-items: start; }
@media (max-width: 820px){ .marco__grid{ grid-template-columns: 1fr; } }
.marco__side{ border: 1px solid var(--c-line); padding: var(--space-md); background: var(--c-paper); }
.marco__h{ font-size: 12px; color: var(--c-accent); margin-bottom: var(--space-sm); }
.marco__list{ list-style: none; padding: 0; margin: 0 0 var(--space-sm); }
.marco__list li{ padding: 6px 0; border-bottom: 1px dashed var(--c-muted); font-size: 13px; }
.marco__list li:last-child{ border-bottom: 0; }
.marco__list em{ color: var(--c-muted); font-style: normal; }
.marco__foot{ font-size: 12px; color: var(--c-muted); margin: 0; }

/* ===== KYC ===== */
.kyc{ padding: var(--space-md) 0 var(--space-lg); }
.kyc-list{ list-style: none; padding: 0; margin: 0; counter-reset: kyc; }
.kyc-list li{ display: grid; grid-template-columns: 70px 1fr; gap: var(--space-sm); padding: var(--space-sm) 0; border-bottom: 1px dashed var(--c-muted); align-items: start; }
.kyc-list li:last-child{ border-bottom: 0; }
.kyc__n{ font-weight: 700; color: var(--c-accent); font-size: 14px; }
.kyc-list h3{ margin: 0 0 4px; font-size: 16px; }
.kyc-list p{ font-size: 13px; margin: 0; }

/* ===== FAQ ===== */
.faq{ padding: var(--space-md) 0 var(--space-lg); }
.faq__search{
  display: flex; align-items: center; gap: var(--space-sm);
  border: 1px solid var(--c-line); padding: 10px var(--space-sm); margin-bottom: var(--space-md);
  background: var(--c-paper);
}
.faq__prompt{ color: var(--c-accent); font-size: 13px; }
#faq-q{
  flex: 1; border: 0; background: transparent; outline: none; padding: 4px 0;
  font-family: inherit; font-size: 14px; color: var(--c-text);
}
.faq__count{ font-size: 12px; color: var(--c-muted); }
.faq__list{ display: grid; gap: 0; }
.faq__item{ border-top: 1px solid var(--c-line); padding: var(--space-sm) 0; }
.faq__item:last-child{ border-bottom: 1px solid var(--c-line); }
.faq__item summary{ cursor: pointer; font-weight: 700; padding: 4px 0; list-style: none; position: relative; padding-left: 22px; }
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::before{ content: '[+]'; position: absolute; left: 0; color: var(--c-accent); }
.faq__item[open] summary::before{ content: '[-]'; }
.faq__item p{ margin: 8px 0 0; font-size: 14px; }
.faq__item.is-hidden{ display: none; }

/* ===== Pledge ===== */
.pledge{ padding: var(--space-md) 0 var(--space-xl); }
.pledge__box{ border: 2px solid var(--c-accent); padding: var(--space-lg); background: var(--c-paper); box-shadow: 8px 8px 0 var(--c-secondary); }
.pledge__h{ font-size: 12px; color: var(--c-accent); margin-bottom: var(--space-sm); }
.pledge__warn{ background: var(--c-text); color: var(--c-bg); padding: var(--space-sm); margin: var(--space-md) 0 0; }
.pledge__warn strong{ color: var(--c-bg); }

/* ===== Footer ===== */
.foot{ background: var(--c-text); color: var(--c-bg); margin-top: var(--space-lg); }
.foot a{ color: var(--c-bg); }
.foot a:hover{ color: var(--c-accent); }
.foot__strip{ background: var(--c-secondary); padding: var(--space-md) 0; border-bottom: 2px solid var(--c-accent); }
.foot__strip-inner{ display: grid; grid-template-columns: minmax(180px, 1fr) 3fr; gap: var(--space-md); align-items: center; }
@media (max-width: 720px){ .foot__strip-inner{ grid-template-columns: 1fr; } }
.foot__strip-label{ font-size: 12px; color: var(--c-bg); opacity: .8; }
.foot__logos{ display: flex; gap: var(--space-md); flex-wrap: wrap; align-items: center; }
.foot__logos a{ display: inline-block; padding: 6px; background: rgba(251,247,240,0.10); transition: background .15s; }
.foot__logos a:hover{ background: rgba(251,247,240,0.20); }
.foot__logos img{ height: 48px; width: auto; max-width: 130px; object-fit: contain; }

.foot__cols{ display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--grid-gap); padding: var(--space-lg) var(--space-md); }
@media (max-width: 820px){ .foot__cols{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px){ .foot__cols{ grid-template-columns: 1fr; } }
.foot__brand{ font-size: 22px; font-weight: 700; margin-bottom: var(--space-sm); }
.foot__brand span{ color: var(--c-accent); }
.foot__col h4{ font-size: 13px; color: var(--c-accent); margin-bottom: var(--space-sm); }
.foot__col ul{ list-style: none; padding: 0; margin: 0; }
.foot__col li{ padding: 4px 0; font-size: 14px; }
.foot__addr{ font-size: 13px; color: rgba(251,247,240,0.7); }
.foot__legal{ background: #15110f; padding: var(--space-md) 0; font-size: 12px; }
.foot__legal p{ margin: 0 0 4px; opacity: .8; }

/* ===== Sticky bottom nav ===== */
.botnav{
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 800;
  background: var(--c-text); color: var(--c-bg);
  border-top: 2px solid var(--c-accent);
  font-size: 13px;
}
.botnav__inner{ display: flex; gap: var(--space-md); padding: 12px var(--space-md); justify-content: center; flex-wrap: wrap; }
.botnav a{ color: var(--c-bg); text-decoration: none; }
.botnav a:hover{ color: var(--c-accent); }

/* ===== Brand subpage ===== */
.bp-hero{ padding: var(--space-lg) 0 var(--space-md); border-bottom: 1px solid var(--c-line); }
.bp-hero__grid{ display: grid; grid-template-columns: 160px 1fr auto; gap: var(--space-md); align-items: center; }
@media (max-width: 720px){ .bp-hero__grid{ grid-template-columns: 1fr; } }
.bp-hero__logo{ width: 140px; height: auto; border: 1px solid var(--c-line); padding: var(--space-sm); background: #fff; }
.bp-hero__score{ text-align: right; }
.bp-grid{ display: grid; grid-template-columns: minmax(0, 2fr) minmax(260px, 1fr); gap: var(--grid-gap); padding: var(--space-md) 0 var(--space-lg); align-items: start; }
@media (max-width: 820px){ .bp-grid{ grid-template-columns: 1fr; } }
.bp-side{ border: 1px solid var(--c-line); padding: var(--space-md); background: var(--c-paper); position: sticky; top: var(--space-sm); }
.bp-side dl{ margin: 0; display: grid; grid-template-columns: 1fr; gap: 8px; }
.bp-side dt{ font-size: 11px; color: var(--c-muted); margin-top: 8px; }
.bp-side dd{ margin: 0; font-size: 13px; font-weight: 700; }
.bp-cta{ display: block; margin-top: var(--space-md); text-align: center; }
.contras{ background: var(--c-paper); padding: var(--space-md); border-left: 4px solid var(--c-secondary); margin-top: var(--space-md); }

/* ===== Policy pages ===== */
.policy{ padding: var(--space-lg) 0; max-width: 820px; margin: 0 auto; }
.policy h2{ margin-top: var(--space-lg); padding-top: var(--space-sm); border-top: 1px solid var(--c-line); }
.policy h3{ margin-top: var(--space-md); }
.policy ul{ padding-left: 22px; }
.policy li{ margin-bottom: 4px; }
