/* ════════════════════════════════════════════════════════════════
   MINGA.CSS — Design system compartido de MingaJobs (FASE A)

   FUENTE ÚNICA de tokens para landing + páginas internas SSR.
   Canon de valores: packages/dashboard/tailwind.config.js + BRAND.md.
   Motion: sistema CSS-first extraído de landing.hbs (validado en prod).

   Reglas:
   - Los colores de marca NO se redefinen en ningún otro archivo.
   - Prohibido slate-*: texto = --ink / --ink-2 / --ink-3.
   - Todo motion respeta prefers-reduced-motion (Emil: "fewer and
     gentler, not zero").
   ════════════════════════════════════════════════════════════════ */

/* ──────────────────────────────────────────────
   TIPOGRAFÍA — Inter variable autohospedada
   Un solo woff2 cubre los pesos 100–900 (incluye
   400/600/800/900 de BRAND). latin-ext solo se
   descarga si la página usa esos caracteres.
   ────────────────────────────────────────────── */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/public/fonts/inter-var-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/public/fonts/inter-var-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7,
    U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F,
    U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F,
    U+A720-A7FF;
}

/* ──────────────────────────────────────────────
   TOKENS
   ────────────────────────────────────────────── */
:root {
  /* Marca (BRAND.md §3) */
  --violet:  #8B5CF6;
  --orange:  #FF6B35;
  --cyan:    #06B6D4;
  --navy:    #0F172A;
  --navy-d:  #0B1220;
  --navy-dd: #070E1A;
  --green:   #2EC4B6;
  --green-ink: #0E7C72;   /* Match Green legible sobre blanco (AA); #2EC4B6 solo sobre navy */
  --orange-ink: #B03508;   /* Naranja legible sobre blanco (AA); patrón análogo a --green-ink */
  --orange-soft: #f07c54;  /* Naranja suave para texto sobre fondos oscuros (navy/dark cards) */
  --violet-ink: #6D28D9;   /* Violeta legible sobre blanco (AA); #8B5CF6 solo sobre navy */
  --red:     #FF4F5E;
  --gold:    #FFCA28;

  /* Superficies — light (modo principal de las internas) */
  --bg-warm: #FAFAF9;
  --bg-soft: #F5F5F0;
  --bg-card: #FFFFFF;

  /* Texto — light (elimina slate-*) */
  --ink:   #1A1A1A;
  --ink-2: #6B7280;
  --ink-3: #9CA3AF;

  /* Bordes — light */
  --border:        #E5E7EB;
  --border-soft:   #F0F0F0;
  --border-strong: #1A1A1A;

  /* Texto sobre navy (header/footer/heros oscuros) */
  --t1: #FFFFFF;
  --t2: #CBD5E1;                    /* cuerpo, 5.4:1 sobre navy */
  --t3: #94A3B8;                    /* secundario */
  --t4: rgba(255, 255, 255, .28);

  /* Superficies sobre navy */
  --card-bg:     rgba(255, 255, 255, .045);
  --card-border: rgba(255, 255, 255, .08);
  --card-hover:  rgba(255, 255, 255, .07);

  /* Gradiente Minga-Energy — máximo 1 por página (BRAND.md) */
  --minga-energy: linear-gradient(135deg, #8B5CF6, #FF6B35);

  /* Radios (BRAND.md: card 8 / button 6 — nunca 20+) */
  --r-card:  8px;
  --r-btn:   6px;
  --r-input: 6px;
  --r-badge: 4px;

  /* Motion — tokens aprobados por JJ (landing) */
  --ease:     cubic-bezier(.16, 1, .3, 1);
  --ease-btn: cubic-bezier(.23, 1, .32, 1);
  --dur:      300ms;
  --dur-fast: 160ms;
  --reveal-y: 20px;

  /* Escala tipográfica fluida (modular ~1.25) */
  --text-hero: clamp(2.375rem, 5.5vw, 5.5rem);
  --text-h2:   clamp(1.875rem, 3.8vw, 3rem);
  --text-h3:   clamp(1.0625rem, 1.8vw, 1.25rem);
  --text-body: clamp(.9375rem, 1.6vw, 1.0625rem);
  --text-sm:   .875rem;
  --text-xs:   .8125rem;

  /* Layout */
  --pad-x:  clamp(20px, 6vw, 80px);
  --sec-py: clamp(80px, 10vw, 128px);
  --max-w:  1240px;

  /* Z-index */
  --z-nav:   100;
  --z-above: 10;
}

/* ──────────────────────────────────────────────
   REVEAL SYSTEM — CSS-first
   Por defecto TODO es visible (sin JS, crawlers,
   reduced-motion). html.js (clase añadida inline
   antes del primer paint) activa el estado oculto;
   minga.js añade .vis al entrar en viewport.
   ────────────────────────────────────────────── */
[data-reveal] {
  opacity: 1;
  transform: none;
}
html.js [data-reveal] {
  opacity: 0;
  transform: translateY(var(--reveal-y)) scale(0.96);
  filter: blur(8px);
  transition:
    opacity   380ms var(--ease),
    transform 380ms var(--ease),
    filter    340ms var(--ease);
}
html.js [data-reveal].vis {
  opacity: 1;
  transform: none;
  filter: blur(0);
  /* CAUSA DEL BLEED: html.js [data-reveal] define transition con 380ms para
     opacity/transform/filter. Esta regla tiene especificidad 0,0,2,1 y supera
     a las transiciones propias de .job-card (0,0,1,0) o .pain-card (0,0,1,0).
     Mientras el elemento esté en estado .vis, el hover heredaba la duración
     larga del reveal (380ms) en vez de su duración corta propia.
     FIX: una vez revelado (.vis), se resetea la transition a duraciones de
     hover: transform y box-shadow en var(--dur) (300ms), opacity/filter rápidos.
     Así el reveal anima a 380ms pero el hover usa su velocidad correcta. */
  transition:
    opacity    var(--dur-fast) var(--ease-btn),
    transform  var(--dur)      var(--ease),
    box-shadow var(--dur)      var(--ease),
    filter     var(--dur-fast) var(--ease-btn);
}

/* ──────────────────────────────────────────────
   MICRO-INTERACCIONES BASE
   .m-press → feedback táctil al click (Emil)
   .m-lift  → elevación sutil al hover (solo
              dispositivos con hover real)
   ────────────────────────────────────────────── */
.m-press:active { transform: scale(0.98); }

.m-lift {
  transition:
    transform  var(--dur-fast) var(--ease-btn),
    box-shadow var(--dur) var(--ease),
    border-color var(--dur-fast) var(--ease-btn);
}
@media (hover: hover) and (pointer: fine) {
  .m-lift:hover { transform: translateY(-2px); }
}

/* Foco visible consistente en todo el sitio */
:focus-visible {
  outline: 2px solid var(--orange);
  outline-offset: 3px;
}

/* ──────────────────────────────────────────────
   PREFERS-REDUCED-MOTION — genérico
   (cada página puede ampliar con sus selectores)
   ────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  html.js [data-reveal] {
    transform: none !important;
    filter: none !important;
    transition: opacity 200ms ease;
  }
  .m-lift, .m-lift:hover { transform: none !important; transition: none; }
  .m-press:active { transform: none; }
  html { scroll-behavior: auto; }
}

/* ──────────────────────────────────────────────
   CHROME COMPARTIDO — nav + footer navy (FASE B)
   Base extraída de landing.hbs (validada en prod).
   .nav         → fija y transparente (landing, sobre hero navy)
   .nav--solid  → sticky y navy sólido (páginas internas light)
   ────────────────────────────────────────────── */
.nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: var(--z-nav);
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--pad-x);
  background: transparent;
  transition:
    background var(--dur) var(--ease),
    border-color var(--dur) var(--ease),
    backdrop-filter var(--dur) var(--ease);
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(11,18,32,.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom-color: var(--card-border);
}
.nav--solid,
.nav--solid.scrolled {
  position: sticky;
  top: 0;
  background: var(--navy);
  border-bottom-color: rgba(255,255,255,.08);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.nav-logo { display: flex; align-items: center; }
.nav-logo-img { height: 32px; width: auto; display: block; }

.nav-links { display: flex; align-items: center; gap: 4px; }
.nav-a {
  font-size: .875rem;
  font-weight: 500;
  color: var(--t3);
  padding: 7px 12px;
  border-radius: var(--r-btn);
  transition:
    color      var(--dur-fast) var(--ease-btn),
    background var(--dur-fast) var(--ease-btn);
}
@media (hover: hover) and (pointer: fine) {
  .nav-a:hover { color: var(--t1); background: var(--card-bg); }
}
.nav-a:focus-visible { outline: 2px solid rgba(139,92,246,.6); outline-offset: 2px; }
.nav-cta {
  color: var(--t2) !important;
  border: 1px solid var(--card-border);
  background: var(--card-bg);
}
@media (hover: hover) and (pointer: fine) {
  .nav-cta:hover {
    color: var(--t1) !important;
    background: var(--card-hover);
    border-color: rgba(255,255,255,.16);
  }
}
@media (max-width: 600px) { .nav-links { display: none; } }

/* Footer navy compartido + watermark del escudo (~6%) */
.s-footer {
  position: relative;
  overflow: hidden;
  background: var(--navy-dd);
  padding: clamp(48px, 7vw, 80px) var(--pad-x) clamp(28px, 4vw, 40px);
  border-top: 1px solid rgba(255,255,255,.05);
}
.footer-watermark {
  position: absolute;
  right: -8%;
  bottom: -22%;
  width: clamp(320px, 36vw, 560px);
  height: auto;
  opacity: .06;
  pointer-events: none;
  user-select: none;
}
.footer-top {
  position: relative;
  max-width: var(--max-w);
  margin: 0 auto clamp(40px, 6vw, 60px);
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: clamp(32px, 5vw, 56px);
}
.footer-logo { display: flex; align-items: center; margin-bottom: 10px; }
.footer-logo-img { height: 38px; width: auto; display: block; }
.footer-tag { font-size: .875rem; line-height: 1.6; color: var(--t4); max-width: 28ch; }
.footer-col-title {
  font-size: .6875rem;
  font-weight: 700;
  color: var(--t4);
  letter-spacing: .07em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.footer-links { display: flex; flex-direction: column; gap: 8px; }
.footer-links a {
  font-size: .875rem;
  color: var(--t3);
  transition: color var(--dur-fast) var(--ease-btn);
}
@media (hover: hover) and (pointer: fine) { .footer-links a:hover { color: var(--t1); } }
.footer-links a:focus-visible { outline: 2px solid rgba(139,92,246,.5); outline-offset: 2px; border-radius: 2px; }
.footer-bottom {
  position: relative;
  max-width: var(--max-w);
  margin: 0 auto;
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.footer-legal { font-size: .8125rem; color: var(--t4); }
.footer-legal a { transition: color var(--dur-fast) var(--ease-btn); }
@media (hover: hover) and (pointer: fine) { .footer-legal a:hover { color: var(--t2); } }
.footer-eco { font-size: .8125rem; color: var(--t4); }
.footer-eco a { color: var(--violet); font-weight: 600; transition: opacity var(--dur-fast) var(--ease-btn); }
@media (hover: hover) and (pointer: fine) { .footer-eco a:hover { opacity: .7; } }

@media (max-width: 960px) { .footer-top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) {
  .footer-top { grid-template-columns: 1fr; gap: 28px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}

/* ──────────────────────────────────────────────
   JOB-CARD ÚNICA (FASE B)
   Light por defecto (internas). `.job-card--dark`
   replica el look de la landing sobre navy.
   ────────────────────────────────────────────── */
.jobs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
}
.job-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 20px;
  transition:
    transform    var(--dur) var(--ease),
    box-shadow   var(--dur) var(--ease),
    border-color var(--dur) var(--ease),
    background   var(--dur) var(--ease);
}
@media (hover: hover) and (pointer: fine) {
  .job-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(15,23,42,.10), 0 0 0 1px rgba(139,92,246,.14);
    border-color: rgba(139,92,246,.32);
  }
}
.jc-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 10px; }
.jc-title { margin: 0; font-size: .9375rem; font-weight: 700; color: var(--ink); line-height: 1.3; }
.jc-title-link { color: inherit; text-decoration: none; }
@media (hover: hover) and (pointer: fine) { .jc-title-link:hover .jc-title { color: var(--violet); } }

.badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 3px 8px;
  border-radius: 100px;
  font-size: .6875rem;
  font-weight: 700;
  flex-shrink: 0;
  margin-left: 6px;
}
.badge svg { width: 9px; height: 9px; }
.b-hi  { background: rgba(46,196,182,.14); color: var(--green-ink); }
.b-mid { background: rgba(255,107,53,.14); color: var(--orange-ink); }

.jc-meta {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: .75rem;
  color: var(--ink-2);
  margin-bottom: 4px;
}
.jc-meta svg { width: 11px; height: 11px; stroke-width: 1.5; }
.jc-date { margin-top: 10px; font-size: .75rem; color: var(--ink-3); }

.salary-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 3px 8px;
  background: rgba(46,196,182,.10);
  border: 1px solid rgba(46,196,182,.25);
  border-radius: var(--r-badge);
  font-size: .75rem;
  font-weight: 700;
  color: var(--green-ink);
  margin: 8px 0 14px;
}
.salary-badge svg { width: 11px; height: 11px; }

.btn-wa {
  width: 100%;
  padding: 9px 14px;
  background: var(--orange);
  color: #fff;
  border: none;
  border-radius: var(--r-btn);
  font-family: inherit;
  font-size: .8125rem;
  font-weight: 600;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 5px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.16);
  transition:
    opacity   var(--dur-fast) var(--ease-btn),
    transform var(--dur-fast) var(--ease-btn);
  text-decoration: none;
}
.btn-wa:active { transform: scale(0.97); }
@media (hover: hover) and (pointer: fine) { .btn-wa:hover { opacity: .88; } }
.btn-wa svg { width: 13px; height: 13px; }
.btn-wa:focus-visible { outline: 2px solid var(--orange); outline-offset: 2px; }

/* Modifier dark — look de la landing sobre navy */
.job-card--dark {
  background: var(--card-bg);
  border-color: var(--card-border);
}
@media (hover: hover) and (pointer: fine) {
  .job-card--dark:hover {
    background: rgba(255,255,255,.065);
    box-shadow: 0 16px 48px rgba(0,0,0,.38), 0 0 0 1px rgba(139,92,246,.18);
    border-color: rgba(139,92,246,.28);
  }
}
.job-card--dark .jc-title { color: var(--t1); }
@media (hover: hover) and (pointer: fine) { .job-card--dark .jc-title-link:hover .jc-title { color: #fff; } }
.job-card--dark .jc-meta { color: var(--t3); }
.job-card--dark .jc-date { color: var(--t4); }
.job-card--dark .b-hi  { background: rgba(46,196,182,.15); color: var(--green); }
.job-card--dark .b-mid { background: rgba(255,107,53,.15); color: var(--orange-soft); }
.job-card--dark .salary-badge {
  background: rgba(255,255,255,.06);
  border-color: var(--card-border);
  color: var(--t1);
}

@media (prefers-reduced-motion: reduce) {
  .job-card:hover, .btn-wa:active { transform: none !important; }
}

/* ──────────────────────────────────────────────
   LANDING ELEVACIÓN (FASE C) — sala de control con aurora
   Paneles B + luz A + escudo C. Solo la landing los usa hoy;
   las internas heredan .panel en la fase siguiente.
   ────────────────────────────────────────────── */

/* Panel elevado (dirección B) */
.panel {
  position: relative;
  background: var(--navy-d);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px;
  overflow: hidden;
}
.panel::before {                 /* borde superior iluminado */
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(139,92,246,.45), rgba(255,107,53,.35), transparent);
  pointer-events: none;
}

/* Aurora (dirección A): glow posicional por sección + separador de luz */
.sec-glow {
  position: absolute;
  width: min(720px, 80vw);
  aspect-ratio: 1;
  border-radius: 50%;
  filter: blur(90px);
  opacity: .10;
  pointer-events: none;
}
.sec-glow--violet { background: radial-gradient(circle, var(--violet), transparent 65%); }
.sec-glow--orange { background: radial-gradient(circle, var(--orange), transparent 65%); }
.sec-sep {
  height: 1px;
  max-width: var(--max-w);
  margin: 0 auto;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.10), transparent);
}
.sec--tight { padding-block: clamp(56px, 7vw, 88px); }

/* Chips flotantes del hero (máx 3; nunca en móvil) */
.hero-chip {
  position: absolute;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  background: rgba(11,18,32,.78);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 100px;
  font-size: .75rem;
  font-weight: 600;
  color: var(--t2);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}
.hero-chip svg { width: 12px; height: 12px; color: var(--green); }
html.js .hero-chip { animation: chipFloat 6s ease-in-out infinite; }
.hero-chip--1 { top: 12%;  left: -34px; }
.hero-chip--2 { top: 44%;  right: -42px; animation-delay: -2s !important; }
.hero-chip--3 { bottom: 14%; left: -22px; animation-delay: -4s !important; }
@keyframes chipFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-7px); }
}
@media (max-width: 600px) { .hero-chip { display: none; } }

/* Chat del hero — gate html.js (condición JJ #3: sin JS, estado final visible) */
.pm-bubble, .pm-match, .pm-audio, .pm-cv { opacity: 1; }
.pm-typing { display: none; }
html.js .pm-typing { display: flex; opacity: 0; }
html.js .pm-bubble, html.js .pm-match, html.js .pm-audio, html.js .pm-cv {
  opacity: 0;
  animation: bubbleIn 280ms var(--ease) forwards;
}
/* Keyframes de la coreografía del chat — viven aquí (no en el inline de la
   landing) porque las reglas html.js .pm-* de arriba los referencian. */
@keyframes bubbleIn { to { opacity: 1; transform: none; } }
@keyframes typingAppear { from { opacity: 0; } to { opacity: 1; } }
@keyframes typingHide { to { opacity: 0; } }

/* Nota de audio (waveform CSS, sin imágenes) */
.pm-audio {
  display: flex;
  align-items: center;
  gap: 8px;
  align-self: flex-end;
  background: var(--violet);
  border-radius: 12px 12px 4px 12px;
  padding: 9px 12px;
  max-width: 78%;
}
.pm-audio-bars { display: flex; align-items: center; gap: 2px; height: 16px; }
.pm-audio-bars i {
  width: 2.5px;
  border-radius: 2px;
  background: rgba(255,255,255,.85);
  height: var(--h, 8px);
}
html.js .pm-audio-bars i { animation: audioBar 1.1s ease-in-out infinite; animation-delay: calc(var(--i) * 90ms); }
@keyframes audioBar { 0%,100% { transform: scaleY(.55); } 50% { transform: scaleY(1); } }
.pm-audio-dur { font-size: .6875rem; color: rgba(255,255,255,.85); font-weight: 600; }

/* Entrega del CV con QR (remate del loop) */
.pm-cv {
  align-self: flex-start;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(46,196,182,.35);
  border-radius: 12px 12px 12px 4px;
  padding: 10px 12px;
  display: flex;
  gap: 10px;
  align-items: center;
  max-width: 88%;
}
.pm-cv-qr {
  width: 44px; height: 44px;
  flex-shrink: 0;
  border-radius: 4px;
  background: #fff;
  padding: 4px;
}
.pm-cv-qr svg { width: 100%; height: 100%; display: block; color: #0F172A; }
.pm-cv-txt { display: flex; flex-direction: column; gap: 2px; }
.pm-cv-title { font-size: .75rem; font-weight: 700; color: var(--t1); }
.pm-cv-url { font-size: .6875rem; color: var(--green); font-weight: 600; }

/* Timing del loop (~14s, CSS only — corre también sin JS… pero sin JS no hay
   estado oculto inicial, así que se ve TODO desde el primer paint) */
html.js .pm-b1  { animation-delay: .6s; }
html.js .pm-b2  { animation: typingAppear 180ms ease .6s both, typingHide 140ms ease 1.6s both; }
html.js .pm-b3  { animation-delay: 1.7s; }
html.js .pm-b4  { animation-delay: 2.6s; }
html.js .pm-b5  { animation: typingAppear 180ms ease 2.6s both, typingHide 140ms ease 3.6s both; }
html.js .pm-b6  { animation-delay: 3.7s; }
html.js .pm-b7  { animation-delay: 4.6s; }
html.js .pm-b8  { animation-delay: 5.6s; }   /* nota de audio */
html.js .pm-b9  { animation: typingAppear 180ms ease 6.6s both, typingHide 140ms ease 7.8s both; }
html.js .pm-b10 { animation-delay: 7.9s; }
html.js .pm-b11 { animation-delay: 8.9s; }   /* match card */
html.js .pm-b12 { animation: typingAppear 180ms ease 9.9s both, typingHide 140ms ease 11s both; }
html.js .pm-b13 { animation-delay: 11.2s; }  /* entrega del CV */

/* Bento del problema (2 grandes + 2 chicas) */
/* Selector simple: el inline conflictivo .pain-grid fue eliminado en FASE D. */
.pain-grid--bento {
  display: grid;
  /* RONDA 2 #2: columnas laterales más anchas — las cards chicas (áreas b y c)
     necesitan ≥28 caracteres por línea, la 1fr/1fr/1fr las dejaba en astillas. */
  grid-template-columns: 1.2fr .8fr 1.2fr;
  grid-template-areas: 'a a b' 'c d d';
  gap: 14px;
}
.pain-grid--bento .pain-card:nth-child(1) { grid-area: a; }
.pain-grid--bento .pain-card:nth-child(2) { grid-area: b; }
.pain-grid--bento .pain-card:nth-child(3) { grid-area: c; }
.pain-grid--bento .pain-card:nth-child(4) { grid-area: d; }
.pain-grid--bento .pain-card { padding: clamp(20px, 2.6vw, 30px); }
.pain-icon--lg {
  width: 52px; height: 52px;
  border-radius: 12px;
  display: grid;
  place-items: center;
}
.pain-icon--violet { background: rgba(139,92,246,.10); color: var(--violet); }
.pain-icon--orange { background: rgba(255,107,53,.10); color: var(--orange); }
.pain-icon--lg svg { width: 26px; height: 26px; }
.pain-num {
  /* Énfasis INLINE dentro de la frase corrida del pain-body: el tamaño va en em
     y cabe dentro del line-box (.9rem × 1.6) — un display-size aquí rompe el párrafo. */
  font-size: 1.35em;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--orange);
}
.pain-num em { font-style: normal; color: var(--orange); }
/* Micrográfico del embudo 80→20→5 (RONDA 2: llena la card grande del empleador).
   Decorativo (aria-hidden): las cifras ya viven en el copy del pain-body. */
.pain-chart { display: flex; flex-direction: column; gap: 10px; margin-top: 18px; }
.pain-chart-row { display: flex; align-items: center; gap: 12px; }
.pain-chart-bar {
  display: block;
  height: 10px;
  border-radius: 5px;
  width: var(--w, 100%);
  transform-origin: left center;
}
.pain-chart-row:nth-child(1) .pain-chart-bar { background: rgba(255,255,255,.22); }
.pain-chart-row:nth-child(2) .pain-chart-bar { background: rgba(255,255,255,.40); }
.pain-chart-row:nth-child(3) .pain-chart-bar { background: var(--orange); }
.pain-chart-num { font-size: .8125rem; font-weight: 800; color: var(--t2); min-width: 7ch; }
.pain-chart-row:nth-child(3) .pain-chart-num { color: var(--orange); }
/* Animación scaleX al reveal de la card (reutiliza el .vis del IO existente) */
html.js [data-reveal] .pain-chart-bar { transform: scaleX(0); transition: transform 700ms var(--ease); }
html.js [data-reveal] .pain-chart-row:nth-child(2) .pain-chart-bar { transition-delay: 120ms; }
html.js [data-reveal] .pain-chart-row:nth-child(3) .pain-chart-bar { transition-delay: 240ms; }
html.js [data-reveal].vis .pain-chart-bar { transform: scaleX(1); }

/* BREAKPOINT INTERMEDIO TABLET (iPad portrait y landscape estrecho):
   Entre 801px y 1000px el bento 3-col 'a a b'/'c d d' queda comprimido
   (las columnas laterales caen a ~200px). Se pasa a 2-col con layout
   'a a'/'b c'/'d d': las dos cards grandes ocupan fila completa y las
   chicas comparten fila, dando ≥280px por card a 800px. */
@media (max-width: 1000px) and (min-width: 801px) {
  .pain-grid--bento {
    grid-template-columns: 1fr 1fr;
    grid-template-areas: 'a a' 'b c' 'd d';
  }
}
@media (max-width: 800px) {
  .pain-grid--bento { grid-template-columns: 1fr; grid-template-areas: 'a' 'b' 'c' 'd'; }
}

/* Pasos: panel compacto, números protagonistas, línea conectora.
   Selector simple: el inline conflictivo .steps fue eliminado en FASE D. */
.steps--panel {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0;
  margin-top: 0;
  padding: clamp(28px, 4vw, 44px);
}
.steps--panel .step {
  padding: 0 clamp(18px, 2.5vw, 32px);
  border-left: 1px solid rgba(255,255,255,.06);
}
.steps--panel .step:first-child { border-left: none; padding-left: 0; }
.step-num--xl {
  font-size: clamp(3.5rem, 6vw, 6rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.03em;
}
.step:nth-child(1) .step-num--xl { color: var(--violet); text-shadow: 0 0 32px rgba(139,92,246,.35); }
.step:nth-child(2) .step-num--xl { color: var(--orange); text-shadow: 0 0 32px rgba(255,107,53,.30); }
.step:nth-child(3) .step-num--xl { color: var(--green);  text-shadow: 0 0 32px rgba(46,196,182,.30); }
.steps-line {
  /* RONDA 2 #5: abarca el ancho del contenido del panel — arranca alineada
     con su borde, nada de 70% centrado que la dejaba descolgada. */
  height: 2px;
  margin: 0 0 clamp(20px, 3vw, 32px);
  background: linear-gradient(90deg, var(--violet), var(--orange), var(--green));
  border-radius: 2px;
  transform-origin: left center;
}
html.js .steps-line { transform: scaleX(0); transition: transform 900ms var(--ease) 150ms; }
html.js .steps-line.vis { transform: scaleX(1); }
@media (max-width: 800px) {
  .steps--panel { grid-template-columns: 1fr; gap: 28px; }
  .steps--panel .step { border-left: none; padding: 0; }
  .steps-line { display: none; }
}

/* Panel-tablero de vacantes + escudo + ghosts */
.panel--vacantes { padding: clamp(22px, 3.5vw, 40px); }
.panel--vacantes .panel-shield {
  position: absolute;
  right: -6%;
  bottom: -18%;
  width: clamp(260px, 30vw, 460px);
  opacity: .04;
  pointer-events: none;
}
.vacantes-live {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: .75rem;
  font-weight: 700;
  color: var(--green);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.vacantes-live i {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--green);
}
html.js .vacantes-live i { animation: livePulse 2.2s ease-in-out infinite; }
@keyframes livePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(46,196,182,.45); }
  50%      { box-shadow: 0 0 0 6px rgba(46,196,182,0); }
}
.jobs-grid--panel { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 960px) { .jobs-grid--panel { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .jobs-grid--panel { grid-template-columns: 1fr; } }

.job-card--ghost {
  border-style: dashed;
  border-color: rgba(255,255,255,.12);
  background: rgba(255,255,255,.02);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.job-card--ghost .ghost-bar {
  height: 10px;
  border-radius: 4px;
  background: linear-gradient(90deg, rgba(255,255,255,.05) 25%, rgba(255,255,255,.10) 50%, rgba(255,255,255,.05) 75%);
  background-size: 200% 100%;
}
html.js .job-card--ghost .ghost-bar { animation: ghostShimmer 2.4s linear infinite; }
@keyframes ghostShimmer { to { background-position: -200% 0; } }
.ghost-city { font-size: .9375rem; font-weight: 700; color: var(--t2); }
.ghost-cta {
  margin-top: auto;
  font-size: .8125rem;
  font-weight: 600;
  color: var(--violet);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.ghost-cta svg { width: 13px; height: 13px; }

/* Anchos de las barras skeleton (antes inline style="width:…").
   Convención: --xl 80%, --lg 70/65%, --md 55/60%, --sm 35/40/45%.
   Se usan en landing.hbs (dark) y vacantes-list.hbs (light). */
.ghost-bar--xl  { width: 80%; }
.ghost-bar--lg  { width: 70%; }
.ghost-bar--lg2 { width: 65%; }
.ghost-bar--md  { width: 60%; }
.ghost-bar--md2 { width: 55%; }
.ghost-bar--sm  { width: 45%; }
.ghost-bar--sm2 { width: 40%; }
.ghost-bar--sm3 { width: 35%; }
.ghost-bar--sm4 { width: 75%; }

/* Precio: banda integrada de ancho completo (RONDA 2: cifra · detalle · CTA) */
.precio-banda {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
  padding: clamp(24px, 3.5vw, 40px);
  margin-top: clamp(32px, 4vw, 48px);
}
.precio-cifra {
  font-size: clamp(3rem, 5.5vw, 5rem);
  font-weight: 900;
  line-height: .95;
  letter-spacing: -0.03em;
  color: var(--t1);
}
.precio-cifra small { font-size: .35em; font-weight: 700; color: var(--t3); display: block; letter-spacing: 0; }
.precio-lineas {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--t1);
  line-height: 1.6;
  margin: 0 0 6px;
}
.precio-nota { font-size: .9375rem; color: var(--t3); line-height: 1.6; margin: 0; }
.precio-banda .btn { white-space: nowrap; }
@media (max-width: 800px) {
  .precio-banda { grid-template-columns: 1fr; gap: 18px; }
  .precio-banda .btn { justify-self: start; }
}

/* CTA glow (Emil: feedback en hover, nunca en táctil) */
@media (hover: hover) and (pointer: fine) {
  .btn-pri:hover, .btn-wa:hover { box-shadow: 0 0 0 1px rgba(255,107,53,.4), 0 8px 32px rgba(255,107,53,.25); }
}

/* Parallax del watermark del footer — solo mejora progresiva */
@supports (animation-timeline: view()) {
  @media (prefers-reduced-motion: no-preference) {
    .footer-watermark {
      animation: shieldDrift linear both;
      animation-timeline: view();
      animation-range: entry 0% cover 100%;
    }
    @keyframes shieldDrift {
      from { transform: translateY(8%); }
      to   { transform: translateY(-6%); }
    }
  }
}

/* Reduced-motion FASE C: estado final, sin loops */
@media (prefers-reduced-motion: reduce) {
  html.js .pm-bubble, html.js .pm-match, html.js .pm-audio, html.js .pm-cv {
    opacity: 1 !important;
    animation: none !important;
  }
  html.js .pm-typing { display: none !important; }
  html.js .hero-chip { animation: none !important; }
  html.js .pm-audio-bars i { animation: none !important; }
  html.js .steps-line { transform: none !important; transition: none; }
  html.js [data-reveal] .pain-chart-bar { transform: none !important; transition: none; }
  html.js .vacantes-live i, html.js .job-card--ghost .ghost-bar { animation: none !important; }
  .footer-watermark { animation: none !important; }
}

/* ══════════ INTERNAS LIGHT (FASE INTERNAS) ══════════ */

/* ── 1. Panel light ─────────────────────────────────
   Token --minga-border no existe en :root aún; se usa
   el valor literal #E2E8F0 hasta que se formalice.
   Radio 12px conforme BRAND (≤12px OK).
   El ::before es un ECO tenue del gradiente (1px al 35%/25%
   de opacidad, decorativo) — no cuenta como el Minga-Energy
   pleno de BRAND (ese sigue limitado a 1 por página).
   ─────────────────────────────────────────────────── */
.panel--light {
  position: relative;
  overflow: hidden;
  background: #fff;
  border: 1px solid #E2E8F0;           /* --minga-border fallback */
  border-radius: 12px;
  padding: clamp(20px, 3vw, 32px);
}
.panel--light::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(139, 92, 246, .35),
    rgba(255, 107, 53, .25),
    transparent
  );
  pointer-events: none;
}

/* ── 2. Aurora light ────────────────────────────────
   Glow posicional decorativo para páginas internas.
   Opacidad .06 (≤ .08 requerido). pointer-events none.
   CONTRATO: requiere ancestro con position:relative +
   overflow:hidden (.panel--light, .nf-panel) — suelto
   se ancla al html y aparece en cualquier parte.
   ─────────────────────────────────────────────────── */
.sec-glow--light-violet {
  position: absolute;
  width: clamp(320px, 55vw, 620px);
  aspect-ratio: 1;
  border-radius: 50%;
  filter: blur(90px);
  opacity: .06;
  pointer-events: none;
  background: radial-gradient(circle, var(--violet), transparent 65%);
}
.sec-glow--light-orange {
  position: absolute;
  width: clamp(320px, 55vw, 620px);
  aspect-ratio: 1;
  border-radius: 50%;
  filter: blur(90px);
  opacity: .06;
  pointer-events: none;
  background: radial-gradient(circle, var(--orange), transparent 65%);
}

/* ── 3. Hero de vacante ─────────────────────────────
   Vive dentro de un .panel--light.
   .vd-salario: chip Match Green — fondo rgba(46,196,182,.10),
   texto --green-ink (AA: 5.0:1 sobre blanco, confirmado).
   .badge-verif: chip neutro con icono Lucide --violet.
   ─────────────────────────────────────────────────── */
.vd-hero {
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 2vw, 18px);
}
.vd-title {
  margin: 0;
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -0.02em;
  text-wrap: balance;
  line-height: 1.15;
}
.vd-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 14px;
  color: #475569;
  font-size: var(--text-sm);
}
.vd-meta svg {
  width: 14px;
  height: 14px;
  stroke-width: 1.5;
  vertical-align: middle;
}
.vd-salario {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(46, 196, 182, .10);
  color: var(--green-ink);          /* #0E7C72 — AA 5.0:1 sobre blanco */
  font-weight: 800;
  font-size: 1.125rem;
  padding: 6px 14px;
  border-radius: 8px;
}
.vd-salario svg { width: 16px; height: 16px; }
.vd-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.badge-verif {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border: 1px solid #E2E8F0;
  background: #F8FAFC;
  color: #334155;                   /* AA 10.1:1 sobre #F8FAFC, confirmado */
  font-size: .8125rem;
  font-weight: 600;
  border-radius: 100px;
}
.badge-verif svg {
  width: 14px;
  height: 14px;
  color: var(--violet);
  flex-shrink: 0;
}

/* ── 4. Sticky CTA móvil ────────────────────────────
   Oculto por defecto (sin JS). El gate html.js + media
   query ≤640px lo activa como mejora progresiva.
   Vd-sticky--off lo oculta cuando el CTA del hero
   está en viewport (IO de 4 líneas en minga.js Task 3).
   El backdrop-filter difumina el contenido que pasa
   por debajo. Se coloca como último hijo del wrapper
   de contenido → sticky en ese límite, nunca tapa footer.
   ─────────────────────────────────────────────────── */
.vd-sticky {
  position: sticky;
  bottom: 0;
  display: none;
  padding: 12px 16px;
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-top: 1px solid #E2E8F0;
  /* Sangra el padding del contenedor REAL de las internas (tailwind px-4 = 1rem
     en móvil) — var(--pad-x) es de la landing y aquí desbordaría en horizontal. */
  margin: 0 -1rem;
}
@media (max-width: 640px) {
  html.js .vd-sticky { display: block; }
  html.js .vd-sticky.vd-sticky--off { display: none; }
}
.vd-sticky .btn-wa { width: 100%; justify-content: center; }

/* ── 5. Tiers de precios ────────────────────────────
   Grid 4 col → 2 col → 1 col.
   Jerarquía de Growth SOLO por elevación + borde naranja.
   Starter (.tier--entrada): borde violeta sutil, MISMO
   peso que los demás (cifras idénticas, sin opacity/gris).
   En móvil tier--destacado pierde translateY (orden natural).
   ─────────────────────────────────────────────────── */
.tiers-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  align-items: start;
}
@media (max-width: 1024px) { .tiers-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .tiers-grid { grid-template-columns: 1fr; } }

.tier {
  position: relative;
  background: #fff;
  border: 1px solid #E2E8F0;
  border-radius: 12px;
  padding: clamp(20px, 2.5vw, 28px);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.tier--entrada {
  border: 1px solid rgba(139, 92, 246, .35);   /* Starter: violeta sutil */
}
.tier--destacado {
  border: 2px solid var(--orange);
  transform: translateY(-8px);
  box-shadow: 0 12px 32px rgba(255, 107, 53, .12);
}
@media (max-width: 640px) {
  .tier--destacado { transform: none; }
}

.tier-badge {
  display: inline-flex;
  align-self: flex-start;
  align-items: center;
  padding: 4px 10px;
  background: var(--orange);
  color: #fff;
  font-size: .75rem;
  font-weight: 700;
  border-radius: 100px;
}
.tier-nombre {
  font-size: 1rem;
  font-weight: 700;
  color: var(--navy);
}
.tier-precio {
  font-size: clamp(2.5rem, 3.5vw, 3.5rem);
  font-weight: 900;
  color: var(--navy);
  line-height: 1;
  letter-spacing: -0.03em;
}
.tier-unidad {
  font-size: .875rem;
  color: var(--ink-2);
}
.tier-features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: .9375rem;
  color: var(--ink);
}
.tier-features li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.tier-features li svg {
  width: 16px;
  height: 16px;
  color: var(--green-ink);      /* AA sobre blanco */
  flex-shrink: 0;
  margin-top: 2px;
}
.tier-cta {
  margin-top: auto;
}
@media (hover: hover) and (pointer: fine) {
  .tier:hover {
    box-shadow: 0 8px 24px rgba(15, 23, 42, .08), 0 0 0 1px rgba(139, 92, 246, .12);
  }
}

/* ── 6. Estados vacíos light ────────────────────────
   .empty-city: panel light centrado con padding generoso.
   .job-card--ghost-light: variante light del ghost existente.
   El shimmer reutiliza @keyframes ghostShimmer (ya definido).
   .ghost-cta dentro del ghost-light usa --violet-ink (el
   --violet puro no alcanza AA sobre blanco).
   ─────────────────────────────────────────────────── */
.empty-city {
  background: #fff;
  border: 1px solid #E2E8F0;
  border-radius: 12px;
  padding: clamp(40px, 6vw, 64px) clamp(24px, 4vw, 48px);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 16px;
}

.job-card--ghost-light {
  background: #fff;
  border-style: dashed;
  border-color: #CBD5E1;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.job-card--ghost-light .ghost-bar {
  background: #E2E8F0;             /* override del gradiente navy */
}
html.js .job-card--ghost-light .ghost-bar {
  background-size: 200% 100%;
  background-image: linear-gradient(
    90deg,
    #E2E8F0 25%,
    #EEF2F7 50%,
    #E2E8F0 75%
  );
  animation: ghostShimmer 2.4s linear infinite;
}
/* Sobre blanco, --violet puro da 4.23:1 (<AA): se usa la variante ink. */
.job-card--ghost-light .ghost-cta { color: var(--violet-ink); }

/* ── 7. 404 ─────────────────────────────────────────
   .nf-shield: escudo navy como fondo decorativo (~8%).
   .nf-panel: panel light centrado para el contenido 404.
   ─────────────────────────────────────────────────── */
.nf-shield {
  position: absolute;
  pointer-events: none;
  opacity: .08;
  user-select: none;
}
.nf-panel {
  position: relative;
  background: #fff;
  border: 1px solid #E2E8F0;
  border-radius: 12px;
  padding: clamp(32px, 5vw, 56px);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 16px;
  overflow: hidden;
}

/* ── 8. Reduced-motion FASE INTERNAS ────────────────
   .tier--destacado: la elevación es decorativa → none.
   .vd-sticky: sin transición de entrada.
   Ghost-light: shimmer desactivado (ya gated por html.js).
   ─────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .tier--destacado { transform: none; }
  .vd-sticky { transition: none; }
  html.js .job-card--ghost-light .ghost-bar { animation: none !important; }
}

/* ===== LANDING (migrado desde inline, FASE D) =====
   Componentes below-the-fold y wrappers de sección.
   El CSS above-the-fold (hero, phone-mockup, botones) sigue
   en el <style> inline de landing.hbs para evitar FOUC en
   Android lento antes del primer paint de minga.css.
   ===================================================== */

/* ── Wrappers de sección ─────────────────────────── */
.sec { padding: var(--sec-py) var(--pad-x); position: relative; overflow: hidden; }
.sec-alt { background: var(--navy-d); }
.inner { max-width: var(--max-w); margin: 0 auto; }
.sec-h {
  font-size: var(--text-h2);
  font-weight: 800;
  letter-spacing: -.032em;
  line-height: 1.02;
  color: var(--t1);
  text-wrap: balance;
}

/* ── S-Problema: pain-grid base (layout genérico) ── */
.pain-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: clamp(40px, 5vw, 64px);
}
.pain-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 10px;
  padding: clamp(20px, 3vw, 28px);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition:
    border-color var(--dur) var(--ease),
    box-shadow   var(--dur) var(--ease),
    background   var(--dur) var(--ease);
}
.pain-card:nth-child(1) { border-color: rgba(255,107,53,.14); }
.pain-card:nth-child(3) { border-color: rgba(139,92,246,.14); }
.pain-card:nth-child(4) { border-color: rgba(255,107,53,.14); }
@media (hover: hover) and (pointer: fine) {
  .pain-card:hover {
    background: rgba(255,255,255,.065);
    box-shadow: 0 8px 32px rgba(0,0,0,.28);
  }
  .pain-card:nth-child(1):hover,
  .pain-card:nth-child(4):hover { border-color: rgba(255,107,53,.32); }
  .pain-card:nth-child(2):hover,
  .pain-card:nth-child(3):hover { border-color: rgba(139,92,246,.32); }
}
.pain-icon {
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 8px;
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  color: var(--t3);
}
.pain-icon svg { width: 18px; height: 18px; stroke-width: 1.5; }
.pain-card:nth-child(1) .pain-icon { color: var(--orange); border-color: rgba(255,107,53,.2); }
.pain-card:nth-child(2) .pain-icon { color: var(--violet); border-color: rgba(139,92,246,.2); }
.pain-card:nth-child(3) .pain-icon { color: var(--violet); border-color: rgba(139,92,246,.2); }
.pain-card:nth-child(4) .pain-icon { color: var(--orange); border-color: rgba(255,107,53,.2); }
.pain-title {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--t1);
  letter-spacing: -.018em;
  line-height: 1.3;
}
.pain-body {
  font-size: .9rem;
  line-height: 1.6;
  color: var(--t2);
}
.pain-tag {
  font-size: .6875rem;
  font-weight: 700;
  color: var(--t4);
  letter-spacing: .06em;
  text-transform: uppercase;
  align-self: flex-start;
}
.pain-card:nth-child(1) .pain-tag,
.pain-card:nth-child(2) .pain-tag,
.pain-card:nth-child(3) .pain-tag { color: rgba(139,92,246,.5); }
.pain-card:nth-child(4) .pain-tag { color: rgba(255,107,53,.5); }

/* ── S-Cómo funciona: steps base ────────────────── */
.steps {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: clamp(32px, 5vw, 56px);
  margin-top: clamp(48px, 6vw, 72px);
}
.step { display: flex; flex-direction: column; gap: 16px; }
.step-num {
  font-size: clamp(3rem, 5vw, 4.5rem);
  font-weight: 900;
  letter-spacing: -.04em;
  line-height: 1;
}
.step-num-v { color: var(--violet); }
.step-num-o { color: var(--orange); }
.step-num-g { color: var(--green); }
.step-icon {
  width: 44px; height: 44px;
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
}
.step-icon svg { width: 20px; height: 20px; stroke-width: 1.5; }
.step:nth-child(1) .step-icon { color: var(--violet); border-color: rgba(139,92,246,.2); }
.step:nth-child(2) .step-icon { color: var(--orange); border-color: rgba(255,107,53,.2); }
.step:nth-child(3) .step-icon { color: var(--green);  border-color: rgba(46,196,182,.2); }
.step-title {
  font-size: clamp(1.0625rem, 1.8vw, 1.25rem);
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--t1);
  line-height: 1.25;
}
.step-body {
  font-size: .9375rem;
  line-height: 1.65;
  color: var(--t2);
  max-width: 50ch;
  text-wrap: pretty;
}

/* ── S-Candidato (producto: CV) ─────────────────── */
.s-candidato-inner {
  display: grid;
  grid-template-columns: 55fr 45fr;
  align-items: center;
  gap: clamp(28px, 4vw, 56px);
}
.product-img {
  position: relative;
  margin-left: clamp(-48px, -4vw, -20px);
}
.product-img picture,
.product-img img {
  width: 100%;
  max-width: none;
  border-radius: 12px;
  filter:
    drop-shadow(0 36px 90px rgba(0,0,0,.58))
    drop-shadow(0 0 56px rgba(139,92,246,.14));
  transition:
    transform var(--dur) var(--ease),
    filter    var(--dur) var(--ease);
}
@media (hover: hover) and (pointer: fine) {
  .product-img img:hover {
    transform: scale(1.012);
    filter:
      drop-shadow(0 44px 110px rgba(0,0,0,.65))
      drop-shadow(0 0 64px rgba(139,92,246,.20));
  }
}
.product-img::before {
  content: '';
  position: absolute;
  inset: -48px;
  background: radial-gradient(ellipse at 50% 50%, rgba(139,92,246,.12) 0%, transparent 65%);
  z-index: -1;
  pointer-events: none;
}
.product-text { max-width: 480px; }
.product-h {
  font-size: var(--text-h2);
  font-weight: 800;
  letter-spacing: -.032em;
  line-height: 1.02;
  color: var(--t1);
  margin-bottom: clamp(12px, 2vw, 18px);
  text-wrap: balance;
}
.product-sub {
  font-size: var(--text-body);
  line-height: 1.65;
  color: var(--t2);
  max-width: 44ch;
  margin-bottom: clamp(20px, 3vw, 32px);
  text-wrap: pretty;
}
.feature-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: clamp(24px, 3vw, 36px);
}
.feature-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: .9375rem;
  color: var(--t2);
  line-height: 1.5;
}
.feature-item svg {
  width: 16px; height: 16px;
  flex-shrink: 0;
  margin-top: 3px;
  color: var(--green);
  stroke-width: 2;
}

/* ── S-Trust ─────────────────────────────────────── */
.trust-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: clamp(24px, 4vw, 40px);
  margin-top: 0;
}
.trust-item { display: flex; flex-direction: column; gap: 10px; }
.trust-icon { color: var(--green); }
.trust-icon svg { width: 22px; height: 22px; stroke-width: 1.5; }
.trust-label {
  font-size: 1rem;
  font-weight: 700;
  color: var(--t1);
  letter-spacing: -.015em;
  line-height: 1.3;
}
.trust-desc {
  font-size: .875rem;
  line-height: 1.55;
  color: var(--t2);
  text-wrap: pretty;
}

/* ── S-Vacantes: header + see-all ───────────────── */
.jobs-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: clamp(32px, 4vw, 48px);
}
.see-all {
  font-size: .875rem;
  font-weight: 600;
  color: var(--violet);
  display: flex;
  align-items: center;
  gap: 4px;
  transition: gap var(--dur-fast) var(--ease-btn);
}
@media (hover: hover) and (pointer: fine) {
  .see-all:hover { gap: 8px; }
}
.see-all svg { width: 14px; height: 14px; }

/* ── S-Empleadores ───────────────────────────────── */
.s-emp-inner {
  display: grid;
  grid-template-columns: 45fr 55fr;
  align-items: center;
  gap: clamp(28px, 4vw, 56px);
}
.emp-img {
  position: relative;
  order: 2;
  margin-right: clamp(-48px, -4vw, -20px);
}
.emp-img picture,
.emp-img img {
  width: 100%;
  max-width: none;
  border-radius: 12px;
  filter:
    drop-shadow(0 36px 90px rgba(0,0,0,.62))
    drop-shadow(0 0 56px rgba(255,107,53,.12));
  transition: transform var(--dur) var(--ease), filter var(--dur) var(--ease);
}
@media (hover: hover) and (pointer: fine) {
  .emp-img img:hover {
    transform: scale(1.012);
    filter:
      drop-shadow(0 44px 110px rgba(0,0,0,.68))
      drop-shadow(0 0 64px rgba(255,107,53,.18));
  }
}
.emp-img::before {
  content: '';
  position: absolute;
  inset: -48px;
  background: radial-gradient(ellipse at 50% 50%, rgba(255,107,53,.11) 0%, transparent 65%);
  z-index: -1;
  pointer-events: none;
}
.emp-text { order: 1; max-width: 480px; }
.emp-flow {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin: clamp(24px, 3vw, 32px) 0;
}
.emp-step {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.emp-step-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--violet);
  flex-shrink: 0;
  margin-top: 6px;
}
.emp-step:nth-child(2) .emp-step-dot { background: var(--orange); }
.emp-step:nth-child(3) .emp-step-dot { background: var(--green); }
.emp-step:nth-child(4) .emp-step-dot { background: var(--t4); }
.emp-step-body {}
.emp-step-title {
  font-size: .9375rem;
  font-weight: 700;
  color: var(--t1);
  line-height: 1.3;
  margin-bottom: 2px;
}
.emp-step-desc {
  font-size: .875rem;
  line-height: 1.55;
  color: var(--t2);
}
.emp-diff-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: clamp(20px, 2.5vw, 28px) 0;
}
.emp-diff-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 8px;
  padding: 14px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition:
    border-color var(--dur) var(--ease),
    background   var(--dur) var(--ease);
}
@media (hover: hover) and (pointer: fine) {
  .emp-diff-card:hover {
    background: rgba(255,255,255,.065);
    border-color: rgba(139,92,246,.28);
  }
}
.emp-diff-icon { color: var(--violet); }
.emp-diff-icon svg { width: 15px; height: 15px; stroke-width: 1.5; }
.emp-diff-card:nth-child(2) .emp-diff-icon { color: var(--green); }
.emp-diff-card:nth-child(3) .emp-diff-icon { color: var(--orange); }
.emp-diff-card:nth-child(4) .emp-diff-icon { color: var(--t3); }
.emp-diff-title {
  font-size: .8125rem;
  font-weight: 700;
  color: var(--t1);
  line-height: 1.25;
}
.emp-diff-desc {
  font-size: .75rem;
  color: var(--t2);
  line-height: 1.5;
}

/* ── S-Cobertura ─────────────────────────────────── */
.cob-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 1px;
  background: var(--card-border);
  border: 1px solid var(--card-border);
  border-radius: 12px;
  overflow: hidden;
  margin-top: clamp(40px, 5vw, 60px);
}
.cob-item {
  background: var(--navy);
  padding: clamp(24px, 3vw, 36px) clamp(20px, 2.5vw, 28px);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: background var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.sec-alt .cob-item { background: var(--navy-d); }
@media (hover: hover) and (pointer: fine) {
  .cob-item:hover { background: var(--card-bg); }
}
.cob-item--soon { opacity: 0.5; }
@media (hover: hover) and (pointer: fine) {
  .cob-item--soon:hover { opacity: 0.72; }
}
.cob-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 9px;
  border-radius: 100px;
  font-size: .6875rem;
  font-weight: 700;
  letter-spacing: .02em;
  align-self: flex-start;
}
.cob-badge-active {
  background: rgba(46,196,182,.15);
  color: var(--green);
  border: 1px solid rgba(46,196,182,.22);
}
.cob-badge-soon {
  background: rgba(255,255,255,.06);
  color: var(--t4);
  border: 1px solid rgba(255,255,255,.1);
}
.cob-city {
  font-size: clamp(1.125rem, 2vw, 1.375rem);
  font-weight: 800;
  letter-spacing: -.025em;
  color: var(--t1);
}
.cob-role {
  font-size: .875rem;
  font-weight: 600;
  color: var(--violet);
}
.cob-desc {
  font-size: .8125rem;
  line-height: 1.55;
  color: var(--t3);
}

/* ── S-FAQ ───────────────────────────────────────── */
.faq-list {
  margin-top: clamp(40px, 5vw, 60px);
  display: flex;
  flex-direction: column;
  border: 1px solid var(--card-border);
  border-radius: 12px;
  overflow: hidden;
}
details.faq-item {
  border-bottom: 1px solid var(--card-border);
  display: grid;
  grid-template-rows: auto 0fr;
  transition: grid-template-rows var(--dur) var(--ease);
}
details.faq-item:last-child { border-bottom: none; }
details.faq-item[open] { grid-template-rows: auto 1fr; }
summary.faq-q {
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 20px 24px;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 600;
  color: var(--t1);
  background: var(--card-bg);
  transition:
    background var(--dur-fast) var(--ease-btn),
    color     var(--dur-fast) var(--ease-btn);
  user-select: none;
}
summary.faq-q::-webkit-details-marker { display: none; }
@media (hover: hover) and (pointer: fine) {
  summary.faq-q:hover { background: var(--card-hover); }
}
summary.faq-q:focus-visible { outline: 2px solid var(--violet); outline-offset: -2px; }
.faq-arrow {
  width: 20px; height: 20px;
  flex-shrink: 0;
  border-right: 2px solid var(--t3);
  border-bottom: 2px solid var(--t3);
  transform: rotate(45deg) translateY(-3px);
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
  margin-top: 0;
}
details.faq-item[open] .faq-arrow {
  transform: rotate(-135deg) translateY(-3px);
  border-color: var(--t1);
}
.faq-body {
  overflow: hidden;
  background: var(--card-bg);
}
.faq-body-inner {
  padding: 0 24px 20px;
  font-size: .9375rem;
  line-height: 1.7;
  color: var(--t2);
  max-width: 68ch;
  text-wrap: pretty;
}
.faq-body-inner p + p { margin-top: 10px; }

/* ── S-CTA final ─────────────────────────────────── */
.s-cta {
  position: relative;
  overflow: hidden;
  padding: var(--sec-py) var(--pad-x);
  text-align: center;
}
.cta-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.cta-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: .18;
}
.cta-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(139,92,246,.35) 0%, rgba(255,107,53,.25) 100%);
}
.cta-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom, var(--navy-d) 0%, transparent 30%),
    linear-gradient(to top, var(--navy) 0%, transparent 30%);
  z-index: 1;
}
.cta-inner {
  position: relative;
  z-index: var(--z-above);
  max-width: 640px;
  margin: 0 auto;
}
.cta-h {
  font-size: clamp(2rem, 4.5vw, 3.5rem);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.08;
  color: var(--t1);
  margin-bottom: clamp(12px, 2vw, 18px);
  text-wrap: balance;
}
.cta-sub {
  font-size: clamp(.9375rem, 1.6vw, 1.0625rem);
  line-height: 1.65;
  color: var(--t2);
  max-width: 44ch;
  margin: 0 auto clamp(28px, 4vw, 40px);
  text-wrap: pretty;
}
.cta-btns { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }

/* ── Parallax (solo mejora progresiva desktop) ──── */
.parallax-img { will-change: transform; }

/* ── Responsive FASE D ───────────────────────────── */
@media (max-width: 960px) {
  .s-candidato-inner { grid-template-columns: 1fr; }
  .product-img { order: -1; margin-left: 0; }
  .product-img picture, .product-img img { max-width: min(500px, 94vw); margin: 0 auto; }

  .s-emp-inner { grid-template-columns: 1fr; }
  .emp-img { order: -1; margin-right: 0; }
  .emp-img picture, .emp-img img { max-width: 94vw; }

  .trust-grid { grid-template-columns: 1fr 1fr; }
  .steps { grid-template-columns: 1fr; gap: 36px; }
  .cob-grid { grid-template-columns: repeat(3,1fr); }
}

@media (max-width: 600px) {
  .pain-grid { grid-template-columns: 1fr; }
  .trust-grid { grid-template-columns: 1fr; }
  .cob-grid { grid-template-columns: 1fr; }
  .cta-btns { flex-direction: column; align-items: stretch; }
  .cta-btns .btn { justify-content: center; }
  summary.faq-q { font-size: .9375rem; padding: 16px 18px; }
  .faq-body-inner { padding: 0 18px 16px; }
}

/* ── Reduced-motion FASE D ───────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .btn-pri:hover, .btn-ghost:hover { transform: none !important; }
  .product-img img:hover, .emp-img img:hover { transform: none !important; }
  details.faq-item { transition: none; }
  .faq-arrow { transition: none; }
}
