/* ============================================================
   COMPRALEADS.ES — Design System
   Industrial / Predator · Graphite · Blaze orange-red · Hazard
   Anton (display) · Archivo (UI) · Space Mono (data)
   ============================================================ */

:root{
  /* Graphite surfaces */
  --g-0:  #0C0D0F;   /* deepest / footer */
  --g-1:  #131518;   /* base background */
  --g-2:  #191C20;   /* panels */
  --g-3:  #21252B;   /* raised cards */
  --g-4:  #2A2F36;   /* hover raise */
  --line: #2C3138;
  --line-2:#383F47;

  /* Blaze — orange-red predator accent */
  --blaze:   #FF3D00;
  --blaze-2: #FF6A2B;   /* lighter highlight */
  --ember:   #D62B00;   /* deeper / hover */
  --blaze-tint: rgba(255,61,0,.12);
  --blaze-line: rgba(255,61,0,.34);

  /* Signal greens / amber for "live / data" */
  --signal: #38E08A;
  --amber:  #FFB020;

  /* Text */
  --paper:  #F4F3EF;   /* headline white */
  --steel:  #D6D8DB;   /* primary body */
  --muted:  #989DA4;   /* secondary */
  --muted-2:#6B7178;   /* faint */
  --ink:    #0C0D0F;   /* text on blaze */

  /* Radii — industrial = mostly hard */
  --r-xs: 2px;
  --r-sm: 4px;
  --r:    6px;
  --r-lg: 10px;

  /* Spacing */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px;
  --s-5: 24px; --s-6: 32px; --s-7: 48px; --s-8: 64px;
  --s-9: 96px; --s-10: 128px;

  /* Layout */
  --maxw: 1280px;
  --pad: clamp(20px, 4vw, 56px);

  /* Type */
  --display: 'Anton', 'Archivo', system-ui, sans-serif;
  --sans: 'Archivo', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --mono: 'Space Mono', ui-monospace, monospace;

  /* Motion */
  --ease: cubic-bezier(.2,.7,.2,1);
  --t: .22s;

  /* Hazard stripe (reusable) */
  --hazard: repeating-linear-gradient(-45deg,
    var(--blaze) 0 14px, #1a1c1f 14px 28px);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  background:var(--g-1);
  color:var(--steel);
  font-size:16px; line-height:1.55;
  letter-spacing:-.005em;
  text-wrap:pretty;
  overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
button{ font:inherit; background:none; border:none; cursor:pointer; color:inherit; }
img,svg{ display:block; max-width:100%; }
ul,ol{ list-style:none; }
::selection{ background:var(--blaze); color:var(--ink); }

/* ---------- Layout primitives ---------- */
.container{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
.section{ padding:clamp(72px,9vw,128px) 0; position:relative; }
.section--tight{ padding:clamp(48px,6vw,88px) 0; }
.section--alt{ background:var(--g-2); }
.section--dark{ background:var(--g-0); }
.section--blaze{ background:var(--blaze); color:var(--ink); }

.rule-top{ border-top:1px solid var(--line); }

/* ---------- Type ---------- */
.display{
  font-family:var(--display);
  font-weight:400;            /* Anton is single weight */
  text-transform:uppercase;
  line-height:.92;
  letter-spacing:.004em;
  color:var(--paper);
  font-size:clamp(48px,9vw,128px);
}
.h1{ font-family:var(--display); text-transform:uppercase; line-height:.94;
  font-size:clamp(40px,6.4vw,86px); letter-spacing:.006em; color:var(--paper); }
.h2{ font-family:var(--display); text-transform:uppercase; line-height:1.06;
  font-size:clamp(32px,4.6vw,62px); letter-spacing:.008em; color:var(--paper); }
.h3{ font-family:var(--sans); font-weight:800; letter-spacing:-.018em; line-height:1.08;
  font-size:clamp(21px,2.4vw,30px); color:var(--paper); }
.h4{ font-family:var(--sans); font-weight:700; font-size:18px; letter-spacing:-.01em; color:var(--paper); }

.blaze-text{ color:var(--blaze); }
.display .em, .h1 .em, .h2 .em{ color:var(--blaze); }

.lead{ font-size:clamp(17px,1.45vw,21px); color:var(--steel); max-width:62ch; line-height:1.5; }
.muted{ color:var(--muted); }
.mono{ font-family:var(--mono); }

.eyebrow{
  font-family:var(--mono); font-size:11.5px; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase; color:var(--blaze);
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow--muted{ color:var(--muted); }
.eyebrow::before{ content:""; width:18px; height:2px; background:currentColor; }

.kicker{ font-family:var(--mono); font-size:12px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--muted); }

/* numbered section index */
.snum{ font-family:var(--mono); font-size:12px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--blaze); display:block; margin-bottom:18px; }

/* ---------- Hazard / diagonal motifs ---------- */
.hazard-bar{ height:10px; background:var(--hazard);
  background-size:auto; opacity:.9; }
.hazard-bar--thin{ height:6px; }

.tag{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:11px; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase;
  padding:5px 10px; border:1px solid var(--line-2);
  color:var(--muted); background:var(--g-2);
}
.tag--blaze{ color:var(--blaze); border-color:var(--blaze-line); background:var(--blaze-tint); }
.tag--live{ color:var(--signal); border-color:rgba(56,224,138,.3); }
.tag .dot{ width:7px; height:7px; border-radius:50%; background:currentColor; }
.tag .dot--pulse{ animation:pulse 1.6s var(--ease) infinite; }
@keyframes pulse{ 0%,100%{ opacity:1; transform:scale(1);} 50%{ opacity:.35; transform:scale(.7);} }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--sans); font-weight:700; font-size:14.5px;
  letter-spacing:.01em; text-transform:uppercase;
  padding:15px 26px; border:1.5px solid transparent;
  transition:transform var(--t) var(--ease), background var(--t), color var(--t), border-color var(--t);
  white-space:nowrap; position:relative;
}
.btn .arr{ transition:transform var(--t) var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }
.btn--blaze{ background:var(--blaze); color:var(--ink); }
.btn--blaze:hover{ background:var(--blaze-2); transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ember); }
.btn--ghost{ border-color:var(--line-2); color:var(--paper); }
.btn--ghost:hover{ border-color:var(--blaze); color:var(--blaze); }
.btn--ink{ background:var(--ink); color:var(--paper); }
.btn--ink:hover{ background:#1a1c20; transform:translate(-2px,-2px); }
.btn--link{ padding:15px 4px; color:var(--paper); border:0; }
.btn--link:hover{ color:var(--blaze); }
.btn-row{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }

/* ---------- Nav ---------- */
.nav{ position:sticky; top:0; z-index:50; background:rgba(15,16,18,.86);
  backdrop-filter:blur(14px); border-bottom:1px solid var(--line); }
.nav__inner{ display:flex; align-items:center; gap:26px; height:68px; }
.brand{ display:flex; align-items:center; gap:11px; font-family:var(--display);
  text-transform:uppercase; font-size:22px; letter-spacing:.02em; color:var(--paper);
  flex:none; white-space:nowrap; }
.brand__mark{ width:30px; height:30px; flex:none; }
.nav__links{ display:flex; gap:24px; margin-left:18px; flex-wrap:nowrap; white-space:nowrap; }
.nav__links a{ font-size:13.5px; font-weight:600; color:var(--muted);
  letter-spacing:.01em; transition:color var(--t); text-transform:uppercase; }
.nav__links a:hover{ color:var(--paper); }
.nav__cta{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.nav__btn-mobile{ display:none; color:var(--paper); }
.mobile-menu{ display:none; }

/* language switch */
.langsw{ display:inline-flex; border:1px solid var(--line-2); }
.langsw a{ font-family:var(--mono); font-size:12px; font-weight:700; letter-spacing:.08em;
  padding:7px 11px; color:var(--muted); transition:background var(--t),color var(--t); }
.langsw a.on{ background:var(--blaze); color:var(--ink); }
.langsw a:not(.on):hover{ color:var(--paper); }

/* ---------- Hero ---------- */
.hero{ position:relative; padding-top:clamp(48px,7vw,90px); padding-bottom:clamp(48px,7vw,80px);
  overflow:hidden; }
.hero::before{ /* faint blueprint grid */
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px; opacity:.18;
  mask-image:radial-gradient(120% 80% at 70% 0%,#000 30%,transparent 75%);
  pointer-events:none;
}
.hero::after{ /* blaze glow */
  content:""; position:absolute; top:-30%; right:-10%; width:50vw; height:60vh;
  background:radial-gradient(closest-side,var(--blaze-tint),transparent 70%);
  pointer-events:none;
}
.hero__inner{ position:relative; }

/* ---------- Reveal ---------- */
[data-reveal]{ opacity:0; transform:translateY(18px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ [data-reveal]{ opacity:1; transform:none; transition:none; } }

/* ---------- Section heads ---------- */
.shead{ max-width:60ch; margin-bottom:var(--s-7); }
.shead--split{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:end; max-width:none; }
.shead--split .r{ padding-bottom:6px; }

/* ---------- Cards / grids ---------- */
.grid{ display:grid; gap:18px; }
.card{ background:var(--g-2); border:1px solid var(--line); padding:28px; position:relative;
  transition:border-color var(--t), transform var(--t), background var(--t); }
.card:hover{ border-color:var(--line-2); }
.card--raise{ background:var(--g-3); }

/* index number badge */
.idx{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; color:var(--blaze); }

/* feature/step card */
.step{ background:var(--g-2); border:1px solid var(--line); padding:30px; position:relative; overflow:hidden; }
.step__n{ font-family:var(--display); font-size:60px; color:var(--g-4); line-height:1;
  position:absolute; top:14px; right:18px; }
.step__k{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--blaze); }
.step h3{ margin:14px 0 10px; }
.step p{ color:var(--muted); font-size:15px; }

/* metrics */
.metrics{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); }
.metric{ background:var(--g-1); padding:28px 24px; }
.metric__n{ font-family:var(--display); font-size:clamp(34px,4vw,52px); color:var(--paper);
  line-height:1; letter-spacing:.01em; }
.metric__n sup{ font-size:.5em; color:var(--blaze); }
.metric__l{ color:var(--muted); font-size:13.5px; margin-top:10px; max-width:24ch; }

/* lead quality cards (no prices) */
.qual{ background:var(--g-2); border:1px solid var(--line); padding:30px; display:flex; flex-direction:column; gap:16px; position:relative; }
.qual--feat{ background:var(--g-3); border-color:var(--blaze-line); }
.qual__corner{ position:absolute; top:0; right:0; width:0; height:0;
  border-top:42px solid var(--blaze); border-left:42px solid transparent; }
.qual__name{ font-family:var(--display); text-transform:uppercase; font-size:28px; color:var(--paper); }
.qual__tier{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--blaze); }
.qual ul{ display:flex; flex-direction:column; gap:10px; }
.qual li{ display:flex; gap:10px; font-size:14.5px; color:var(--steel); }
.qual li::before{ content:"›"; color:var(--blaze); font-weight:700; }

/* sectors */
.sectors{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.sector{ background:var(--g-1); padding:22px; display:flex; flex-direction:column; gap:6px;
  transition:background var(--t); }
.sector:hover{ background:var(--g-3); }
.sector__n{ font-family:var(--mono); font-size:11px; color:var(--muted-2); }
.sector__t{ font-weight:700; color:var(--paper); font-size:15.5px; }
.sector__d{ font-size:12.5px; color:var(--muted); }

/* comparison table */
.ctable{ width:100%; border-collapse:collapse; font-size:14.5px; }
.ctable th,.ctable td{ text-align:left; padding:16px 18px; border-bottom:1px solid var(--line); }
.ctable thead th{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--muted); font-weight:700; }
.ctable .us{ background:var(--blaze-tint); color:var(--paper); font-weight:700; }
.ctable .yes{ color:var(--signal); font-weight:700; }
.ctable .no{ color:var(--muted-2); }
.ctable tbody th{ color:var(--steel); font-weight:600; }

/* faq */
.faq{ border-top:1px solid var(--line); }
.faq__item{ border-bottom:1px solid var(--line); }
.faq__q{ width:100%; display:flex; justify-content:space-between; align-items:center; gap:20px;
  padding:24px 0; text-align:left; font-weight:700; font-size:17px; color:var(--paper); }
.faq__q .ico{ color:var(--blaze); font-size:22px; transition:transform var(--t); flex:none; }
.faq__item.open .ico{ transform:rotate(45deg); }
.faq__a{ max-height:0; overflow:hidden; transition:max-height var(--t) var(--ease); }
.faq__a p{ padding:0 0 24px; color:var(--muted); max-width:70ch; }

/* testimonial */
.quote{ font-family:var(--sans); font-weight:600; font-size:clamp(20px,2.2vw,30px);
  line-height:1.3; color:var(--paper); letter-spacing:-.01em; }
.quote .em{ color:var(--blaze); }

/* blog cards */
.posts{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.post{ background:var(--g-2); border:1px solid var(--line); display:flex; flex-direction:column;
  transition:border-color var(--t), transform var(--t); }
.post:hover{ border-color:var(--blaze-line); transform:translateY(-3px); }
.post__thumb{ aspect-ratio:16/9; background:var(--g-3); position:relative; overflow:hidden;
  border-bottom:1px solid var(--line); }
.post__cat{ position:absolute; top:12px; left:12px; }
.post__body{ padding:22px; display:flex; flex-direction:column; gap:10px; flex:1; }
.post__meta{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; color:var(--muted-2);
  text-transform:uppercase; }
.post__title{ font-weight:800; font-size:18px; color:var(--paper); line-height:1.2; letter-spacing:-.015em; }
.post__excerpt{ font-size:14px; color:var(--muted); flex:1; }
.post__more{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; color:var(--blaze);
  text-transform:uppercase; }

/* footer */
.footer{ background:var(--g-0); border-top:1px solid var(--line); padding:72px 0 36px; }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; }
.footer h5{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted-2); margin-bottom:16px; }
.footer a{ display:block; color:var(--muted); font-size:14px; padding:5px 0; transition:color var(--t); }
.footer a:hover{ color:var(--blaze); }
.footer__bottom{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap;
  margin-top:56px; padding-top:24px; border-top:1px solid var(--line);
  font-size:12.5px; color:var(--muted-2); font-family:var(--mono); }

/* ---------- Article ---------- */
.article{ max-width:760px; margin:0 auto; padding:0 var(--pad); }
.article__hero{ padding:clamp(48px,6vw,88px) 0 var(--s-7); border-bottom:1px solid var(--line); }
.article__title{ font-family:var(--display); text-transform:uppercase; line-height:1.32;
  font-size:clamp(30px,5vw,46px); color:var(--paper); letter-spacing:.008em; margin:16px 0 36px; }
.article__meta{ display:flex; gap:16px; flex-wrap:wrap; font-family:var(--mono); font-size:12px;
  letter-spacing:.06em; color:var(--muted); text-transform:uppercase; }
.article__lead{ font-size:clamp(20px,2.1vw,25px); color:var(--paper); line-height:1.5; margin-top:22px;
  font-weight:500; letter-spacing:-.012em; }
.prose{ padding:var(--s-7) 0 var(--s-8); font-size:19.5px; line-height:1.82; color:#E4E6E9;
  max-width:680px; margin:0 auto; }
.prose > * + *{ margin-top:1.5em; }
.prose > p:first-of-type{ font-size:21px; color:var(--paper); }
.prose > p:first-of-type::first-letter{ font-family:var(--display); float:left; font-size:3.5em;
  line-height:.78; padding:8px 14px 0 0; color:var(--blaze); }
.prose h2{ font-family:var(--display); text-transform:uppercase; font-size:clamp(27px,3.2vw,40px);
  color:var(--paper); letter-spacing:.01em; line-height:1.04; margin-top:1.9em; padding-top:.4em;
  scroll-margin-top:96px; position:relative; }
.prose h2::before{ content:""; position:absolute; top:0; left:0; width:38px; height:3px; background:var(--blaze); }
.prose h3{ font-family:var(--sans); font-weight:800; font-size:23px; color:var(--paper);
  letter-spacing:-.015em; margin-top:1.6em; scroll-margin-top:96px; }
.prose p{ color:#E4E6E9; }
.prose a{ color:var(--blaze); text-decoration:underline; text-underline-offset:3px;
  text-decoration-thickness:1.5px; font-weight:600; }
.prose a:hover{ color:var(--blaze-2); }
.prose strong{ color:var(--paper); font-weight:700; }
.prose ul,.prose ol{ padding-left:0; display:flex; flex-direction:column; gap:12px; }
.prose ul li{ display:flex; gap:14px; }
.prose ul li::before{ content:"›"; color:var(--blaze); font-weight:700; flex:none; }
.prose ol{ counter-reset:li; }
.prose ol li{ display:flex; gap:14px; counter-increment:li; }
.prose ol li::before{ content:counter(li); font-family:var(--mono); color:var(--blaze);
  font-weight:700; flex:none; }
.prose blockquote{ position:relative; margin:1.9em 0; padding:8px 0 8px 30px;
  border-left:4px solid var(--blaze); font-family:var(--sans); font-weight:600;
  font-size:clamp(22px,2.5vw,28px); color:var(--paper); line-height:1.32; letter-spacing:-.018em; }
.prose .callout{ background:linear-gradient(180deg,var(--g-3),var(--g-2)); border:1px solid var(--line-2);
  border-left:3px solid var(--blaze); padding:24px 26px; position:relative; }
.prose .callout::before{ content:""; position:absolute; top:-9px; left:22px; width:16px; height:16px;
  background:var(--blaze); transform:rotate(45deg); }
.prose .callout p{ margin:0; color:var(--paper); font-size:18px; line-height:1.6; }
.prose .callout strong{ color:var(--blaze); }
.prose figure{ margin:1.8em 0; }
.prose .ph{ /* image placeholder */
  aspect-ratio:16/9; border:1px solid var(--line); background:
    repeating-linear-gradient(-45deg,var(--g-2) 0 12px,var(--g-1) 12px 24px);
  display:flex; align-items:center; justify-content:center; }
.prose .ph span{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; color:var(--muted-2);
  text-transform:uppercase; background:var(--g-1); padding:6px 12px; border:1px solid var(--line); }
.prose figcaption{ font-family:var(--mono); font-size:12px; color:var(--muted-2); margin-top:10px; text-align:center; }

.toc{ background:var(--g-2); border:1px solid var(--line); padding:22px 24px; margin:var(--s-7) 0; }
.toc h4{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted); margin-bottom:12px; }
.toc ol{ display:flex; flex-direction:column; gap:8px; }
.toc a{ color:var(--steel); font-size:14.5px; }
.toc a:hover{ color:var(--blaze); }

.author{ display:flex; align-items:center; gap:14px; padding:24px 0; border-top:1px solid var(--line);
  border-bottom:1px solid var(--line); margin:var(--s-7) 0; }
.author__av{ width:46px; height:46px; background:var(--hazard); flex:none; }
.author__n{ font-weight:700; color:var(--paper); font-size:14.5px; }
.author__r{ font-family:var(--mono); font-size:11.5px; color:var(--muted); letter-spacing:.06em; }

/* ---------- Article: Medium-style reading layer ---------- */
.read-progress{ position:fixed; top:0; left:0; height:3px; width:0; background:var(--blaze);
  z-index:200; transition:width .08s linear; box-shadow:0 0 10px rgba(255,61,0,.6); }
.art-kicker{ display:flex; align-items:center; gap:12px; margin-bottom:6px; }
.art-kicker .cat{ font-family:var(--mono); font-size:11.5px; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--blaze); }
.art-kicker .line{ flex:1; height:1px; background:var(--line); }
.share-row{ display:flex; align-items:center; gap:10px; margin-top:26px; flex-wrap:wrap; }
.share-row .lbl{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); }
.share-btn{ width:38px; height:38px; display:inline-flex; align-items:center; justify-content:center;
  border:1px solid var(--line-2); color:var(--muted); transition:all var(--t); }
.share-btn:hover{ border-color:var(--blaze); color:var(--blaze); transform:translateY(-2px); }
.share-btn svg{ width:16px; height:16px; }
.share-btn.copied{ border-color:var(--signal); color:var(--signal); }
.toc-auto{ background:var(--g-2); border:1px solid var(--line); border-left:3px solid var(--blaze);
  padding:22px 26px; margin:2em 0; }
.toc-auto .toc-h{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); margin-bottom:14px; }
.toc-auto ol{ counter-reset:toc; display:flex; flex-direction:column; gap:15px; }
.toc-auto li{ counter-increment:toc; display:flex; gap:14px; align-items:baseline; }
.toc-auto li::before{ content:counter(toc,decimal-leading-zero); font-family:var(--mono); font-size:13px;
  color:var(--blaze); font-weight:700; flex:none; }
.toc-auto a{ color:var(--steel); font-size:15.5px; line-height:1.4; transition:color var(--t); }
.toc-auto a:hover{ color:var(--blaze); }
.prose figure .ph{ aspect-ratio:16/8; }

.cta-band{ background:var(--blaze); color:var(--ink); padding:clamp(48px,6vw,80px) 0; }
.cta-band .h2{ color:var(--ink); }
.cta-band .btn--ink{ background:var(--ink); color:var(--paper); }
.cta-band .btn--ghost{ border-color:rgba(12,13,15,.35); color:var(--ink); }
.cta-band .btn--ghost:hover{ border-color:var(--ink); }

.breadcrumb{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; color:var(--muted-2);
  text-transform:uppercase; display:flex; gap:8px; flex-wrap:wrap; }
.breadcrumb a:hover{ color:var(--blaze); }

/* ---------- Home: marquee ticker ---------- */
.marquee{ overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:var(--g-2); position:relative; }
.marquee::before,.marquee::after{ content:""; position:absolute; top:0; bottom:0; width:90px; z-index:2; pointer-events:none; }
.marquee::before{ left:0; background:linear-gradient(90deg,var(--g-1),transparent); }
.marquee::after{ right:0; background:linear-gradient(-90deg,var(--g-1),transparent); }
.marquee__track{ display:flex; width:max-content; animation:marquee 30s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__item{ display:inline-flex; align-items:center; gap:16px; padding:15px 26px;
  font-family:var(--display); text-transform:uppercase; font-size:21px; color:var(--paper); white-space:nowrap; }
.marquee__item i{ width:8px; height:8px; background:var(--blaze); flex:none; transform:rotate(45deg); }
.marquee__item.dim{ color:var(--muted-2); }
@keyframes marquee{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .marquee__track{ animation:none; } }

/* ---------- Home: trust strip ---------- */
.trust-label{ text-align:center; font-family:var(--mono); font-size:11.5px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted-2); margin-bottom:28px; }
.trust-row{ display:flex; align-items:center; gap:38px; flex-wrap:wrap; justify-content:center; }
.trust-logo{ display:inline-flex; align-items:center; gap:10px; font-family:var(--display);
  text-transform:uppercase; font-size:19px; letter-spacing:.02em; color:var(--muted);
  opacity:.72; transition:opacity var(--t),color var(--t); white-space:nowrap; }
.trust-logo:hover{ opacity:1; color:var(--steel); }
.trust-logo svg{ width:19px; height:19px; color:var(--blaze); flex:none; }

/* ---------- Home: process rail ---------- */
.rail{ display:grid; grid-template-columns:repeat(3,1fr); border:1px solid var(--line); background:var(--g-2); }
.rail__step{ padding:38px 32px; position:relative; border-right:1px solid var(--line); }
.rail__step:last-child{ border-right:0; }
.rail__num{ font-family:var(--display); font-size:66px; line-height:1; color:var(--blaze); }
.rail__k{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.rail__step h3{ margin:14px 0 10px; }
.rail__step p{ color:var(--muted); font-size:15px; }
.rail__arrow{ position:absolute; top:50%; right:-14px; transform:translateY(-50%); z-index:3;
  width:28px; height:28px; background:var(--g-1); border:1px solid var(--line-2); color:var(--blaze);
  display:flex; align-items:center; justify-content:center; font-size:15px; font-weight:700; }
.rail__step:last-child .rail__arrow{ display:none; }
@media(max-width:720px){ .rail{ grid-template-columns:1fr; } .rail__step{ border-right:0; border-bottom:1px solid var(--line); }
  .rail__step:last-child{ border-bottom:0; } .rail__arrow{ display:none; } }

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .metrics{ grid-template-columns:repeat(2,1fr); }
  .sectors{ grid-template-columns:repeat(2,1fr); }
  .posts{ grid-template-columns:repeat(2,1fr); }
  .shead--split{ grid-template-columns:1fr; gap:24px; }
  .footer__top{ grid-template-columns:1fr 1fr; gap:32px; }
}
@media (max-width:720px){
  .nav__links{ display:none; }
  .nav__btn-mobile{ display:flex; }
  .nav__cta .login{ display:none; }
  .mobile-menu{ display:none; flex-direction:column; gap:4px; padding:18px var(--pad) 28px;
    border-bottom:1px solid var(--line); background:var(--g-1); }
  .mobile-menu.open{ display:flex; }
  .mobile-menu a{ padding:12px 0; border-bottom:1px solid var(--line); color:var(--steel);
    text-transform:uppercase; font-weight:600; font-size:15px; }
  .mobile-menu .btn{ justify-content:center; margin-top:10px; }
  .metrics,.sectors{ grid-template-columns:1fr 1fr; }
  .posts{ grid-template-columns:1fr; }
  .footer__top{ grid-template-columns:1fr 1fr; }
  .qual__cols{ grid-template-columns:1fr !important; }
}
