/* Valoris — sistema visual de landings públicas 2026 (estética A · Vibrante, paleta oficial).
   Scope: todo bajo .vh para no chocar con base_public.html / landing-system.css. */
:root{
  --vh-bg:#fff; --vh-ink:#0f172a; --vh-muted:#64748b; --vh-soft:#f8fafc;
  --vh-g1:#2563eb; --vh-g2:#6366f1; --vh-g3:#60a5fa;
  --vh-accent:#3b82f6; --vh-accent2:#6366f1; --vh-success:#10b981;
  --vh-line:#e2e8f0; --vh-radius:22px;
  --vh-font:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
}
.vh{font-family:var(--vh-font);color:var(--vh-ink);background:var(--vh-bg);line-height:1.6;-webkit-font-smoothing:antialiased}
.vh *{box-sizing:border-box}
.vh-wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.vh a{text-decoration:none;color:inherit}

/* Buttons */
.vh .vh-btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;border-radius:999px;padding:14px 28px;font-size:16px;cursor:pointer;border:none;transition:transform .2s,box-shadow .2s,background .2s;font-family:var(--vh-font)}
.vh .vh-btn--primary{background:linear-gradient(135deg,var(--vh-g1),var(--vh-g2));color:#fff;box-shadow:0 10px 30px rgba(37,99,235,.35)}
.vh .vh-btn--primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(37,99,235,.45);color:#fff}
.vh .vh-btn--ghost{background:#fff;color:var(--vh-ink);border:1.5px solid var(--vh-line)}
.vh .vh-btn--ghost:hover{border-color:var(--vh-accent);color:var(--vh-accent)}
.vh .vh-btn--light{background:#fff;color:var(--vh-g1)}
.vh .vh-btn--light:hover{transform:translateY(-2px);color:var(--vh-g1)}
.vh .vh-btn--ghost-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.6)}
.vh .vh-btn--ghost-light:hover{background:rgba(255,255,255,.14);color:#fff;border-color:#fff}

/* HERO */
.vh-hero{position:relative;overflow:hidden;padding:84px 0 64px;text-align:center}
.vh-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.45;z-index:0}
.vh-blob--1{width:520px;height:520px;background:#bfdbfe;top:-180px;left:-120px}
.vh-blob--2{width:480px;height:480px;background:#c7d2fe;top:-90px;right:-140px}
.vh-hero .vh-wrap{position:relative;z-index:1}
.vh-pill{display:inline-flex;align-items:center;gap:8px;background:#eff6ff;color:var(--vh-accent);font-weight:700;font-size:13px;padding:8px 16px;border-radius:999px;margin-bottom:24px}
.vh-dot{width:8px;height:8px;border-radius:50%;background:var(--vh-accent2);box-shadow:0 0 0 4px rgba(99,102,241,.18)}
.vh-h1{font-size:clamp(36px,6vw,60px);line-height:1.06;font-weight:700;letter-spacing:-1.5px;margin:0 0 22px}
.vh-grad{background:linear-gradient(120deg,var(--vh-g1),var(--vh-g2) 60%,var(--vh-g3));-webkit-background-clip:text;background-clip:text;color:transparent}
.vh-sub{font-size:clamp(17px,2vw,21px);color:var(--vh-muted);max-width:720px;margin:0 auto 36px}
.vh-cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.vh-trust{margin-top:20px;color:var(--vh-muted);font-size:14px;font-weight:600}

/* Phone mock */
.vh-stage{margin-top:56px;display:flex;justify-content:center}
.vh-phone{width:300px;background:#0f172a;border-radius:42px;padding:12px;box-shadow:0 40px 80px rgba(15,23,42,.35)}
.vh-screen{background:#f8fafc;border-radius:32px;overflow:hidden;height:520px;position:relative}
.vh-scrtop{background:linear-gradient(135deg,var(--vh-g1),var(--vh-g2));padding:22px 18px;color:#fff;text-align:left}
.vh-scrtop small{opacity:.85;font-weight:600;font-size:12px}
.vh-scrtop h3{font-size:18px;font-weight:700;margin:2px 0 0}
.vh-chat{padding:16px;display:flex;flex-direction:column;gap:12px}
.vh-bub{padding:12px 14px;border-radius:16px;font-size:13.5px;max-width:86%;line-height:1.5}
.vh-bub--me{align-self:flex-end;background:linear-gradient(135deg,var(--vh-g3),var(--vh-g1));color:#fff;border-bottom-right-radius:5px}
.vh-bub--ai{align-self:flex-start;background:#fff;border:1px solid var(--vh-line);border-bottom-left-radius:5px}
.vh-bub--ai b{color:var(--vh-accent)}
.vh-mtag{display:inline-block;font-size:11px;font-weight:700;color:var(--vh-accent);background:#eff6ff;padding:4px 9px;border-radius:7px;margin-top:6px}

/* Metrics */
.vh-metrics{display:flex;gap:48px;justify-content:center;flex-wrap:wrap;margin-top:60px}
.vh-metric{text-align:center}
.vh-metric .n{font-size:32px;font-weight:700;background:linear-gradient(120deg,var(--vh-g1),var(--vh-g2));-webkit-background-clip:text;background-clip:text;color:transparent}
.vh-metric .l{color:var(--vh-muted);font-weight:600;font-size:14px}

/* Sections */
.vh-section{padding:90px 0}
.vh-section--soft{background:var(--vh-soft)}
.vh-eyebrow{text-align:center;color:var(--vh-accent);font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:13px;margin-bottom:12px}
.vh-h2{text-align:center;font-size:clamp(28px,4vw,42px);font-weight:700;letter-spacing:-1px;margin:0 0 14px}
.vh-lead{text-align:center;color:var(--vh-muted);font-size:18px;max-width:640px;margin:0 auto 52px}

/* Capability grid */
.vh-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.vh-grid--2{grid-template-columns:repeat(2,1fr)}
.vh-card{background:#fff;border:1px solid var(--vh-line);border-radius:var(--vh-radius);padding:30px;transition:transform .25s,box-shadow .25s,border-color .25s}
.vh-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px rgba(15,23,42,.10);border-color:transparent}
.vh-ico{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;font-size:26px;margin-bottom:18px;color:#fff}
.vh-ico--1{background:linear-gradient(135deg,#2563eb,#3b82f6)}
.vh-ico--2{background:linear-gradient(135deg,#4f46e5,#6366f1)}
.vh-ico--3{background:linear-gradient(135deg,#0284c7,#38bdf8)}
.vh-ico--4{background:linear-gradient(135deg,#1d4ed8,#60a5fa)}
.vh-ico--5{background:linear-gradient(135deg,#0891b2,#22d3ee)}
.vh-ico--6{background:linear-gradient(135deg,#059669,#10b981)}
.vh-card h3{font-size:20px;font-weight:700;margin:0 0 8px}
.vh-card p{color:var(--vh-muted);font-size:15.5px;margin:0}

/* Alternating feature rows */
.vh-feat{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;padding:64px 0}
.vh-feat__media{order:2}
.vh-feat--rev .vh-feat__body{order:2}
.vh-feat--rev .vh-feat__media{order:1}
.vh-feat__kicker{color:var(--vh-accent);font-weight:700;font-size:13px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:10px}
.vh-feat__body h2{font-size:clamp(26px,3.4vw,36px);font-weight:700;letter-spacing:-.8px;margin:0 0 14px;line-height:1.15}
.vh-feat__body p{color:var(--vh-muted);font-size:17px;margin:0 0 20px}
.vh-checks{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.vh-checks li{display:flex;gap:11px;align-items:flex-start;font-size:15.5px}
.vh-checks .ck{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:#eff6ff;color:var(--vh-accent);display:grid;place-items:center;font-weight:800;font-size:13px;margin-top:1px}

/* Mock cards inside features */
.vh-mock{background:#fff;border:1px solid var(--vh-line);border-radius:var(--vh-radius);box-shadow:0 30px 60px rgba(15,23,42,.08);padding:22px}
.vh-mock__head{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.vh-mock__avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--vh-g1),var(--vh-g2));color:#fff;display:grid;place-items:center;font-weight:700}
.vh-mock__title{font-weight:700;font-size:15px}
.vh-mock__sub{color:var(--vh-muted);font-size:12.5px}
.vh-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:6px}
.vh-field{background:var(--vh-soft);border:1px solid var(--vh-line);border-radius:12px;padding:10px 12px}
.vh-field .k{font-size:11px;color:var(--vh-muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.vh-field .v{font-size:14px;font-weight:700;margin-top:2px}
.vh-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.vh-badge{font-size:12px;font-weight:700;padding:5px 11px;border-radius:999px;background:#eff6ff;color:var(--vh-accent)}
.vh-badge--ok{background:#dcfce7;color:#047857}
.vh-bigval{font-size:34px;font-weight:700;letter-spacing:-1px}
.vh-range{color:var(--vh-muted);font-size:14px;margin-top:2px}

/* Mock del módulo de marketing: Reel vertical 9:16 + selector de formatos */
.vh-reelwrap{display:flex;gap:18px;align-items:center;justify-content:center;flex-wrap:wrap}
.vh-reel{position:relative;width:226px;aspect-ratio:9/16;border-radius:22px;overflow:hidden;flex:0 0 auto;box-shadow:0 30px 60px rgba(15,23,42,.30);background:linear-gradient(150deg,#3b82f6,#6366f1 55%,#0f172a)}
.vh-reel__top{position:absolute;top:12px;left:12px;right:12px;display:flex;justify-content:space-between;align-items:center;z-index:2}
.vh-reel__fmt{background:rgba(0,0,0,.42);color:#fff;font-size:11px;font-weight:700;padding:5px 11px;border-radius:999px}
.vh-reel__ratio{background:rgba(255,255,255,.22);color:#fff;font-size:10px;font-weight:700;padding:4px 8px;border-radius:7px}
.vh-reel__play{position:absolute;inset:0;margin:auto;width:58px;height:58px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;color:#1e293b;font-size:20px;z-index:2;box-shadow:0 10px 30px rgba(0,0,0,.3)}
.vh-reel__grad{position:absolute;left:0;right:0;bottom:0;height:58%;background:linear-gradient(180deg,transparent,rgba(15,23,42,.88));z-index:1}
.vh-reel__cap{position:absolute;left:14px;right:14px;bottom:18px;z-index:2;color:#fff}
.vh-reel__cap .badge{display:inline-block;background:#ef4444;color:#fff;font-size:10px;font-weight:800;padding:3px 8px;border-radius:6px;margin-bottom:8px;letter-spacing:.03em}
.vh-reel__cap .price{font-size:21px;font-weight:800;line-height:1}
.vh-reel__cap .old{font-size:13px;font-weight:600;opacity:.7;text-decoration:line-through;margin-left:6px}
.vh-reel__cap .ttl{font-size:12.5px;font-weight:600;opacity:.95;margin-top:3px}
.vh-reel__cap .ag{display:flex;align-items:center;gap:6px;margin-top:9px;font-size:11px;font-weight:700;opacity:.92}
.vh-reel__cap .ag .dot{width:16px;height:16px;border-radius:5px;background:#fff;color:#2563eb;display:grid;place-items:center;font-size:10px;font-weight:800}
.vh-reel__scrub{position:absolute;left:0;right:0;bottom:0;height:4px;background:rgba(255,255,255,.28);z-index:3}
.vh-reel__scrub span{display:block;height:100%;width:62%;background:#fff}
.vh-fmts{display:flex;flex-direction:column;gap:9px;min-width:196px}
.vh-fmt{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--vh-line);border-radius:12px;padding:10px 13px;font-size:13.5px;font-weight:600;color:var(--vh-ink)}
.vh-fmt .e{font-size:17px}
.vh-fmt.is-active{border-color:var(--vh-accent);box-shadow:0 0 0 2px rgba(59,130,246,.16)}
.vh-fmt .chk{margin-left:auto;color:var(--vh-accent);font-weight:800}

/* Mini agenda semanal (vista de semana con tipos de evento) */
.vh-week{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin:8px 0 14px}
.vh-week .d{background:var(--vh-soft);border:1px solid var(--vh-line);border-radius:9px;padding:7px 3px 9px;text-align:center;min-height:64px}
.vh-week .d .dn{font-size:10px;color:var(--vh-muted);font-weight:700;margin-bottom:6px}
.vh-week .d .ev{display:block;height:5px;border-radius:3px;margin:3px 3px}
.vh-week .today{border-color:var(--vh-accent);box-shadow:0 0 0 2px rgba(59,130,246,.15)}
.vh-legend{display:flex;flex-wrap:wrap;gap:8px 14px;font-size:12px;color:var(--vh-muted);font-weight:600}
.vh-legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:-1px}
.ev--visit{background:#2563eb}
.ev--firma{background:#6366f1}
.ev--task{background:#38bdf8}
.ev--cumple{background:#f59e0b}
.ev--reminder{background:#10b981}
.ev--media{background:#8b5cf6}

/* Agenda realista: cabecera + tira de días + lista scrolleable del día */
.vh-agenda{background:#fff;border:1px solid var(--vh-line);border-radius:var(--vh-radius);box-shadow:0 30px 60px rgba(15,23,42,.10);overflow:hidden}
.vh-agenda__hd{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 0}
.vh-agenda__hd .ttl{font-weight:700;font-size:15px}
.vh-agenda__hd .sub{font-size:12px;color:var(--vh-muted)}
.vh-agenda__hoy{font-size:11px;font-weight:700;color:var(--vh-accent);background:#eff6ff;padding:3px 10px;border-radius:999px}
.vh-agenda__days{display:flex;gap:5px;padding:12px 18px 8px}
.vh-agenda__day{flex:1;text-align:center;font-size:10.5px;font-weight:700;color:var(--vh-muted);padding:6px 0;border-radius:9px;background:var(--vh-soft);border:1px solid var(--vh-line)}
.vh-agenda__day b{display:block;font-size:13px;margin-top:1px;font-weight:700}
.vh-agenda__day.is-active{background:linear-gradient(135deg,var(--vh-g1),var(--vh-g2));color:#fff;border-color:transparent}
.vh-agenda__list{max-height:300px;overflow-y:auto;padding:2px 18px 16px}
.vh-agenda__item{display:flex;gap:11px;align-items:stretch;padding:11px 0;border-bottom:1px solid #f1f5f9}
.vh-agenda__item:last-child{border-bottom:none}
.vh-agenda__time{flex:0 0 auto;width:44px;font-weight:700;font-size:12.5px;color:var(--vh-ink);padding-top:1px}
.vh-agenda__bar{flex:0 0 auto;width:4px;border-radius:3px}
.vh-agenda__c{flex:1;min-width:0}
.vh-agenda__c .t{font-weight:700;font-size:13.5px;line-height:1.3}
.vh-agenda__c .s{font-size:12px;color:var(--vh-muted);margin-top:1px}
.vh-agenda__tag{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;margin-top:5px;background:var(--vh-soft);color:var(--vh-muted)}

/* Mini-gráfico de tendencia (trendline mensual) dentro de un mock */
.vh-spark{display:flex;align-items:flex-end;gap:7px;height:92px;margin:10px 0 6px}
.vh-spark span{flex:1;background:linear-gradient(180deg,var(--vh-g3),var(--vh-g1));border-radius:6px 6px 0 0}
.vh-sparkx{display:flex;gap:7px;font-size:10px;color:var(--vh-muted);font-weight:600}
.vh-sparkx span{flex:1;text-align:center}

/* Checklist (tareas automáticas) dentro de un mock */
.vh-tasklist{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:11px}
.vh-tasklist li{display:flex;gap:10px;align-items:center;font-size:14px}
.vh-tasklist .box{flex:0 0 auto;width:20px;height:20px;border-radius:6px;border:2px solid var(--vh-border-strong,#cbd5e1);display:grid;place-items:center;font-size:12px}
.vh-tasklist .box--done{background:var(--vh-success);border-color:var(--vh-success);color:#fff}
.vh-tasklist .due{margin-left:auto;font-size:11px;color:var(--vh-muted);font-weight:600;white-space:nowrap}

/* Rows of stat numbers */
.vh-statrow{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:760px;margin:0 auto}
.vh-stat{text-align:center;background:#fff;border:1px solid var(--vh-line);border-radius:var(--vh-radius);padding:26px 18px}
.vh-stat .n{font-size:30px;font-weight:700;background:linear-gradient(120deg,var(--vh-g1),var(--vh-g2));-webkit-background-clip:text;background-clip:text;color:transparent}
.vh-stat .l{color:var(--vh-muted);font-weight:600;font-size:14px;margin-top:4px}

/* FAQ */
.vh-faq{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.vh-faq details{background:#fff;border:1px solid var(--vh-line);border-radius:14px;padding:0 22px;transition:box-shadow .2s}
.vh-faq details[open]{box-shadow:0 12px 30px rgba(15,23,42,.07)}
.vh-faq summary{cursor:pointer;list-style:none;font-weight:700;font-size:16.5px;padding:20px 0;display:flex;justify-content:space-between;align-items:center;gap:16px}
.vh-faq summary::-webkit-details-marker{display:none}
.vh-faq summary::after{content:"+";font-size:24px;color:var(--vh-accent);font-weight:400;line-height:1}
.vh-faq details[open] summary::after{content:"\2212"}
.vh-faq .a{color:var(--vh-muted);font-size:15.5px;padding:0 0 22px;margin:0}

/* CTA band */
.vh-band{margin:0 24px;border-radius:36px;background:linear-gradient(135deg,var(--vh-g1),var(--vh-g2));color:#fff;text-align:center;padding:74px 30px}
.vh-band h2{font-size:clamp(28px,4vw,42px);font-weight:700;letter-spacing:-1px;margin:0 0 12px}
.vh-band p{color:rgba(255,255,255,.88);font-size:18px;max-width:540px;margin:0 auto 30px}

/* Manifiesto / banda oscura */
.vh-future{position:relative;overflow:hidden;background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff;border-radius:36px;padding:74px 30px;text-align:center}
.vh-future__glow{position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.40),transparent 70%);top:-240px;left:50%;transform:translateX(-50%);pointer-events:none}
.vh-future__inner{position:relative;z-index:1}
.vh-future__chips{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.vh-future__chip{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:10px 18px;font-weight:600;font-size:14px;color:#e2e8f0}

/* Comparativa de dos columnas (sin precios) */
.vh-save{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:920px;margin:0 auto;align-items:stretch}
.vh-save__card{border-radius:var(--vh-radius);padding:32px;border:1px solid var(--vh-line);background:#fff}
.vh-save__card--sep{background:var(--vh-soft)}
.vh-save__card--val{background:linear-gradient(135deg,var(--vh-g1),var(--vh-g2));color:#fff;border-color:transparent;box-shadow:0 30px 60px rgba(37,99,235,.30)}
.vh-save__h{font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.vh-save__card--sep .vh-save__h{color:var(--vh-muted)}
.vh-save__item{display:flex;gap:12px;align-items:flex-start;font-size:15.5px;margin-bottom:14px;line-height:1.45}
.vh-save__item .mk{flex:0 0 auto;width:23px;height:23px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:12px;margin-top:1px}
.vh-save__card--sep .vh-save__item{color:var(--vh-muted)}
.vh-save__card--sep .mk{background:#fee2e2;color:#b91c1c}
.vh-save__card--val .mk{background:rgba(255,255,255,.22);color:#fff}

@media(max-width:860px){
  .vh-grid,.vh-grid--2{grid-template-columns:1fr}
  .vh-save{grid-template-columns:1fr}
  .vh-statrow{grid-template-columns:1fr}
  .vh-feat{grid-template-columns:1fr;gap:30px;padding:44px 0}
  .vh-feat__media,.vh-feat--rev .vh-feat__media,.vh-feat--rev .vh-feat__body{order:0}
}
