/* ============================================================
   BLOQUES-EXTRA.CSS — Biblioteca extendida de bloques (Sistema Web HKR)
   Extiende bloques.css con 27 variantes NUEVAS y distintas para
   maximizar la variabilidad y evitar la "sameness" de plantilla.
   Usa SOLO variables de tokens.css. Nunca colores/fuentes hardcodeados.
   Tokens: --brand-1..5, --accent, --accent-ink, --ink, --ink-soft,
   --surface, --surface-2, --card, --line, --font-display, --font-body,
   --radius, --maxw, --shadow, --ease.
   Clases con prefijos nuevos para no colisionar con las existentes.
   ============================================================ */

/* ============================================================ 1. HERO--SPLIT (texto izq, media der; no full-bg) */
.herox{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:center;
  padding:clamp(96px,12vw,150px) 0 clamp(48px,7vw,84px)}
.herox__copy .eyebrow{display:inline-block}
.herox h1{font-size:clamp(2.2rem,5.2vw,3.8rem);font-weight:800;margin-top:12px}
.herox p{color:var(--ink-soft);font-size:clamp(1rem,1.7vw,1.22rem);margin-top:18px;max-width:48ch}
.herox__cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.herox__media{position:relative;border-radius:calc(var(--radius)*2);overflow:hidden;box-shadow:var(--shadow)}
.herox__media img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;transition:transform .6s var(--ease)}
.herox__media:hover img{transform:scale(1.04)}
.herox__badge{position:absolute;left:18px;bottom:18px;background:var(--card);color:var(--ink);
  border:1.5px solid var(--line);border-radius:var(--radius);padding:12px 16px;font-size:13px;font-weight:600;box-shadow:var(--shadow)}
@media(max-width:860px){.herox{grid-template-columns:1fr;text-align:left}}

/* ============================================================ 2. HERO--CENTERED (texto centrado, bg degradé de marca) */
.heroc{position:relative;text-align:center;color:#fff;overflow:hidden;
  padding:clamp(120px,16vw,190px) 0 clamp(64px,9vw,110px);
  background:linear-gradient(135deg,var(--brand-1) 0%,var(--brand-2) 55%,var(--brand-3) 100%)}
.heroc::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 60% at 50% 0%,color-mix(in oklab,#fff,transparent 90%),transparent 70%)}
.heroc__in{position:relative;z-index:1;max-width:760px;margin:0 auto;padding:0 clamp(20px,5vw,40px)}
.heroc .eyebrow{color:var(--accent-ink);opacity:.92}
.heroc h1{font-size:clamp(2.4rem,6vw,4.4rem);font-weight:800;margin-top:14px}
.heroc p{font-size:clamp(1.05rem,1.9vw,1.32rem);color:rgba(255,255,255,.9);margin:18px auto 0;max-width:54ch}
.heroc__cta{display:flex;gap:14px;justify-content:center;margin-top:34px;flex-wrap:wrap}

/* ============================================================ 3. HERO--MINIMAL (tipográfico, sin imagen) */
.herom{padding:clamp(120px,17vw,210px) 0 clamp(56px,8vw,96px);border-bottom:1px solid var(--line)}
.herom__lede{font-family:var(--font-display);font-weight:800;letter-spacing:-0.03em;
  font-size:clamp(2.4rem,8vw,6rem);line-height:1.02;max-width:16ch}
.herom__lede em{font-style:normal;color:var(--accent)}
.herom__row{display:flex;gap:clamp(20px,4vw,52px);align-items:end;justify-content:space-between;
  margin-top:clamp(28px,5vw,52px);flex-wrap:wrap}
.herom__row p{color:var(--ink-soft);max-width:42ch;font-size:clamp(1rem,1.6vw,1.15rem)}
.herom__cta{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:640px){.herom__row{align-items:flex-start}}

/* ============================================================ 4. FEATURE--ZIGZAG (filas alternadas, icono + texto) */
.fzig{display:flex;flex-direction:column;gap:clamp(40px,7vw,96px);margin-top:48px}
.fzig__row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
/* zigzag real: en filas pares la imagen va a la DERECHA (la media está primera en el DOM, así que
   para alternar hay que MANDARLA AL FINAL con order:2 — order:-1 no hacía nada porque ya iba primera). */
.fzig__row:nth-child(even) .fzig__media{order:2}
.fzig__media{border-radius:calc(var(--radius)*1.8);overflow:hidden;box-shadow:var(--shadow);background:var(--surface-2)}
.fzig__media img{width:100%;height:auto;aspect-ratio:16/11;object-fit:cover;transition:transform .5s var(--ease)}
.fzig__row:hover .fzig__media img{transform:scale(1.04)}
.fzig__ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:22px;
  background:color-mix(in oklab,var(--accent),transparent 86%);color:var(--accent)}
.fzig__copy h3{font-size:clamp(1.3rem,2.6vw,1.9rem);margin-top:18px}
.fzig__copy p{color:var(--ink-soft);margin-top:12px;max-width:46ch}
@media(max-width:760px){.fzig__row{grid-template-columns:1fr}.fzig__row:nth-child(even) .fzig__media{order:0}}

/* ============================================================ 5. FEATURE--BENTO (grid bento de tarjetas de tamaño mixto) */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(150px,auto);
  gap:16px;margin-top:46px}
.bento__cell{background:var(--card);border:1.5px solid var(--line);border-radius:calc(var(--radius)*1.5);
  padding:26px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;
  transition:transform .2s var(--ease),box-shadow .2s,border-color .2s}
.bento__cell:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--accent)}
.bento__cell--lg{grid-column:span 2;grid-row:span 2}
.bento__cell--wide{grid-column:span 2}
.bento__cell--accent{background:linear-gradient(140deg,var(--brand-1),var(--brand-2));color:#fff;border-color:transparent}
.bento__cell .k{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;color:var(--accent)}
.bento__cell--accent .k{color:#fff}
.bento__cell h3{font-size:1.15rem;margin-top:8px}
.bento__cell p{color:var(--ink-soft);font-size:14px;margin-top:6px}
.bento__cell--accent p{color:rgba(255,255,255,.85)}
@media(max-width:820px){.bento{grid-template-columns:repeat(2,1fr)}.bento__cell--lg{grid-column:span 2;grid-row:span 1}}
@media(max-width:520px){.bento{grid-template-columns:1fr}.bento__cell--lg,.bento__cell--wide{grid-column:span 1}}

/* ============================================================ 6. LOGOS--MARQUEE (fila de logos en scroll infinito) */
.lmar{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.lmar__track{display:flex;gap:clamp(40px,6vw,80px);width:max-content;animation:lmar-scroll 32s linear infinite}
.lmar:hover .lmar__track{animation-play-state:paused}
.lmar__item{display:flex;align-items:center;height:48px;font-family:var(--font-display);font-weight:800;
  font-size:1.25rem;letter-spacing:-0.01em;color:var(--ink-soft);opacity:.7;transition:opacity .2s,color .2s}
.lmar__item:hover{opacity:1;color:var(--ink)}
.lmar__item img{height:100%;width:auto;object-fit:contain;filter:grayscale(1);transition:filter .2s}
.lmar__item:hover img{filter:none}
@keyframes lmar-scroll{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.lmar__track{animation:none;flex-wrap:wrap;justify-content:center}
  .lmar{-webkit-mask-image:none;mask-image:none}}

/* ============================================================ 7. STAT--CARDS (tarjetas con números grandes) */
.statc{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:46px}
.statc__c{background:var(--card);border:1.5px solid var(--line);border-radius:calc(var(--radius)*1.5);
  padding:30px 26px;transition:transform .2s var(--ease),box-shadow .2s}
.statc__c:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.statc__c b{font-family:var(--font-display);font-size:clamp(2.2rem,4.5vw,3.2rem);font-weight:800;
  line-height:1;display:block;color:var(--brand-1)}
.statc__c .lbl{font-size:14px;color:var(--ink-soft);margin-top:10px;display:block}
.statc__c .delta{font-size:12.5px;font-weight:700;color:var(--accent);margin-top:8px;display:inline-block;
  background:color-mix(in oklab,var(--accent),transparent 88%);padding:3px 9px;border-radius:20px}
@media(max-width:820px){.statc{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.statc{grid-template-columns:1fr}}

/* ============================================================ 8. ACCORDION (CSS puro con <details>, distinto de .faq) */
.acc{display:flex;flex-direction:column;gap:12px;margin-top:40px;max-width:820px}
.acc__item{border:1.5px solid var(--line);border-radius:calc(var(--radius)*1.2);background:var(--card);
  overflow:hidden;transition:border-color .2s,box-shadow .2s}
.acc__item[open]{border-color:var(--accent);box-shadow:var(--shadow)}
.acc__item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:20px 24px;font-family:var(--font-display);font-weight:700;font-size:1.08rem}
.acc__item summary::-webkit-details-marker{display:none}
.acc__item summary:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}
.acc__item summary::after{content:"+";font-size:1.5rem;font-weight:400;color:var(--accent);
  flex:0 0 auto;transition:transform .25s var(--ease)}
.acc__item[open] summary::after{transform:rotate(45deg)}
.acc__body{padding:0 24px 22px;color:var(--ink-soft);font-size:15px}
@media(prefers-reduced-motion:reduce){.acc__item summary::after{transition:none}}

/* ============================================================ 9. TABS (CSS-only con radios) */
.tabs{margin-top:40px}
.tabs input{position:absolute;opacity:0;pointer-events:none}
.tabs__nav{display:flex;gap:6px;flex-wrap:wrap;border-bottom:1.5px solid var(--line);padding-bottom:2px}
.tabs__nav label{cursor:pointer;padding:11px 20px;font-weight:600;font-size:14.5px;color:var(--ink-soft);
  border-radius:var(--radius) var(--radius) 0 0;border:1.5px solid transparent;border-bottom:none;
  transition:color .2s,background .2s}
.tabs__nav label:hover{color:var(--ink)}
.tabs input:focus-visible+label{outline:2px solid var(--accent);outline-offset:2px}
.tabs__panel{display:none;padding:28px 4px;color:var(--ink-soft);animation:tabs-fade .3s var(--ease)}
.tabs__panel h3{color:var(--ink);font-size:1.3rem;margin-bottom:10px}
/* mapeo radio→label activo + panel (hasta 5 tabs) */
.tabs input:nth-of-type(1):checked~.tabs__nav label:nth-of-type(1),
.tabs input:nth-of-type(2):checked~.tabs__nav label:nth-of-type(2),
.tabs input:nth-of-type(3):checked~.tabs__nav label:nth-of-type(3),
.tabs input:nth-of-type(4):checked~.tabs__nav label:nth-of-type(4),
.tabs input:nth-of-type(5):checked~.tabs__nav label:nth-of-type(5){
  color:var(--brand-1);background:var(--card);border-color:var(--line);position:relative;top:1.5px}
.tabs input:nth-of-type(1):checked~.tabs__panels .tabs__panel:nth-of-type(1),
.tabs input:nth-of-type(2):checked~.tabs__panels .tabs__panel:nth-of-type(2),
.tabs input:nth-of-type(3):checked~.tabs__panels .tabs__panel:nth-of-type(3),
.tabs input:nth-of-type(4):checked~.tabs__panels .tabs__panel:nth-of-type(4),
.tabs input:nth-of-type(5):checked~.tabs__panels .tabs__panel:nth-of-type(5){display:block}
@keyframes tabs-fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.tabs__panel{animation:none}}

/* ============================================================ 10. COMPARE--TABLE (comparativa de features, sin precios) */
.cmp{width:100%;border-collapse:separate;border-spacing:0;margin-top:42px;
  border:1.5px solid var(--line);border-radius:calc(var(--radius)*1.4);overflow:hidden}
.cmp th,.cmp td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--line);font-size:15px}
.cmp thead th{background:var(--brand-1);color:#fff;font-family:var(--font-display);font-weight:700}
.cmp thead th.is-feat{background:var(--brand-2)}
.cmp tbody th{font-weight:600;color:var(--ink)}
.cmp tbody tr:nth-child(even) td,.cmp tbody tr:nth-child(even) th{background:var(--surface-2)}
.cmp tbody tr:hover td,.cmp tbody tr:hover th{background:color-mix(in oklab,var(--accent),transparent 92%)}
.cmp td:last-child,.cmp th:last-child{border-right:none}
.cmp .yes{color:var(--accent);font-weight:800}
.cmp .no{color:var(--ink-soft);opacity:.6}
.cmp tr:last-child td,.cmp tr:last-child th{border-bottom:none}
@media(max-width:680px){.cmp{display:block;overflow-x:auto;white-space:nowrap}}

/* ============================================================ 11. STEPS--VERTICAL (pasos numerados con línea conectora) */
.svert{margin-top:44px;max-width:760px;counter-reset:svstep}
.svert__step{position:relative;padding:0 0 clamp(28px,4vw,44px) 64px}
.svert__step::before{counter-increment:svstep;content:counter(svstep);position:absolute;left:0;top:0;
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;z-index:1;
  font-family:var(--font-display);font-weight:800;background:var(--accent);color:var(--accent-ink)}
.svert__step::after{content:"";position:absolute;left:21px;top:44px;bottom:0;width:2px;background:var(--line)}
.svert__step:last-child{padding-bottom:0}
.svert__step:last-child::after{display:none}
.svert__step h3{font-size:1.2rem;margin-bottom:6px}
.svert__step p{color:var(--ink-soft);font-size:15px}

/* ============================================================ 12. QUOTE--CARD (grid de testimonios, 2-3 columnas) */
.qcards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px}
.qcard{background:var(--card);border:1.5px solid var(--line);border-radius:calc(var(--radius)*1.5);
  padding:30px 28px;display:flex;flex-direction:column;transition:transform .2s var(--ease),box-shadow .2s}
.qcard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.qcard__mark{font-family:var(--font-display);font-size:3rem;line-height:.6;color:var(--accent);opacity:.6}
.qcard blockquote{font-size:15.5px;color:var(--ink);margin-top:12px;flex:1}
.qcard__who{display:flex;align-items:center;gap:12px;margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}
.qcard__av{width:42px;height:42px;border-radius:50%;object-fit:cover;background:var(--surface-2);flex:0 0 auto}
.qcard__who b{font-size:14.5px;display:block}
.qcard__who span{font-size:13px;color:var(--ink-soft)}
@media(max-width:860px){.qcards{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.qcards{grid-template-columns:1fr}}

/* ============================================================ 13. CTA--SPLIT (CTA con form a un lado) */
.ctaform{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,56px);align-items:center;
  background:linear-gradient(135deg,var(--brand-1),var(--brand-3));color:#fff;
  border-radius:calc(var(--radius)*2);padding:clamp(32px,5vw,56px)}
.ctaform__copy h2{font-size:clamp(1.7rem,3.4vw,2.5rem);font-weight:800}
.ctaform__copy p{color:rgba(255,255,255,.88);margin-top:14px;max-width:42ch}
.ctaform__form{background:var(--card);border-radius:calc(var(--radius)*1.4);padding:28px;display:grid;gap:12px;box-shadow:var(--shadow)}
.ctaform__form label{font-size:13px;font-weight:600;color:var(--ink-soft)}
.ctaform__form input,.ctaform__form textarea{width:100%;font-family:var(--font-body);font-size:15px;color:var(--ink);
  background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius);padding:12px 14px;transition:border-color .2s,box-shadow .2s}
.ctaform__form input:focus,.ctaform__form textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in oklab,var(--accent),transparent 80%)}
.ctaform__form button{margin-top:6px}
@media(max-width:820px){.ctaform{grid-template-columns:1fr}}

/* ============================================================ 14. BANNER--RIBBON (cinta de anuncio full-width) */
.ribbon{background:var(--accent);color:var(--accent-ink);font-weight:600;font-size:14.5px}
.ribbon__in{max-width:var(--maxw,1180px);margin:0 auto;padding:12px clamp(20px,5vw,40px);
  display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;text-align:center}
.ribbon__in .pill{background:color-mix(in oklab,var(--accent-ink),transparent 82%);
  padding:3px 11px;border-radius:20px;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
.ribbon a{font-weight:800;text-decoration:underline;text-underline-offset:3px}
.ribbon a:hover{opacity:.8}

/* ============================================================ 15. CARDS--ICON (tarjetas de feature con icono, 4-up) */
.icards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:46px}
.icard{background:var(--card);border:1.5px solid var(--line);border-radius:calc(var(--radius)*1.5);
  padding:28px 24px;transition:transform .2s var(--ease),box-shadow .2s,border-color .2s}
.icard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--accent)}
.icard__ic{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:22px;
  background:color-mix(in oklab,var(--brand-1),transparent 88%);color:var(--brand-1);transition:background .2s,color .2s}
.icard:hover .icard__ic{background:var(--accent);color:var(--accent-ink)}
.icard h3{font-size:1.15rem;margin-top:18px}
.icard p{color:var(--ink-soft);font-size:14px;margin-top:9px}
@media(max-width:860px){.icards{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.icards{grid-template-columns:1fr}}

/* ============================================================ 16. MEDIA--FULLBLEED (banda full-bleed con overlay) */
.fbleed{position:relative;min-height:clamp(340px,52vh,560px);display:flex;align-items:center;
  color:#fff;overflow:hidden;border-radius:calc(var(--radius)*2)}
.fbleed img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.fbleed::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,color-mix(in oklab,var(--brand-1),transparent 8%) 0%,
    color-mix(in oklab,var(--brand-1),transparent 55%) 60%,transparent 100%)}
.fbleed__in{padding:clamp(32px,6vw,64px);max-width:560px}
.fbleed h2{font-size:clamp(1.8rem,4vw,3rem);font-weight:800}
.fbleed p{color:rgba(255,255,255,.9);margin-top:14px;max-width:42ch}
.fbleed .btn{margin-top:26px}

/* ============================================================ 17. LIST--CHECKS (checklist de beneficios a 2 columnas) */
.checks{display:grid;grid-template-columns:1fr 1fr;gap:14px 40px;margin-top:42px;max-width:900px}
.checks li{list-style:none;display:flex;gap:13px;align-items:flex-start;font-weight:500;font-size:15.5px}
.checks li .ck{flex:0 0 26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:14px;margin-top:1px;
  background:color-mix(in oklab,var(--accent),transparent 84%);color:var(--accent);font-weight:800}
.checks li span{color:var(--ink-soft);font-weight:400}
@media(max-width:640px){.checks{grid-template-columns:1fr}}

/* ============================================================ 18. CTA--BOXED (tarjeta CTA centrada en caja) */
.ctabox{max-width:760px;margin:0 auto;text-align:center;background:var(--card);
  border:1.5px solid var(--line);border-radius:calc(var(--radius)*2);padding:clamp(36px,6vw,64px);
  box-shadow:var(--shadow);position:relative;overflow:hidden}
.ctabox::before{content:"";position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none;
  background:radial-gradient(70% 90% at 50% -10%,color-mix(in oklab,var(--accent),transparent 88%),transparent 70%)}
.ctabox>*{position:relative;z-index:1}
.ctabox h2{font-size:clamp(1.6rem,3.4vw,2.4rem);font-weight:800}
.ctabox p{color:var(--ink-soft);margin:14px auto 0;max-width:46ch}
.ctabox__cta{display:flex;gap:14px;justify-content:center;margin-top:28px;flex-wrap:wrap}

/* ============================================================ 19. GALLERY--MASONRY (galería masonry, distinta de .gallery) */
.mason{columns:3 260px;column-gap:14px;margin-top:46px}
.mason__item{break-inside:avoid;margin-bottom:14px;border-radius:calc(var(--radius)*1.3);overflow:hidden;
  position:relative;box-shadow:var(--shadow);background:var(--surface-2)}
.mason__item img{width:100%;height:auto;display:block;transition:transform .5s var(--ease)}
.mason__item:hover img{transform:scale(1.05)}
.mason__cap{position:absolute;inset:auto 0 0 0;padding:14px 16px;color:#fff;font-size:13.5px;font-weight:600;
  background:linear-gradient(transparent,color-mix(in oklab,var(--brand-1),transparent 25%));
  opacity:0;transform:translateY(8px);transition:opacity .25s var(--ease),transform .25s var(--ease)}
.mason__item:hover .mason__cap{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.mason__item img,.mason__cap{transition:none}}
@media(max-width:520px){.mason{columns:1}}

/* ============================================================ 20. SPEC--CARDS (tarjetas destacando especificaciones) */
.speccards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:46px}
.speccard{background:var(--surface-2);border:1.5px solid var(--line);border-radius:calc(var(--radius)*1.5);
  padding:26px;display:flex;flex-direction:column;gap:12px;transition:transform .2s var(--ease),box-shadow .2s}
.speccard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.speccard__hd{display:flex;align-items:center;gap:12px}
.speccard__ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:19px;
  background:var(--brand-1);color:#fff;flex:0 0 auto}
.speccard__hd h3{font-size:1.1rem}
.speccard dl{display:grid;grid-template-columns:auto 1fr;gap:8px 14px;font-size:14px}
.speccard dt{color:var(--ink-soft)}
.speccard dd{text-align:right;font-weight:600;color:var(--ink)}
@media(max-width:820px){.speccards{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.speccards{grid-template-columns:1fr}}

/* ============================================================ 21. CONTACT--MINI (tira de contacto compacta con iconos) */
.cmini{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:42px}
.cmini__item{display:flex;align-items:center;gap:14px;background:var(--card);border:1.5px solid var(--line);
  border-radius:calc(var(--radius)*1.3);padding:18px 20px;transition:border-color .2s,box-shadow .2s,transform .2s var(--ease)}
.cmini__item:hover{border-color:var(--accent);box-shadow:var(--shadow);transform:translateY(-2px)}
.cmini__ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:19px;flex:0 0 auto;
  background:color-mix(in oklab,var(--accent),transparent 86%);color:var(--accent)}
.cmini__item .lbl{font-size:12.5px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.cmini__item b{font-size:15px;display:block;margin-top:2px}
.cmini__item a:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
@media(max-width:760px){.cmini{grid-template-columns:1fr}}

/* ============================================================ 22. FAQ--TWO-COL (FAQ a dos columnas) */
.faq2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);margin-top:44px}
.faq2__col{display:flex;flex-direction:column;gap:22px}
.faq2__q{font-family:var(--font-display);font-weight:700;font-size:1.08rem;
  padding-bottom:8px;border-bottom:2px solid var(--accent);display:inline-block}
.faq2__a{color:var(--ink-soft);font-size:15px;margin-top:10px}
@media(max-width:760px){.faq2{grid-template-columns:1fr;gap:22px}}

/* ============================================================ 23. PROCESS--HORIZONTAL (scroll-snap horizontal) */
.phoriz{display:flex;gap:18px;margin-top:46px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:16px;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.phoriz__step{scroll-snap-align:start;flex:0 0 clamp(240px,72vw,300px);background:var(--card);
  border:1.5px solid var(--line);border-radius:calc(var(--radius)*1.5);padding:28px;
  counter-increment:phstep;transition:border-color .2s,box-shadow .2s}
.phoriz{counter-reset:phstep}
.phoriz__step:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.phoriz__step::before{content:counter(phstep,decimal-leading-zero);font-family:var(--font-display);
  font-weight:800;font-size:1.6rem;color:var(--accent);display:block}
.phoriz__step h3{font-size:1.15rem;margin-top:12px}
.phoriz__step p{color:var(--ink-soft);font-size:14px;margin-top:8px}
.phoriz::-webkit-scrollbar{height:8px}
.phoriz::-webkit-scrollbar-thumb{background:var(--line);border-radius:20px}

/* ============================================================ 24. BADGE--ROW (fila de sellos de confianza) */
.brow{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:40px}
.brow__b{display:inline-flex;align-items:center;gap:10px;background:var(--surface-2);
  border:1.5px solid var(--line);border-radius:50px;padding:10px 18px;font-size:13.5px;font-weight:600;
  transition:border-color .2s,transform .2s var(--ease)}
.brow__b:hover{border-color:var(--accent);transform:translateY(-2px)}
.brow__b .ic{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:13px;
  background:var(--accent);color:var(--accent-ink);flex:0 0 auto}
.brow__b span{color:var(--ink-soft)}

/* ============================================================ 25. CTA--GRADIENT (banda CTA con color comprometido de marca) */
.ctagrad{background:linear-gradient(120deg,var(--brand-1) 0%,var(--brand-2) 50%,var(--brand-4) 100%);
  color:#fff;text-align:center;border-radius:calc(var(--radius)*2)}
.ctagrad__in{padding:clamp(44px,7vw,84px) clamp(20px,5vw,40px);max-width:720px;margin:0 auto}
.ctagrad h2{font-size:clamp(1.8rem,4vw,2.9rem);font-weight:800}
.ctagrad p{color:rgba(255,255,255,.9);margin:16px auto 0;max-width:48ch}
.ctagrad__cta{display:flex;gap:14px;justify-content:center;margin-top:30px;flex-wrap:wrap}
.ctagrad .btn--light:hover{filter:brightness(1.04)}

/* ============================================================ 26. TABLE--DATA (tabla de datos limpia) */
.dtable{width:100%;border-collapse:collapse;margin-top:42px;font-size:15px}
.dtable caption{text-align:left;color:var(--ink-soft);font-size:13px;margin-bottom:12px}
.dtable th,.dtable td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line)}
.dtable thead th{font-family:var(--font-display);font-weight:700;color:var(--ink);
  border-bottom:2px solid var(--ink);text-transform:none}
.dtable tbody tr{transition:background .15s}
.dtable tbody tr:hover{background:color-mix(in oklab,var(--accent),transparent 93%)}
.dtable td.num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.dtable tfoot td{font-weight:700;border-top:2px solid var(--ink);border-bottom:none}
@media(max-width:680px){.dtable{display:block;overflow-x:auto}}

/* ============================================================ 27. DIVIDER--LABEL (divisor de sección con etiqueta centrada) */
.dlabel{display:flex;align-items:center;gap:20px;margin:clamp(40px,6vw,72px) 0;color:var(--ink-soft)}
.dlabel::before,.dlabel::after{content:"";flex:1;height:1px;background:var(--line)}
.dlabel span{font-family:var(--font-body);font-size:12.5px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);white-space:nowrap}

/* ============================================================ BIBLIOTECA: SELECTOR DE IDIOMA (8 variantes)
   Variabilidad entre clientes SIN romper la función que el gate prueba en vivo:
   el contenedor #langsw.lang siempre contiene botones [data-lang] que disparan applyLang.
   Variante por sitio con la clase .lang--<x> en el contenedor (la base .lang = v1 'pill').
   Desplegables (.lang--dropdown / .lang--flags-dd): los items SÍ existen en el DOM (display:none por CSS),
   se revelan con .open; el gate es dropdown-aware (abre el trigger antes de clickear). */

/* banderas SVG (NO emoji: los emoji de bandera no renderizan en Windows) */
.lang .fi{width:20px;height:13px;border-radius:2px;display:inline-block;flex:0 0 auto;
  box-shadow:0 0 0 1px rgba(0,0,0,.1);vertical-align:middle}
.lang__menu .fi{width:22px;height:15px}
.lang__trigger .gl{width:15px;height:15px;flex:0 0 auto}

/* ---------- 3 HORIZONTALES (muestran SIEMPRE claro el idioma activo) ---------- */
/* H1 pill = base .lang (en bloques.css) */
/* H2 underline — solo texto, activo subrayado con acento (claro qué está elegido) */
.lang--underline{background:transparent;gap:14px;padding:0}
.lang--underline button{padding:4px 1px;border-radius:0;opacity:.6;font-weight:600}
.lang--underline button.on{opacity:1;box-shadow:inset 0 -2px 0 var(--accent);color:var(--accent)}
.nav.scrolled .lang--underline button.on{color:var(--accent-text,var(--accent))}
/* H3 flags — banderas + código, activo con caja de acento */
.lang--flags{background:transparent;gap:6px;padding:0}
.lang--flags button{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:8px;opacity:.55;font-weight:700}
.lang--flags button.on{opacity:1;background:color-mix(in oklab,var(--accent),transparent 78%)}

/* ---------- 5 DESPLEGABLES (base compartida .lang--dd + estilo de trigger por variante) ---------- */
.lang--dd{position:relative;background:transparent;padding:0;gap:0}
.lang--dd .lang__trigger{display:inline-flex;align-items:center;gap:7px;font:inherit;font-size:12.5px;
  font-weight:700;color:inherit;cursor:pointer;line-height:1;border:none}
.lang--dd .lang__trigger::after{content:"▾";font-size:10px;opacity:.7;transition:transform .2s var(--ease)}
.lang--dd.open .lang__trigger::after{transform:rotate(180deg)}
.lang--dd .lang__menu{position:absolute;top:calc(100% + 8px);right:0;display:none;flex-direction:column;gap:2px;
  background:var(--card);border:1px solid var(--line);border-radius:10px;padding:6px;box-shadow:var(--shadow);
  min-width:150px;z-index:60}
.lang--dd.open .lang__menu{display:flex}
.lang--dd .lang__menu button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;font:inherit;
  font-size:13.5px;font-weight:600;color:var(--ink);background:transparent;border:none;border-radius:7px;
  padding:9px 11px;cursor:pointer}
.lang--dd .lang__menu button:hover{background:var(--surface-2)}
.lang--dd .lang__menu button.on{color:var(--accent-text,var(--accent))}
.lang--dd .lang__menu button.on::after{content:"✓";margin-left:auto;color:var(--accent)}

/* D1 dropdown — trigger en chip con caja, menú de códigos con check */
.lang--dropdown .lang__trigger{background:rgba(255,255,255,.12);border-radius:8px;padding:7px 12px}
.nav.scrolled .lang--dropdown .lang__trigger{background:var(--surface-2);color:var(--ink)}

/* D2 flags-dd — bandera + código en el trigger; menú con bandera + nombre nativo */
.lang--flags-dd .lang__trigger{background:rgba(255,255,255,.12);border-radius:8px;padding:6px 11px}
.nav.scrolled .lang--flags-dd .lang__trigger{background:var(--surface-2);color:var(--ink)}

/* D3 dd-ghost — trigger sin caja, solo texto con subrayado de acento (sutil pero claro) */
.lang--dd-ghost .lang__trigger{padding:5px 2px;border-bottom:2px solid var(--accent);border-radius:0}

/* D4 dd-globe — ícono globo + código, pastilla redonda; menú compacto centrado */
.lang--dd-globe .lang__trigger{background:rgba(255,255,255,.10);border-radius:30px;padding:7px 14px}
.nav.scrolled .lang--dd-globe .lang__trigger{background:var(--surface-2);color:var(--ink)}
.lang--dd-globe .lang__menu{min-width:124px}
.lang--dd-globe .lang__menu button{justify-content:center;text-align:center}
.lang--dd-globe .lang__menu button.on::after{display:none}

/* D5 dd-wide — trigger ancho con bandera + nombre nativo y borde; menú con bandera + nombre */
.lang--dd-wide .lang__trigger{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);
  border-radius:9px;padding:8px 14px;font-weight:600}
.nav.scrolled .lang--dd-wide .lang__trigger{background:var(--surface-2);border-color:var(--line);color:var(--ink)}
.lang--dd-wide .lang__menu{min-width:184px}

/* ---------- 3 NUEVAS (jun-2026) basadas en plugins reales (Weglot/WPML/Polylang/GTranslate) ----------
   Best-practice de los plugios líderes: NOMBRES NATIVOS sobre banderas (país≠idioma), ícono globo
   como símbolo universal de "traducir", panel ancho tipo Weglot, y selector flotante no-modal
   (patrón Patagonia/Alibaba). Conservan el contrato: #langsw + [data-lang] que disparan applyLang. */

/* H4 native — horizontal, NOMBRES NATIVOS (English/Español/中文), activo en acento. Text-based puro. */
.lang--native{background:transparent;gap:4px;padding:0}
.lang--native button{padding:5px 10px;border-radius:7px;font-weight:600;opacity:.6;letter-spacing:.01em}
.lang--native button.on{opacity:1;color:var(--accent-text,var(--accent));background:color-mix(in oklab,var(--accent),transparent 86%)}
.nav.scrolled .lang--native button.on{color:var(--accent)}

/* D6 panel — trigger globo + código; PANEL ancho tipo Weglot: nombre nativo + nombre en inglés debajo */
.lang--panel .lang__trigger{background:rgba(255,255,255,.10);border-radius:9px;padding:7px 13px}
.nav.scrolled .lang--panel .lang__trigger{background:var(--surface-2);color:var(--ink)}
.lang--panel .lang__menu{min-width:208px;padding:8px}
.lang--panel .lang__menu button{flex-direction:column;align-items:flex-start;gap:1px;padding:9px 12px}
.lang--panel .lang__menu button .ln-native{font-weight:700;font-size:14px}
.lang--panel .lang__menu button .ln-sub{font-weight:500;font-size:11.5px;color:var(--ink-faint)}
.lang--panel .lang__menu button.on .ln-sub{color:var(--accent-text,var(--accent))}
.lang--panel .lang__menu button.on::after{position:absolute;right:12px}
.lang--panel .lang__menu button{position:relative}

/* FLOATING — selector NO en el header: botón globo fijo abajo-derecha que abre una tarjeta no-modal
   (patrón Patagonia/Alibaba). El #langsw va al final del <body>, no dentro del nav. */
.lang--floating{position:fixed;right:22px;bottom:22px;z-index:80;background:transparent;padding:0;gap:0;display:inline-flex}
.lang--floating .lang__trigger{display:inline-flex;align-items:center;gap:8px;font:inherit;font-size:13px;font-weight:700;
  color:#fff;cursor:pointer;border:none;background:var(--accent);border-radius:30px;padding:11px 17px;
  box-shadow:0 10px 26px -10px rgba(0,0,0,.45)}
.lang--floating .lang__trigger .gl{width:17px;height:17px}
.lang--floating .lang__trigger::after{content:"";}
.lang--floating .lang__menu{position:absolute;right:0;bottom:calc(100% + 10px);display:none;flex-direction:column;gap:2px;
  background:var(--card);border:1px solid var(--line);border-radius:12px;padding:7px;box-shadow:var(--shadow);min-width:172px}
.lang--floating.open .lang__menu{display:flex}
.lang--floating .lang__menu button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;font:inherit;
  font-size:13.5px;font-weight:600;color:var(--ink);background:transparent;border:none;border-radius:8px;padding:9px 11px;cursor:pointer}
.lang--floating .lang__menu button:hover{background:var(--surface-2)}
.lang--floating .lang__menu button.on{color:var(--accent-text,var(--accent))}
.lang--floating .lang__menu button.on::after{content:"✓";margin-left:auto;color:var(--accent)}
@media(max-width:860px){.lang--floating{right:14px;bottom:14px}}

/* ============================================================ BIBLIOTECA: ESTRUCTURA DE HEADER (6 variantes)
   Variabilidad de la barra superior SIN cambiar el orden del DOM (burger/scroll/contraste dependen de él).
   Se reordena con CSS (order/grid). Variante por sitio con la clase .nav--<x> en <header class="nav">.
   Base .nav = 'classic' (logo izq · links centro · idioma+CTA der). Todas conservan #burger, #navlinks,
   #langsw y el comportamiento; en ≤860px todas colapsan al burger igual. */

/* V2 left — links pegados al logo (no centrados); CTA+idioma a la derecha */
@media(min-width:861px){
  .nav--left .nav__in{justify-content:flex-start;gap:clamp(24px,4vw,52px)}
  .nav--left .nav__cta{margin-left:auto}
}

/* V3 center-logo — logo centrado, links a la izquierda, CTA a la derecha (editorial) */
@media(min-width:861px){
  .nav--center-logo .nav__in{display:grid;grid-template-columns:1fr auto 1fr;align-items:center}
  .nav--center-logo .nav__links{order:1;justify-content:flex-start}
  .nav--center-logo .nav__logo{order:2;justify-self:center}
  .nav--center-logo .nav__cta{order:3;justify-self:end}
}

/* V5 cta-left — idioma+CTA a la izquierda, logo centrado, links a la derecha (invertido) */
@media(min-width:861px){
  .nav--cta-left .nav__in{display:grid;grid-template-columns:1fr auto 1fr;align-items:center}
  .nav--cta-left .nav__cta{order:1;justify-self:start}
  .nav--cta-left .nav__logo{order:2;justify-self:center}
  .nav--cta-left .nav__links{order:3;justify-self:end;justify-content:flex-end}
}

/* V6 boxed — la barra es una cápsula flotante con fondo (no full-bleed), separada del borde superior */
.nav--boxed{padding-top:14px}
.nav--boxed .nav__in{background:color-mix(in oklab,var(--brand-1),transparent 12%);
  border:1px solid rgba(255,255,255,.14);border-radius:calc(var(--radius)*2.4);
  padding-left:clamp(16px,2.4vw,28px);padding-right:clamp(12px,1.6vw,16px);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.nav--boxed.scrolled{background:transparent;box-shadow:none}
.nav--boxed.scrolled .nav__in{background:var(--surface);border-color:var(--line);box-shadow:var(--shadow)}
