/* ft-hidden-guard v1 */
[hidden]{display:none!important;}
:root{
  --space-xs: 9px;
  --space-sm: 13px;
  --space-md: 25px;
  --space-lg: 35px;
  --space-xl: 87px;
  --card-padding-y: 27px;
  --card-padding-x: 22px;
  --card-gap: 24px;
  --card-radius: 10px;
  --card-border-width: 2px;
  --card-min-height: 324px;
  --card-min-col-width: 309px;
  --btn-padding-y: 15px;
  --btn-padding-x: 23px;
  --btn-radius: 9px;
  --btn-gap-from-text: 26px;
  --grid-gap: 20px;
  --lh-heading: 1.12;
  --lh-body: 1.64;
  --ls-heading: -0.010em;

  /* Palette, waxed cotton linen, oxidized ink, industrial moss */
  --linen: #e8e1d3;
  --linen-2: #ddd3c0;
  --linen-3: #f2ecde;
  --ink: #221d18;
  --ink-2: #433a30;
  --rust: #a53d2a;
  --moss: #4a6238;
  --moss-2: #617a4a;
  --paper: #f7f2e6;
  --rule: #786a55;
  --thread: rgba(34,29,24,0.18);
  --thread-strong: rgba(34,29,24,0.42);

  --serif: "Iowan Old Style", "Palatino Linotype", Palatino, "Source Serif Pro", Georgia, serif;
  --sans: "Helvetica Neue", "Arial Narrow", Arial, "Founders Grotesk", system-ui, sans-serif;
  --mono: ui-monospace, "SF Mono", "Roboto Mono", "Menlo", monospace;
}

*,*::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;
  background:var(--linen);
  color:var(--ink);
  font-family:var(--serif);
  line-height:var(--lh-body);
  font-size:17px;
  /* warp/weft thread overlay */
  background-image:
    repeating-linear-gradient(0deg, var(--thread) 0 1px, transparent 1px 28px),
    repeating-linear-gradient(90deg, var(--thread) 0 1px, transparent 1px 28px);
  background-attachment:fixed;
}

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

h1,h2,h3,h4{font-family:var(--serif);letter-spacing:var(--ls-heading);line-height:var(--lh-heading);font-weight:600;color:var(--ink);margin:0 0 var(--space-md)}
h1{font-size:clamp(2.2rem,5vw,4.1rem);font-weight:700}
h2{font-size:clamp(1.6rem,2.6vw,2.3rem)}
h3{font-size:1.2rem}
p{margin:0 0 var(--space-md)}

/* =========================================================
   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-family:var(--sans);font-size:0.92rem;font-weight:600;letter-spacing:0.01em;
  text-decoration:none;border:var(--card-border-width) solid var(--ink);
  cursor:pointer;transition:transform .12s ease, background .12s ease, color .12s ease;
}
.btn--primary{background:var(--ink);color:var(--linen-3)}
.btn--primary:hover{background:var(--rust);border-color:var(--rust);color:var(--linen-3);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--linen-3)}
.btn--lg{padding:18px 28px;font-size:1rem}
.btn--sm{padding:10px 16px;font-size:0.85rem}

.link-inline{color:var(--ink-2);font-family:var(--sans);font-size:0.88rem;text-decoration:none;border-bottom:1px solid var(--rule);padding-bottom:2px}
.link-inline:hover{color:var(--rust);border-color:var(--rust)}

.age-pill{
  display:inline-flex;align-items:center;padding:6px 10px;
  border:1.5px solid var(--ink);font-family:var(--sans);font-weight:700;font-size:0.78rem;
  letter-spacing:0.08em;color:var(--ink);background:var(--linen-3);
  border-radius:2px;
}
.age-pill--inverse{background:var(--ink);color:var(--linen-3);border-color:var(--linen-3)}

.seq-tag{display:inline-block;font-family:var(--mono);font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--moss);background:var(--linen-3);border:1px solid var(--rule);padding:4px 10px;margin-bottom:var(--space-md);border-radius:2px}

/* =========================================================
   Age gate + cookie
   ========================================================= */
.age-gate{position:fixed;inset:0;background:rgba(34,29,24,0.86);z-index:9999;align-items:center;justify-content:center;padding:var(--space-md)}
.age-gate:not([hidden]){display:flex}
.age-gate__card{background:var(--linen-3);max-width:540px;width:100%;padding:var(--space-lg);border:var(--card-border-width) solid var(--ink);border-radius:var(--card-radius);box-shadow:8px 8px 0 var(--ink)}
.age-gate__rule{font-family:var(--mono);font-size:0.72rem;letter-spacing:0.14em;color:var(--rust);margin-bottom:var(--space-sm)}
.age-gate h2{margin-top:0}
.age-gate__actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:var(--space-md)}
.age-gate__law{margin-top:var(--space-md);font-family:var(--mono);font-size:0.74rem;color:var(--ink-2);letter-spacing:0.04em}

.cookie{position:fixed;bottom:0;left:0;right:0;background:var(--ink);color:var(--linen-3);z-index:9998;border-top:3px solid var(--rust)}
.cookie:not([hidden]){display:block}
.cookie__inner{max-width:1180px;margin:0 auto;padding:var(--space-md);display:flex;flex-wrap:wrap;gap:var(--space-md);align-items:center;justify-content:space-between}
.cookie p{margin:0;font-size:0.92rem;flex:1 1 320px}
.cookie__actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.cookie .btn--primary{background:var(--linen-3);color:var(--ink);border-color:var(--linen-3)}
.cookie .btn--ghost{color:var(--linen-3);border-color:var(--linen-3)}
.cookie__link{color:var(--linen-3);font-family:var(--sans);font-size:0.85rem}

/* =========================================================
   Header
   ========================================================= */
.site-header{position:absolute;top:0;left:0;right:0;z-index:50;background:transparent}
.site-header__inner{max-width:1280px;margin:0 auto;padding:var(--space-md);display:flex;align-items:center;gap:var(--space-md);justify-content:space-between}
.brand{display:inline-flex;align-items:baseline;gap:10px;text-decoration:none;color:var(--ink)}
.brand__mark{font-size:1.6rem;color:var(--moss-2)}
.brand__name{font-family:var(--serif);font-weight:700;font-size:1.3rem;letter-spacing:-0.01em}
.brand__tag{font-family:var(--mono);font-size:0.72rem;color:var(--ink-2);letter-spacing:0.08em}
.site-nav ul{list-style:none;display:flex;gap:var(--space-md);margin:0;padding:0;flex-wrap:wrap}
.site-nav a{font-family:var(--sans);font-size:0.92rem;font-weight:500;color:var(--ink);text-decoration:none;border-bottom:1.5px solid transparent;padding-bottom:3px}
.site-nav a:hover{border-color:var(--rust);color:var(--rust)}

/* =========================================================
   Hero, split image text (pattern card)
   ========================================================= */
.hero{padding:calc(var(--space-xl) + 60px) var(--space-md) var(--space-xl);position:relative}
.hero__inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.15fr 1fr;gap:var(--space-xl);align-items:center}
.hero__meta{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md);align-items:center}
.hero__seq{font-family:var(--mono);font-size:0.82rem;letter-spacing:0.18em;color:var(--ink-2)}
.hero__stamp{font-family:var(--mono);font-size:0.74rem;letter-spacing:0.1em;color:var(--rust);border:1.5px solid var(--rust);padding:5px 10px;text-transform:uppercase}
.hero__h1 em{font-style:italic;color:var(--rust);font-weight:800}
.hero__sub{font-family:var(--mono);font-size:0.95rem;line-height:1.55;color:var(--ink-2);max-width:480px;margin-bottom:var(--space-lg)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:var(--space-lg)}
.hero__chips{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:8px}
.hero__chips li{font-family:var(--mono);font-size:0.78rem;letter-spacing:0.04em;border:1px solid var(--rule);padding:5px 10px;color:var(--ink-2);background:var(--linen-3);border-radius:2px}

.hero__pattern{justify-self:end;width:100%;max-width:480px}
.pattern{
  position:relative;
  aspect-ratio:1/1.05;
  background:var(--linen-3);
  border:var(--card-border-width) solid var(--ink);
  border-radius:var(--card-radius);
  padding:var(--space-md);
  box-shadow:10px 10px 0 var(--ink);
  background-image:
    repeating-linear-gradient(0deg, var(--thread-strong) 0 1px, transparent 1px 18px),
    repeating-linear-gradient(90deg, var(--thread-strong) 0 1px, transparent 1px 18px);
  display:grid;
  grid-template-rows:auto 1fr auto;
  gap:var(--space-sm);
}
.pattern--small{aspect-ratio:1/0.8;max-width:280px;box-shadow:6px 6px 0 var(--ink)}
.pattern__seq{display:flex;justify-content:space-between;font-family:var(--mono);font-size:0.72rem;color:var(--ink-2);letter-spacing:0.06em}
.pattern__seq span{background:var(--linen-3);padding:2px 4px}
.pattern__grid{position:relative}

/* Thread-cross nodes: short diagonal strokes anchored to grid intersections (18px multiples) */
.node{
  position:absolute;
  width:12px;
  height:12px;
  display:block;
  /* diagonal cross stroke via box-shadow trick */
  background:transparent;
}
.node::before,.node::after{
  content:'';
  position:absolute;
  top:50%;left:50%;
  width:10px;height:2px;
  background:var(--ink);
  transform-origin:center;
}
.node::before{transform:translate(-50%,-50%) rotate(45deg);}
.node::after{transform:translate(-50%,-50%) rotate(-45deg);}

/* Snap to 18px grid intersections */
.node--a{top:36px;left:36px;}
.node--a::before,.node--a::after{background:var(--rust);}
.node--b{top:72px;left:108px;}
.node--b::before,.node--b::after{background:var(--moss-2);}
.node--c{top:108px;left:54px;}
.node--c::before,.node--c::after{background:var(--ink);}
.node--d{top:54px;left:126px;}
.node--d::before,.node--d::after{background:var(--rule);}
/* Additional nodes to fill the lower-right quadrant of the hero pattern */
.node--e{top:144px;left:180px;}
.node--e::before,.node--e::after{background:var(--rust);}
.node--f{top:198px;left:90px;}
.node--f::before,.node--f::after{background:var(--moss-2);}
.node--g{top:234px;left:216px;}
.node--g::before,.node--g::after{background:var(--ink);}
.node--h{top:162px;left:144px;}
.node--h::before,.node--h::after{background:var(--rule);}

.pattern__stamp{
  position:absolute;bottom:var(--space-md);right:var(--space-md);
  border:2px solid var(--rust);padding:8px 12px;background:var(--linen-3);
  transform:rotate(-4deg);
  display:flex;flex-direction:column;align-items:center;
}
/* Tighter stamp on small pattern variant to avoid overlapping nodes */
.pattern--small .pattern__stamp{
  padding:5px 8px;
  bottom:var(--space-sm);
  right:var(--space-sm);
}
.pattern__stamp-line{font-family:var(--mono);font-size:0.7rem;letter-spacing:0.1em;color:var(--rust);text-transform:uppercase;line-height:1.4}
.pattern__legend{position:relative;font-family:var(--mono);font-size:0.7rem;color:var(--ink-2);letter-spacing:0.1em;text-align:right}

@media (max-width:900px){
  .hero__inner{grid-template-columns:1fr;gap:var(--space-lg)}
  .hero{padding-top:140px}
  .hero__pattern{justify-self:start;max-width:340px}
}

/* =========================================================
   Section grid (numbered editorial sections)
   ========================================================= */
.section-grid{max-width:1280px;margin:0 auto;padding:var(--space-xl) var(--space-md) var(--space-md);display:grid;grid-template-columns:240px 1fr;gap:var(--space-xl)}
.section-grid__head .seq, .section-grid__seq{display:block;font-family:var(--mono);font-size:0.82rem;letter-spacing:0.18em;color:var(--moss);margin-bottom:var(--space-sm);text-transform:uppercase}
.section-grid__head h2{margin:0 0 var(--space-sm)}
.section-grid__lede{font-family:var(--mono);font-size:0.88rem;color:var(--ink-2);line-height:1.55;margin:0}
.section-grid__body{font-size:1.05rem;max-width:720px}

/* Section-grid variants: head-only sections (loom, kyc, faq) use a centred heading block */
.section-grid--head-only{
  grid-template-columns:1fr;
  padding-bottom:var(--space-sm);
}
.section-grid--head-only .section-grid__head{
  max-width:1280px;
}

@media (max-width:860px){
  .section-grid{grid-template-columns:1fr;gap:var(--space-md)}
  .section-grid__body{max-width:none}
}

/* about facts */
.about__facts{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md);margin:var(--space-md) 0;padding:var(--space-md);background:var(--linen-3);border:1.5px solid var(--rule);border-radius:var(--card-radius)}
.about__facts div{display:flex;flex-direction:column;gap:4px}
.about__facts dt{font-family:var(--mono);font-size:0.72rem;letter-spacing:0.12em;color:var(--ink-2);text-transform:uppercase}
.about__facts dd{margin:0;font-weight:600}
.about__note{font-family:var(--mono);font-size:0.85rem;color:var(--ink-2);border-left:3px solid var(--rust);padding-left:var(--space-sm);margin-top:var(--space-md)}

/* =========================================================
   Operators, brand stack
   ========================================================= */
.operators{padding:0 0 var(--space-xl)}
.brand-stack{list-style:none;padding:0 var(--space-md);margin:0 auto;max-width:1280px;display:flex;flex-direction:column;gap:var(--card-gap)}

/* Bug fix 3: remove the 60px 1fr columns that duplicated the rank gutter.
   Children flow full-width; the ::before thread line and rank already do the visual job. */
.brand-card{
  background:var(--linen-3);
  border:var(--card-border-width) solid var(--ink);
  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(--space-md);
  position:relative;
  box-shadow:6px 6px 0 var(--ink);
}
.brand-card__head{display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-md);align-items:start}
.brand-card__rank{font-family:var(--mono);font-size:2rem;font-weight:700;color:var(--rust);line-height:1;padding-top:4px}
.brand-card__title h3{margin:0 0 4px;font-size:1.5rem}
.brand-card__legal{margin:0;font-family:var(--mono);font-size:0.78rem;color:var(--ink-2);letter-spacing:0.04em}
.brand-card__rating{display:flex;flex-direction:column;align-items:flex-end;text-align:right;min-width:120px;gap:4px}
.brand-card__rating-num{font-family:var(--serif);font-weight:700;font-size:2.4rem;line-height:1;color:var(--moss)}
.brand-card__rating-scale{font-family:var(--mono);font-size:0.78rem;color:var(--ink-2)}
.brand-card__rating-label{font-family:var(--mono);font-size:0.68rem;letter-spacing:0.08em;color:var(--ink-2);text-transform:uppercase;margin-top:4px;max-width:140px;line-height:1.3}
.brand-card__blurb{font-size:1.05rem;margin:0}
.brand-card__specs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-sm) var(--space-md);margin:0;padding:var(--space-sm) 0;border-top:1px dashed var(--rule);border-bottom:1px dashed var(--rule)}
.brand-card__specs div{display:flex;flex-direction:column;gap:2px}
.brand-card__specs dt{font-family:var(--mono);font-size:0.7rem;letter-spacing:0.1em;color:var(--ink-2);text-transform:uppercase}
.brand-card__specs dd{margin:0;font-size:0.95rem}
.brand-card__pills{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:8px}
.brand-card__pills li{font-family:var(--mono);font-size:0.75rem;border:1px solid var(--rule);padding:4px 9px;color:var(--ink-2);background:var(--linen);border-radius:2px}
.brand-card__cta{display:flex;flex-wrap:wrap;gap:var(--btn-gap-from-text);align-items:center;margin-top:var(--space-xs)}

@media (max-width:720px){
  .brand-card{padding:var(--space-md) var(--space-sm)}
  .brand-card__head{grid-template-columns:1fr;gap:var(--space-sm)}
  .brand-card__rank{padding:0}
  .brand-card__rating{align-items:flex-start;text-align:left}
  .brand-card__rating-label{max-width:none}
  .brand-card__specs{grid-template-columns:1fr}
}

/* =========================================================
   Loom (methodology) and KYC lists
   ========================================================= */
.loom, .kyc{list-style:none;padding:0 var(--space-md);margin:0 auto;max-width:1280px;display:grid;grid-template-columns:repeat(2,1fr);gap:var(--card-gap)}
.loom__row, .kyc li{
  display:grid;grid-template-columns:70px 1fr;gap:var(--space-md);
  padding:var(--card-padding-y) var(--card-padding-x);
  background:var(--linen-3);
  border:1.5px solid var(--ink);
  border-radius:var(--card-radius);
}
.loom__row > :nth-child(n+2), .kyc li > :nth-child(n+2){grid-column:2}
.loom__num, .kyc__num{font-family:var(--mono);font-weight:700;font-size:1.6rem;color:var(--rust);line-height:1}
.loom__body h3, .kyc__body h3{margin:0 0 8px;font-size:1.1rem}
.loom__body p, .kyc__body p{margin:0;font-size:0.96rem}

@media (max-width:760px){
  .loom, .kyc{grid-template-columns:1fr}
}

/* Marco */
.marco p{font-size:1.05rem}
.marco strong{color:var(--ink);background:linear-gradient(transparent 60%, rgba(165,61,42,0.18) 60%)}

/* FAQ */
.faq{max-width:1280px;margin:0 auto;padding:0 var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}
.faq details{border:1.5px solid var(--rule);border-radius:var(--card-radius);background:var(--linen-3);padding:var(--space-sm) var(--space-md)}
.faq details[open]{border-color:var(--ink);box-shadow:4px 4px 0 var(--ink)}
.faq summary{cursor:pointer;list-style:none;padding:8px 0;display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);font-size:1.4rem;color:var(--rust);transition:transform .2s}
.faq details[open] summary::after{content:"−"}
.faq__q{font-weight:600;font-size:1.05rem}
.faq details p{margin:var(--space-sm) 0 var(--space-sm);font-size:0.98rem}

/* Pledge */
.pledge{font-size:1.05rem}
.pledge p{max-width:720px}

/* =========================================================
   Brand subpage
   ========================================================= */
.brand-page{max-width:1100px;margin:0 auto;padding:140px var(--space-md) var(--space-xl)}
.breadcrumb{font-family:var(--mono);font-size:0.82rem;color:var(--ink-2);margin-bottom:var(--space-md)}
.breadcrumb a{color:var(--ink-2)}
.breadcrumb span{margin:0 6px;color:var(--rule)}

.brand-hero{display:grid;grid-template-columns:1.4fr 1fr;gap:var(--space-lg);align-items:start;margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:2px solid var(--ink)}
.brand-hero__rating{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin:var(--space-md) 0}
.brand-hero__num{font-family:var(--serif);font-weight:700;font-size:3rem;color:var(--moss);line-height:1}
.brand-hero__scale{font-family:var(--mono);color:var(--ink-2)}
.brand-hero__label{font-family:var(--mono);font-size:0.78rem;color:var(--ink-2);letter-spacing:0.06em;width:100%}
.brand-hero__disclosure{font-family:var(--mono);font-size:0.78rem;color:var(--ink-2);margin-top:var(--space-sm)}
.brand-hero__mark{justify-self:end;width:100%;max-width:280px}

@media (max-width:760px){
  .brand-hero{grid-template-columns:1fr}
  .brand-hero__mark{justify-self:start}
}

.brand-section{margin-bottom:var(--space-xl)}
.brand-section h2{display:flex;align-items:baseline;gap:var(--space-sm);border-bottom:1px solid var(--rule);padding-bottom:var(--space-sm)}
.sec-num{font-family:var(--mono);font-size:0.85rem;color:var(--moss);letter-spacing:0.12em}

.spec-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-sm) var(--space-md);margin:0;padding:0}
.spec-list div{display:grid;grid-template-columns:140px 1fr;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px dashed var(--rule)}
.spec-list dt{font-family:var(--mono);font-size:0.78rem;letter-spacing:0.06em;color:var(--ink-2);text-transform:uppercase}
.spec-list dd{margin:0;font-size:0.95rem}
@media (max-width:680px){.spec-list{grid-template-columns:1fr}.spec-list div{grid-template-columns:1fr}}

.cons-list{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-sm)}
.cons-list li{padding:var(--space-sm) var(--space-md);background:var(--linen-3);border-left:4px solid var(--rust);border-radius:0 var(--card-radius) var(--card-radius) 0}

.back-link{display:inline-block;margin-top:var(--space-lg);font-family:var(--mono);font-size:0.9rem;color:var(--ink)}

/* =========================================================
   Policy pages
   ========================================================= */
.policy-page{max-width:820px;margin:0 auto;padding:140px var(--space-md) var(--space-xl)}
.policy-page h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:var(--space-md)}
.policy-page .lede{font-size:1.1rem;color:var(--ink-2);border-left:3px solid var(--rust);padding-left:var(--space-md);margin-bottom:var(--space-lg)}
.policy-page section{margin-bottom:var(--space-lg)}
.policy-page section h2{font-size:1.25rem;border-bottom:1px solid var(--rule);padding-bottom:var(--space-xs);margin-bottom:var(--space-sm)}
.policy-page ul{padding-left:1.2rem}
.policy-page li{margin-bottom:6px}
.policy-page code{font-family:var(--mono);background:var(--linen-3);padding:1px 6px;border-radius:3px;font-size:0.9em}

.help-box{background:var(--ink);color:var(--linen-3);padding:var(--space-lg);border-radius:var(--card-radius);margin-bottom:var(--space-lg);border:2px solid var(--rust)}
.help-box h2{color:var(--linen-3);border:none;margin-bottom:var(--space-sm)}
.help-box__num{font-family:var(--serif);font-size:2.4rem;font-weight:700;margin:var(--space-sm) 0}
.help-box__num a{color:var(--linen-3);text-decoration:none}
.help-box__num a:hover{color:var(--rust)}

/* =========================================================
   404 + menores
   ========================================================= */
.page-narrow{max-width:760px;margin:0 auto;padding:160px var(--space-md) var(--space-xl)}
.page-narrow__inner h1{margin-bottom:var(--space-md)}
.page-narrow .lede{font-size:1.15rem;color:var(--ink-2);margin-bottom:var(--space-lg)}
.page-actions{display:flex;flex-wrap:wrap;gap:12px}

.menores{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg)}
.menores__card{max-width:560px;background:var(--linen-3);border:var(--card-border-width) solid var(--ink);border-radius:var(--card-radius);padding:var(--space-lg);box-shadow:8px 8px 0 var(--ink)}
.menores__card h1{font-size:2rem}

/* =========================================================
   Footer
   ========================================================= */
.site-footer{background:#1a1612;color:var(--linen-3);padding:var(--space-xl) 0 var(--space-md);margin-top:var(--space-xl);background-image:repeating-linear-gradient(0deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 28px),repeating-linear-gradient(90deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 28px)}
.site-footer__inner{max-width:1280px;margin:0 auto;padding:0 var(--space-md);display:grid;grid-template-columns:1.4fr 1fr 1fr 1.4fr;gap:var(--space-lg)}
.site-footer h4{color:var(--rust);font-family:var(--mono);font-size:0.82rem;letter-spacing:0.14em;text-transform:uppercase;margin-bottom:var(--space-sm)}
.site-footer p{font-size:0.92rem;color:#c8bba3}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.site-footer a{color:var(--linen-3);text-decoration:none;font-family:var(--sans);font-size:0.92rem;border-bottom:1px solid transparent;padding-bottom:1px}
.site-footer a:hover{border-color:var(--rust);color:var(--rust)}
.foot-brand{display:flex;align-items:baseline;gap:8px;margin-bottom:var(--space-sm)}
.foot-brand__mark{font-size:1.4rem;color:var(--moss-2)}
.foot-brand__name{font-family:var(--serif);font-weight:700;font-size:1.2rem;color:var(--linen-3)}
.foot-addr{font-size:0.88rem;color:#c8bba3}
.foot-help{margin-top:var(--space-sm);font-family:var(--mono);font-size:0.9rem}

.regulator-panel{background:#0f0c0a;padding:18px;border-radius:6px;display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:flex-start;border:1px solid rgba(255,255,255,0.08)}
.regulator-panel a{display:inline-flex;padding:6px;border-radius:4px;transition:background .15s}
.regulator-panel a:hover{background:rgba(255,255,255,0.06);border:none}
.regulator-panel img{height:42px;width:auto;display:block;filter:brightness(1.05);background:transparent;padding:0;border:none}

.site-footer__law{max-width:1280px;margin:var(--space-lg) auto 0;padding:var(--space-md);border-top:1px solid rgba(255,255,255,0.12);font-size:0.85rem;color:#a89b85}
.site-footer__law p{margin-bottom:8px}
.foot-copy{font-family:var(--mono);font-size:0.78rem;color:#867963;letter-spacing:0.06em}

@media (max-width:900px){
  .site-footer__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:540px){
  .site-footer__inner{grid-template-columns:1fr}
}
