/* ft-hidden-guard v1 */
[hidden]{display:none!important;}
/* MODUVEXA · Manual técnico · industrial service manual aesthetic */

:root{
  --space-xs: 6px;
  --space-sm: 18px;
  --space-md: 28px;
  --space-lg: 33px;
  --space-xl: 67px;
  --card-padding-y: 29px;
  --card-padding-x: 21px;
  --card-gap: 22px;
  --card-radius: 5px;
  --card-border-width: 1px;
  --card-min-height: 324px;
  --card-min-col-width: 300px;
  --btn-padding-y: 10px;
  --btn-padding-x: 28px;
  --btn-radius: 11px;
  --btn-gap-from-text: 15px;
  --grid-gap: 32px;
  --lh-heading: 1.28;
  --lh-body: 1.63;
  --ls-heading: 0.030em;

  --c-bg: #131316;
  --c-bg-2: #1b1b1f;
  --c-bg-3: #25262b;
  --c-ink: #ececea;
  --c-ink-2: #aeaeb0;
  --c-ink-3: #74757a;
  --c-rule: #34353a;
  --c-rule-2: #45464c;
  --c-signal: #ff5b1f;
  --c-signal-2: #ff7a3f;
  --c-cream: #eae6dc;

  --ff-display: 'Industria', 'Oswald', 'Bebas Neue', 'Impact', 'Haettenschweiler', 'Arial Narrow Bold', sans-serif;
  --ff-body: 'Inter', 'Helvetica Neue', 'Arial', system-ui, sans-serif;
  --ff-mono: ui-monospace, 'JetBrains Mono', 'IBM Plex Mono', 'Menlo', 'Consolas', 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{ background:var(--c-bg); }
body{
  margin:0;
  font-family: var(--ff-body);
  color:var(--c-ink);
  background:
    repeating-linear-gradient(0deg, transparent 0 39px, rgba(255,255,255,0.018) 39px 40px),
    var(--c-bg);
  line-height: var(--lh-body);
  font-size:16px;
  -webkit-font-smoothing: antialiased;
}

.wrap{ width: min(1180px, 92%); margin: 0 auto; }

.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }

/* TYPOGRAPHY */
h1,h2,h3,h4{ font-family: var(--ff-display); font-weight: 700; letter-spacing: var(--ls-heading); line-height: var(--lh-heading); text-transform: uppercase; margin: 0 0 var(--space-sm); }
h1{ font-size: clamp(40px, 6.5vw, 84px); letter-spacing: 0.005em; }
h2{ font-size: clamp(24px, 3vw, 36px); }
h3{ font-size: 17px; letter-spacing: 0.06em; }
p{ margin: 0 0 var(--space-sm); }
a{ color: var(--c-signal); text-decoration: none; border-bottom: 1px solid rgba(255,91,31,0.35); }
a:hover{ color: var(--c-signal-2); border-bottom-color: var(--c-signal-2); }

/* BUTTONS */
.btn{
  display: inline-flex; align-items:center; gap:10px;
  padding: var(--btn-padding-y) var(--btn-padding-x);
  border-radius: 0;
  border: 1px solid var(--c-signal);
  background: var(--c-signal);
  color: #18181a;
  font-family: var(--ff-display);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 13px;
  cursor: pointer;
  text-decoration: none;
  transition: transform .12s ease, background .12s ease, color .12s ease;
}
.btn:hover{ background:#fff; border-color:#fff; color:#18181a; transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--c-signal); }
.btn--signal{ background:var(--c-signal); border-color:var(--c-signal); color:#141414; }
.btn--ghost{ background:transparent; color:var(--c-ink); border-color:var(--c-rule-2); }
.btn--ghost:hover{ background:var(--c-bg-3); color:var(--c-ink); border-color:var(--c-ink-2); box-shadow:none; transform:none; }
.btn--lg{ padding: 16px 36px; font-size: 14px; }
.btn--sm{ padding: 8px 18px; font-size: 12px; }
.link-arrow{ font-family:var(--ff-mono); font-size:12px; letter-spacing:0.08em; text-transform:uppercase; border-bottom:1px dashed currentColor; }

/* HEADER */
.site-header{ position:relative; z-index: 50; padding: var(--space-md) 0; }
.site-header--transparent{ position:absolute; left:0; right:0; top:0; background:transparent; }
.header__row{ display:flex; justify-content:space-between; align-items:flex-start; gap: var(--space-md); }
.wordmark{ display:grid; grid-template-columns: auto 1fr; column-gap: 12px; align-items:center; text-decoration:none; border:none; color:var(--c-ink); }
.wordmark__mark{ grid-row: span 2; font-family:var(--ff-display); font-size: 36px; color:var(--c-signal); line-height:1; }
.wordmark__text{ font-family:var(--ff-display); font-weight:700; letter-spacing: 0.16em; font-size: 20px; }
.wordmark__sub{ font-family:var(--ff-mono); font-size:10px; color:var(--c-ink-3); letter-spacing: 0.18em; text-transform:uppercase; }
.header__meta{ display:flex; gap:10px; align-items:center; }
.chip{ font-family:var(--ff-mono); font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--c-ink-2); padding: 5px 10px; border:1px solid var(--c-rule-2); }
.chip--age{ color:var(--c-signal); border-color:var(--c-signal); }

/* HERO */
.hero{ position:relative; padding: 160px 0 var(--space-xl); overflow:hidden; background:
  radial-gradient(1200px 600px at 80% -10%, rgba(255,91,31,0.12), transparent 60%),
  linear-gradient(180deg, #0f0f12 0%, #18181d 60%, var(--c-bg) 100%);
}
.hero::after{
  content:''; position:absolute; left:0; right:0; bottom:0; height:1px; background:var(--c-rule);
}
.hero__tape{
  position:absolute; top: 150px; left:-10%; right:-10%;
  transform: rotate(-3.5deg);
  background: repeating-linear-gradient(135deg, #f0b41a 0 28px, #1a1a1a 28px 56px);
  color:#1a1a1a;
  font-family: var(--ff-display);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  padding: 8px 0;
  opacity: 0.78;
}
.hero__tape span{ display:inline-block; white-space:nowrap; padding-left: 100%; animation: tape 38s linear infinite; }
@keyframes tape{ from{ transform: translateX(0); } to { transform: translateX(-100%); } }

/* Hero: single centred column layout */
.hero__grid{
  display:flex; flex-direction:column; align-items:center; text-align:center;
  position:relative; z-index: 2;
  margin-top: var(--space-lg);
}
.hero__center{
  max-width: 860px;
  width: 100%;
}
.hero__kicker{ font-family:var(--ff-mono); font-size:12px; letter-spacing:0.18em; text-transform:uppercase; color:var(--c-signal); margin:0 0 var(--space-md); }
.hero__h1{ color: var(--c-ink); }
.hero__sub{ max-width: 60ch; color: var(--c-ink-2); font-size: 18px; margin-left:auto; margin-right:auto; }
.hero__cta{ margin: var(--space-md) 0 var(--space-lg); }
.hero__chips{ list-style:none; padding:0; margin:0 auto var(--space-md); display:grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 14px; max-width: 700px; }
.hero__chips li{ display:flex; gap:10px; align-items:baseline; border:1px solid var(--c-rule-2); padding:12px 14px; background: rgba(255,255,255,0.02); }
.hero__chips .chip__k{ font-family:var(--ff-mono); font-size:10px; letter-spacing:0.16em; color:var(--c-signal); text-transform:uppercase; }
.hero__chips .chip__v{ font-size:13px; color:var(--c-ink); }

/* Hero meta strip (horizontal, below chips) */
.hero__meta--strip{
  display:flex; flex-wrap:wrap; justify-content:center; gap: 6px 24px;
  margin: 0 auto;
  font-family:var(--ff-mono); font-size: 11px; letter-spacing:0.05em;
  border-top: 1px solid var(--c-rule); border-bottom: 1px solid var(--c-rule);
  padding: var(--space-xs) 0;
}
.hero__meta--strip .meta-pair{ display:inline-flex; gap: 4px; align-items:baseline; }
.hero__meta--strip dt{ color:var(--c-ink-3); text-transform:uppercase; margin:0; }
.hero__meta--strip dd{ margin:0; color:var(--c-ink); }

@media (max-width: 700px){
  .hero{ padding-top: 140px; }
  .hero__tape{ top: 140px; }
  .hero__chips{ grid-template-columns: 1fr; }
}

/* SECTION HEADS */
.section-head{ display:grid; grid-template-columns: 80px 1fr; gap: var(--space-md); padding: var(--space-xl) 0 var(--space-lg); border-top: 1px solid var(--c-rule); }
.section-head__num{ font-family:var(--ff-display); font-size: 56px; color:var(--c-signal); line-height: 1; }
.section-head h2{ margin-bottom: 10px; }
.section-head p{ color: var(--c-ink-2); max-width: 70ch; margin:0; }
.section-head--side{ padding-top: 0; border-top: 0; }

/* OPERATORS */
.operators{ padding-bottom: var(--space-xl); }
.op-list{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap: var(--card-gap); }

/* Geo-bloqueo note, elevated above card list */
.op-list__note{
  margin-bottom: var(--space-lg);
  margin-top: 0;
  font-family:var(--ff-mono); font-size:13px; color: var(--c-ink-2);
  border-left: 3px solid var(--c-signal);
  border-right: 3px solid var(--c-signal);
  padding: 12px 16px;
  background: rgba(255,91,31,0.04);
}

.op-card{
  border: var(--card-border-width) solid var(--c-rule-2);
  background: linear-gradient(180deg, #1c1d22 0%, #16171b 100%);
  padding: var(--card-padding-y) var(--card-padding-x);
  border-radius: var(--card-radius);
  min-height: var(--card-min-height);
  position:relative;
  display:grid;
  grid-template-rows: auto 1fr auto;
  gap: var(--space-md);
  transition: border-color .15s ease, transform .15s ease;
}
.op-card:hover{ border-color: var(--c-signal); transform: translateY(-2px); }
.op-card::before{
  content:''; position:absolute; left:-1px; top:-1px; bottom:-1px; width: 4px; background: var(--c-signal);
}
.op-card__head{ display:flex; justify-content:space-between; align-items:flex-start; gap: var(--space-md); border-bottom:1px dashed var(--c-rule); padding-bottom: var(--space-sm); }
.op-card__id{ font-family:var(--ff-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--c-ink-3); }
.op-card__part{ display:block; color:var(--c-ink-3); }
.op-card__partv{ display:block; color:var(--c-ink); font-size:14px; letter-spacing:0.18em; }
.op-card__score{ font-family:var(--ff-display); display:flex; align-items:baseline; gap:4px; color:var(--c-signal); }
.op-card__score-n{ font-size: 42px; line-height: 1; }
.op-card__score-d{ font-size: 14px; color: var(--c-ink-3); letter-spacing: 0.12em; }
/* Body: single column flow with gap for breathing room */
.op-card__body{ display:flex; flex-direction:column; gap: var(--card-gap); }
.op-card__brand{ display:flex; gap: 16px; align-items:flex-start; }
/* Logo: min-height enforced via variable; gap added so children have breathing room */
.op-card__logo{ width: 96px; min-width:96px; min-height: var(--card-min-height); height: auto; background:#1a1a1a; border:1px solid var(--c-rule); display:flex; align-items:center; justify-content:center; padding: 8px; gap: var(--card-gap); }
.op-card__logo img{ max-height: 40px; width:auto; object-fit:contain; }
.op-card__legal{ font-family:var(--ff-mono); font-size:11px; color:var(--c-ink-3); margin: 4px 0 0; letter-spacing:0.05em; }
.op-card__blurb{ color: var(--c-ink); margin: 0; max-width: 70ch; }
.op-card__specs{ margin:0; display:grid; grid-template-columns: 1fr; gap: 8px; }
.op-card__specs > div{ display:grid; grid-template-columns: 60px 1fr; gap: 14px; border-top: 1px solid var(--c-rule); padding-top: 8px; }
.op-card__specs dt{ font-family:var(--ff-mono); font-size: 11px; color: var(--c-signal); letter-spacing:0.14em; }
.op-card__specs dd{ margin:0; font-size: 14px; color: var(--c-ink); }
.op-card__tags{ list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap: 6px; }
.op-card__tags li{ font-family:var(--ff-mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:var(--c-ink-2); border:1px solid var(--c-rule-2); padding: 4px 8px; }
.op-card__foot{ display:flex; align-items:center; gap: var(--btn-gap-from-text); flex-wrap:wrap; border-top: 1px solid var(--c-rule); padding-top: var(--space-sm); }
.op-card__stamp{ margin-left:auto; font-family:var(--ff-mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--c-ink-3); border:1px dashed var(--c-rule-2); padding: 5px 10px; transform: rotate(-1.5deg); }

@media (max-width: 700px){
  .op-card__head{ flex-direction:column; align-items:flex-start; }
  .op-card__foot .op-card__stamp{ margin-left:0; }
}

/* METHOD */
.method{ background: linear-gradient(180deg, var(--c-bg) 0%, #101015 100%); }
.method__grid{ display:grid; grid-template-columns: 320px 1fr; gap: var(--grid-gap); padding-bottom: var(--space-xl); }
.pillars{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns: 1fr 1fr; gap: var(--card-gap); }
.pillars li{ display:grid; grid-template-columns: 60px 1fr; gap: 14px; border:1px solid var(--c-rule); padding: var(--card-padding-y) var(--card-padding-x); background: rgba(255,255,255,0.015); }
.pillars li > :nth-child(n+2){ grid-column: 2; }
.pillars__num{ font-family:var(--ff-display); font-size: 36px; color: var(--c-signal); line-height: 1; grid-row: 1 / span 2; }
.pillars__body h3{ font-size:14px; letter-spacing:0.1em; color: var(--c-ink); margin-bottom: 6px; }
.pillars__body p{ color: var(--c-ink-2); margin:0; font-size: 14px; }
@media (max-width: 900px){
  .method__grid{ grid-template-columns: 1fr; }
  .pillars{ grid-template-columns: 1fr; }
}

/* REGS */
.regs__table{ width:100%; border-collapse: collapse; font-family: var(--ff-mono); font-size: 13px; }
.regs__table th, .regs__table td{ text-align:left; padding: 12px 14px; border-bottom: 1px solid var(--c-rule); vertical-align: top; }
.regs__table thead th{ color: var(--c-signal); text-transform: uppercase; letter-spacing: 0.12em; font-size: 11px; border-bottom: 1px solid var(--c-rule-2); }
.regs__table tbody th{ color: var(--c-ink); font-weight:600; }
.regs__table tbody td{ color: var(--c-ink-2); }
.badge{ display:inline-block; font-family:var(--ff-mono); font-size: 10px; letter-spacing:0.14em; padding: 3px 8px; border:1px solid currentColor; text-transform:uppercase; }
.badge--signal{ color: var(--c-signal); }

/* KYC */
.kyc{ padding-bottom: var(--space-xl); }
.kyc__grid{ display:grid; grid-template-columns: 320px 1fr; gap: var(--grid-gap); }
.kyc__steps{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns: 1fr 1fr; gap: var(--card-gap); counter-reset: k; }
.kyc__steps li{ display:grid; grid-template-columns: 70px 1fr; gap: 14px; padding: var(--card-padding-y) var(--card-padding-x); border:1px solid var(--c-rule); background: rgba(255,255,255,0.02); }
.kyc__steps li > :nth-child(n+2){ grid-column: 2; }
.kyc__n{ font-family:var(--ff-mono); color:var(--c-signal); letter-spacing:0.1em; font-size: 14px; grid-row: 1 / span 2; }
.kyc__body h3{ font-size:14px; letter-spacing:0.1em; margin-bottom: 6px; }
.kyc__body p{ color: var(--c-ink-2); font-size: 14px; margin:0; }
@media (max-width: 900px){
  .kyc__grid{ grid-template-columns: 1fr; }
  .kyc__steps{ grid-template-columns: 1fr; }
}

/* FAQ */
.faq__list{ display:flex; flex-direction:column; gap: 0; border-top: 1px solid var(--c-rule); }
.faq__list details{ border-bottom: 1px solid var(--c-rule); padding: var(--space-sm) 0; }
.faq__list summary{ list-style:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap: var(--space-md); padding: 6px 0; }
.faq__list summary::-webkit-details-marker{ display:none; }
.faq__q{ font-family:var(--ff-display); font-size: 17px; letter-spacing:0.04em; text-transform:uppercase; color: var(--c-ink); }
.faq__plus{ font-family:var(--ff-display); color: var(--c-signal); font-size: 24px; transition: transform .2s; }
.faq__list details[open] .faq__plus{ transform: rotate(45deg); }
.faq__a{ padding-top: 10px; color: var(--c-ink-2); max-width: 80ch; }

/* ABOUT */
.about{ padding-bottom: var(--space-xl); }
.about__grid{ display:grid; grid-template-columns: 320px 1fr; gap: var(--grid-gap); }
.about__body{ border-left: 3px solid var(--c-signal); padding-left: var(--space-md); color: var(--c-ink); }
.about__addr{ font-family:var(--ff-mono); font-size: 11px; letter-spacing: 0.12em; color: var(--c-ink-3); text-transform: uppercase; margin-top: var(--space-md); }
@media (max-width: 900px){ .about__grid{ grid-template-columns: 1fr; } }

/* FOOTER */
.site-footer{ background:#0c0c0e; border-top: 1px solid var(--c-rule); padding: var(--space-xl) 0 var(--space-lg); margin-top: var(--space-xl); }
.footer__logos{ background:#1a1a1a; padding: 22px; display:flex; flex-wrap:wrap; gap: 28px; align-items:center; justify-content:center; border:1px solid var(--c-rule); }
.footer__logos a{ border:none; display:inline-flex; padding: 6px 10px; transition: background .12s ease; }
.footer__logos a:hover{ background: rgba(255,255,255,0.06); }
.footer__logos img{ max-height: 56px; width:auto; object-fit:contain; opacity:.95; background:transparent; padding:0; border:none; }
.footer__legal{ margin-top: var(--space-lg); color: var(--c-ink-2); font-size: 13px; }
.footer__legal p{ margin: 0 0 8px; }
.footer__legal strong{ color: var(--c-signal); }
.footer__nav a{ color: var(--c-ink-2); border-bottom: 1px dotted var(--c-rule-2); }
.footer__nav a:hover{ color: var(--c-ink); border-color: var(--c-ink); }

/* PAGE-NARROW (404, menores, brand, politicas) */
.page-narrow{ padding: 120px 0 var(--space-xl); }
.page-narrow .wrap{ max-width: 880px; }
.list-plain{ list-style:none; padding:0; margin: var(--space-md) 0; display:flex; flex-wrap:wrap; gap: 14px; }
.list-plain a{ border-bottom: none; }

/* BRAND PAGE */
.brand-head{ display:grid; grid-template-columns: 140px 1fr min-content; gap: var(--space-lg); align-items:start; padding-bottom: var(--space-lg); border-bottom: 1px solid var(--c-rule); margin-bottom: var(--space-lg); }
.brand-head__logo{ background:#1a1a1a; border:1px solid var(--c-rule); padding: 14px; height: 110px; display:flex; align-items:center; justify-content:center; }
.brand-head__logo img{ max-height: 70px; width:auto; }
.brand-head__meta{ font-family:var(--ff-mono); font-size:11px; color: var(--c-ink-3); letter-spacing: 0.14em; text-transform:uppercase; }
.brand-head__score{ font-family:var(--ff-display); color:var(--c-signal); font-size: 64px; line-height: 1; white-space:nowrap; }
.brand-head__score-sub{ font-size:16px; color:var(--c-ink-3); letter-spacing:0.12em; font-family:var(--ff-display); }
.brand-grid{ display:grid; grid-template-columns: 1.4fr 1fr; gap: var(--grid-gap); }
.brand-grid h2{ margin-top: 0; }
.brand-specs{ border:1px solid var(--c-rule); padding: var(--card-padding-y) var(--card-padding-x); background: rgba(255,255,255,0.02); }
.brand-specs dl{ margin:0; display:grid; grid-template-columns: 1fr; gap: 12px; }
.brand-specs dl > div{ display:grid; grid-template-columns: 100px 1fr; gap: 12px; border-bottom:1px dashed var(--c-rule); padding-bottom: 10px; }
.brand-specs dl > div:last-child{ border-bottom:0; padding-bottom:0; }
.brand-specs dt{ font-family:var(--ff-mono); font-size: 11px; letter-spacing: 0.12em; color: var(--c-signal); text-transform:uppercase; }
.brand-specs dd{ margin:0; color: var(--c-ink); font-size: 14px; }
.contras{ margin-top: var(--space-lg); border-left: 3px solid #f0b41a; padding: 6px 16px; background: rgba(240,180,26,0.05); }
.contras h3{ color:#f0b41a; }
.cta-block{ margin: var(--space-lg) 0; padding: var(--card-padding-y) var(--card-padding-x); border:1px solid var(--c-signal); display:flex; gap: var(--space-md); align-items:center; justify-content:space-between; flex-wrap:wrap; background: rgba(255,91,31,0.04); }
@media (max-width: 900px){
  .brand-head{ grid-template-columns: 1fr; text-align:left; }
  .brand-head__score{ font-size: 48px; }
  .brand-grid{ grid-template-columns: 1fr; }
}

/* AGE GATE */
.age-gate{ position:fixed; inset:0; background: rgba(8,8,10,0.94); display:flex; align-items:center; justify-content:center; padding: var(--space-md); z-index: 1000; }
.age-gate:not([hidden]){ display:flex; }
.age-gate__panel{ max-width: 520px; background:#16171b; border:1px solid var(--c-signal); padding: var(--card-padding-y) var(--card-padding-x); border-radius: 0; box-shadow: 8px 8px 0 var(--c-signal); }
.age-gate__tape{ display:inline-block; background: repeating-linear-gradient(135deg, #f0b41a 0 18px, #1a1a1a 18px 36px); color:#1a1a1a; font-family:var(--ff-display); padding: 4px 10px; font-size: 11px; letter-spacing: 0.14em; margin-bottom: var(--space-md); }
.age-gate__btns{ display:flex; gap: 12px; margin: var(--space-md) 0; flex-wrap:wrap; }
.age-gate__legal{ font-family:var(--ff-mono); font-size: 11px; color: var(--c-ink-3); letter-spacing:0.08em; margin: 0; }

/* COOKIE BANNER */
.cookie-banner{ position:fixed; left: var(--space-md); right: var(--space-md); bottom: var(--space-md); z-index: 900; background:#16171b; border:1px solid var(--c-rule-2); border-left: 4px solid var(--c-signal); padding: var(--space-sm) var(--space-md); }
.cookie-banner:not([hidden]){ display:block; }
.cookie-banner__inner{ display:flex; align-items:center; justify-content:space-between; gap: var(--space-md); flex-wrap:wrap; }
.cookie-banner__inner p{ margin:0; font-size: 13px; color: var(--c-ink-2); max-width: 70ch; }
.cookie-banner__btns{ display:flex; gap: 10px; flex-wrap:wrap; }

/* MOTION (rich budget) */
@media (prefers-reduced-motion: no-preference){
  .reveal{ opacity:0; transform: translateY(14px); transition: opacity .5s ease, transform .5s ease; }
  .reveal.is-in{ opacity:1; transform: none; }
}
