/* ============================================================================
   VITALIZA REBUILD 2026 — Capa de extensión faithful a la referencia "Agencia"
   ----------------------------------------------------------------------------
   Se carga DESPUÉS de vitalibot-design-system.css. NO redefine nada existente:
   solo añade variantes nuevas (clases con modificador) para no romper páginas
   aún no migradas. Reutiliza los tokens del design system (--color-*, --radius-*).
   Doctrina: cero métricas inventadas. La prueba es la demo, no un número falso.
   ============================================================================ */

/* ---------------------------------------------------------------------------
   1. HERO CLARO PARTIDO  (fiel al hero blanco de la referencia)
   Uso:  <section class="hero hero--light"> ... <div class="hero-grid"> ...
--------------------------------------------------------------------------- */
.hero--light{
  background:#fff;
  color:var(--color-text);
  padding:clamp(56px,7vw,92px) var(--container-pad) clamp(36px,4.5vw,56px);
}
.hero--light::before{
  background:radial-gradient(circle,rgba(24,115,98,.08) 0%,transparent 70%);
}
.hero--light::after{
  content:'';position:absolute;bottom:-120px;left:-100px;width:420px;height:420px;
  background:radial-gradient(circle,rgba(212,175,55,.10) 0%,transparent 70%);
  pointer-events:none;
}
.hero--light .hero-badge{
  background:rgba(24,115,98,.08);border-color:rgba(24,115,98,.28);color:var(--color-primary);
}
.hero--light h1{color:var(--color-secondary)}
.hero--light h1 span{color:var(--color-primary)}
.hero--light .hero-sub{color:var(--color-text-light)}
.hero--light .hero-trust{color:var(--color-text-muted)}
.hero--light .hero-trust i{color:var(--color-primary)}
/* Variantes de subtítulo de hero usadas en páginas vs/alternativas/about */
.hero--light .hero-intro,
.hero--light .hero-seed{color:var(--color-text-light)}
.hero--light .hero-intro strong,
.hero--light .hero-seed strong{color:var(--color-secondary)}
.hero--light .hero-tagline{color:var(--color-text)}

/* Hero centrado (hubs + contacto): hero-inner es grid 2-col; aquí lo hacemos
   una sola columna centrada para páginas sin visual a la derecha. */
.hero--center .hero-inner{display:block;max-width:780px;text-align:center}
.hero--center .hero-ctas,
.hero--center .hero-trust{justify-content:center}
.hero--center .hero-intro{margin-left:auto;margin-right:auto;max-width:720px}
/* La tarjeta visual de la derecha, sobre fondo claro */
.hero--light .hero-visual{
  background:#fff;border:1px solid var(--color-border);
  box-shadow:var(--shadow-lg);backdrop-filter:none;
}

/* ---------------------------------------------------------------------------
   2. FILA DE PILLS DE CAPACIDAD bajo el hero
   (fiel a la fila de categorías de la referencia; agent-readable: enlaces reales)
--------------------------------------------------------------------------- */
.hero-pills{
  max-width:var(--max-width);margin:34px auto 0;
  display:flex;flex-wrap:wrap;gap:10px;justify-content:center;
}
.hero-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--color-bg-light);border:1px solid var(--color-border);
  color:var(--color-secondary);font-family:var(--font-display);font-weight:600;
  font-size:.82rem;padding:9px 16px;border-radius:100px;text-decoration:none;
  transition:var(--transition);
}
.hero-pill i{color:var(--color-primary)}
.hero-pill:hover{border-color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow-card)}

/* ---------------------------------------------------------------------------
   3. BANDA DE CONFIANZA REAL  (sustituye al "+200 empresas" inventado)
   Solo señales verificables: tecnología propia, datos UE, modelos, hecho en España.
--------------------------------------------------------------------------- */
.trust-band{
  background:var(--color-bg-light);
  border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);
  padding:20px var(--container-pad);
}
.trust-band-inner{
  max-width:var(--max-width);margin:0 auto;
  display:flex;flex-wrap:wrap;gap:14px 40px;align-items:center;justify-content:center;
}
.trust-item{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--color-secondary);
}
.trust-item i{color:var(--color-primary);font-size:1.05rem}

/* ---------------------------------------------------------------------------
   4. SECCIÓN CASI-NEGRA  (banda oscura de la referencia; reutilizable)
--------------------------------------------------------------------------- */
.section--ink{background:#0c1714;color:#fff}
.section--ink .section-header h2{color:#fff}
.section--ink .section-header p{color:rgba(255,255,255,.72)}
.section--ink .feature-card,
.section--ink .tech-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10)}
.section--ink .feature-card h3,
.section--ink .tech-card h3{color:#fff}
.section--ink .feature-card p,
.section--ink .tech-card p{color:rgba(255,255,255,.74)}

/* ---------------------------------------------------------------------------
   5. BANDA DEMO  — la prueba es la demo, no un testimonio inventado
--------------------------------------------------------------------------- */
.demo-band-wrap{padding:var(--section-pad-y) var(--container-pad)}
.demo-band{
  max-width:var(--max-width);margin:0 auto;
  background:linear-gradient(135deg,var(--color-secondary) 0%,var(--color-primary) 100%);
  color:#fff;border-radius:var(--radius-card);
  padding:clamp(32px,5vw,56px);text-align:center;position:relative;overflow:hidden;
}
.demo-band::before{
  content:'';position:absolute;top:-80px;right:-60px;width:360px;height:360px;
  background:radial-gradient(circle,rgba(212,175,55,.18) 0%,transparent 70%);pointer-events:none;
}
.demo-band .label{justify-content:center;margin-bottom:16px}
.demo-band h2{color:#fff;margin-bottom:14px}
.demo-band p{color:rgba(255,255,255,.9);max-width:580px;margin:0 auto 28px;font-size:1.05rem;position:relative}

/* ---------------------------------------------------------------------------
   6. MATRIZ AEO  — bloques de atributo extractables (attribute-rich, GEO/AEO)
   Cada tarjeta = un par claim+atributo citable por motores de respuesta/LLMs.
--------------------------------------------------------------------------- */
.aeo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:20px;margin-top:8px}
.aeo-card{
  background:#fff;border:1px solid var(--color-border);border-left:3px solid var(--color-primary);
  border-radius:var(--radius-sm);padding:22px;
}
.aeo-card .aeo-tag{
  font-family:var(--font-display);font-size:.7rem;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--color-primary);margin-bottom:8px;display:block;
}
.aeo-card h3{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--color-secondary);margin-bottom:8px}
.aeo-card p{font-size:.9rem;color:var(--color-text-light);line-height:1.7}

/* ---------------------------------------------------------------------------
   7. NUEVO / PRÓXIMAMENTE — etiqueta sobria para funciones que llegan
   (el usuario pide presentarlas como disponibles; etiqueta neutra y discreta)
--------------------------------------------------------------------------- */
.soon-tag{
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(212,175,55,.16);color:#8a6d10;border:1px solid rgba(212,175,55,.4);
  font-family:var(--font-display);font-weight:700;font-size:.62rem;letter-spacing:.04em;
  text-transform:uppercase;padding:2px 8px;border-radius:100px;margin-left:8px;vertical-align:middle;
}

/* ---------------------------------------------------------------------------
   8. Pequeños helpers de altura / lectura
--------------------------------------------------------------------------- */
.section-header--left{text-align:left;margin-left:0;margin-right:0;max-width:760px}
.eyebrow-center{justify-content:center}
@media (max-width:720px){
  .trust-band-inner{gap:12px 22px}
  .trust-item{font-size:.82rem}
}

/* ---------------------------------------------------------------------------
   9. BLOQUES SUB-VERTICAL ANCLADOS (pillar pages de sector)
   Cada sub-vertical = sección autosuficiente, anclada (id) y citable por IA:
   H3 con keyword exacta + párrafos específicos + lista de atributos.
--------------------------------------------------------------------------- */
.verticals{display:flex;flex-direction:column;gap:20px;max-width:920px;margin:0 auto}
.vertical-block{
  background:#fff;border:1px solid var(--color-border);border-left:4px solid var(--color-primary);
  border-radius:var(--radius-card);padding:28px clamp(20px,3vw,32px);scroll-margin-top:90px;
}
.section--light .vertical-block{background:#fff}
.vertical-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.vertical-ic{
  width:46px;height:46px;flex-shrink:0;border-radius:12px;
  background:linear-gradient(135deg,#EBF7F5,#C8EDE7);color:var(--color-primary);
  display:flex;align-items:center;justify-content:center;font-size:1.15rem;
}
.vertical-head h3{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--color-secondary);margin:0}
.vertical-block > p{font-size:.95rem;color:var(--color-text-light);line-height:1.75;margin-bottom:14px}
.vertical-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px 24px;margin:0}
.vertical-list li{position:relative;padding-left:24px;font-size:.9rem;color:var(--color-text);line-height:1.55}
.vertical-list li::before{
  content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;
  position:absolute;left:0;top:1px;color:var(--color-primary);font-size:.8rem;
}

/* ---------------------------------------------------------------------------
   10. HUB DE SECTORES — tarjetas con sub-enlaces ancla
   Internal linking descriptivo a cada sub-vertical (#abogados, #dentales…):
   fuerte para SEO y para que un agente IA navegue a la sección exacta.
--------------------------------------------------------------------------- */
.sector-hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(258px,1fr));gap:20px}
.sector-hub-card{
  background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-card);
  padding:26px;transition:var(--transition);display:flex;flex-direction:column;
}
.sector-hub-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}
.sector-hub-main{text-decoration:none;display:block}
.sector-hub-card .sector-icon{
  width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#EBF7F5,#C8EDE7);
  color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:16px;
}
.sector-hub-card h3{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:var(--color-secondary);margin-bottom:8px}
.sector-hub-card p{font-size:.9rem;color:var(--color-text-light);line-height:1.65;margin-bottom:16px}
.sector-sublinks{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto}
.sector-sublinks a{
  font-family:var(--font-display);font-size:.78rem;font-weight:600;color:var(--color-primary);
  background:var(--color-bg-light);border:1px solid var(--color-border);padding:5px 12px;border-radius:100px;
  text-decoration:none;transition:var(--transition);
}
.sector-sublinks a:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}

/* ---------------------------------------------------------------------------
   11. HARDENING MÓVIL ANTI-OVERFLOW (auditoría 2026)
   Varios grids del home tenían columnas fijas sin colapso en móvil
   (hero-grid 1fr 1fr, bots-grid, tech-grid, pricing-grid) → scroll horizontal.
   Se colapsan a 1 columna en móvil y se blinda el eje X con `clip` (no `hidden`,
   para no convertir el body en scroll-container y no romper el header sticky).
--------------------------------------------------------------------------- */
html, body { overflow-x: clip; }
.vb-public-shell main img,
.vb-public-shell main svg,
.vb-public-shell main video { max-width: 100%; height: auto; }

/* El hero partido (texto + mockup) apila en tablet/móvil */
@media (max-width: 768px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero--light .hero-visual { margin-left: auto; margin-right: auto; max-width: 460px; width: 100%; }
  .chat-mockup { margin-left: auto; margin-right: auto; }
}

/* Grids de tarjetas del home → una sola columna en móvil */
@media (max-width: 600px) {
  .bots-grid,
  .tech-grid,
  .pricing-grid,
  .sectors-grid,
  .aeo-grid { grid-template-columns: 1fr; }
}