﻿/*
Theme Name: SmartMentor Child
Theme URI: https://smartmentor360.com
Description: Tema hijo de Astra para SmartMentor360° — migración del mockup HTML.
Author: SmartMentor
Template: astra
Version: 3.0.0
Text Domain: smartmentor-child
*/
/* ══════════════════════════════════════════
   DESIGN TOKENS — SmartMentor360°
══════════════════════════════════════════ */
:root {
  --p200:#026BC0; --p300:#184674; --p400:#0B1F33;
  --a200:#8FF0DD; --a300:#1DCDAF; --a400:#00C2A8;
  --white:#fff; --light:#F0F8FF; --border:#D0E8F5;
  --text:#0B1F33; --muted:#4A637A;
  --r:14px; --rl:22px;
  --font:'Segoe UI',system-ui,-apple-system,sans-serif;
  --sh:0 4px 32px rgba(2,107,192,.1);
  --sh-lg:0 20px 64px rgba(2,107,192,.2);
  --sh-dk:0 24px 72px rgba(0,0,0,.55);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--text);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none}
.container{max-width:1240px;margin:0 auto;padding:0 28px}
.sec{padding:108px 0}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(36px);transition:opacity .75s ease,transform .75s ease}
.rv.on{opacity:1;transform:translateY(0)}
.rv-l{opacity:0;transform:translateX(-36px);transition:opacity .75s ease,transform .75s ease}
.rv-l.on{opacity:1;transform:translateX(0)}
.rv-r{opacity:0;transform:translateX(36px);transition:opacity .75s ease,transform .75s ease}
.rv-r.on{opacity:1;transform:translateX(0)}

/* ── TYPE ── */
.t-hero{font-size:clamp(2.1rem,4.3vw,3.7rem);font-weight:900;color:#fff;line-height:1.03;letter-spacing:-2px}
.t-hero em{color:var(--a300);font-style:normal;display:block}
.t-sec{font-size:clamp(1.8rem,3vw,2.7rem);font-weight:900;color:var(--p400);line-height:1.1;letter-spacing:-1px;margin-bottom:14px}
.t-sec em{color:var(--a300);font-style:normal}
.t-sec.wh{color:#fff}
.t-sub{font-size:1.03rem;color:var(--muted);line-height:1.78;max-width:580px}
.t-sub.wh{color:rgba(255,255,255,.72)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:9px;border-radius:var(--r);font-weight:700;font-size:.95rem;font-family:var(--font);cursor:pointer;border:none;transition:all .28s;text-decoration:none;white-space:nowrap}
.btn-g{background:var(--a300);color:var(--p400);padding:15px 30px}
.btn-g:hover{background:var(--a200);transform:translateY(-3px);box-shadow:0 12px 36px rgba(29,205,175,.45)}
.btn-o{background:transparent;border:2px solid rgba(255,255,255,.3);color:#fff;padding:13px 26px}
.btn-o:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.6)}
.btn-b{background:var(--p200);color:#fff;padding:15px 30px}
.btn-b:hover{background:var(--p300);transform:translateY(-3px);box-shadow:0 12px 36px rgba(2,107,192,.45)}
.btn-full{width:100%;justify-content:center;background:linear-gradient(135deg,var(--p200),var(--p300));color:#fff;padding:15px 20px;font-size:1rem;border-radius:var(--r)}
.btn-full:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(2,107,192,.5)}
.btn-ghost-price{display:block;text-align:center;background:var(--light);color:var(--text);border:1.5px solid var(--border);border-radius:var(--r);padding:13px;font-size:.92rem;font-weight:700;margin-top:auto;transition:all .22s}
.btn-ghost-price:hover{border-color:var(--p200);color:var(--p200)}
.btn-main-price{display:block;text-align:center;background:var(--p200);color:#fff;border-radius:var(--r);padding:13px;font-size:.92rem;font-weight:700;margin-top:auto;transition:all .22s}
.btn-main-price:hover{background:var(--p300);transform:translateY(-1px)}

/* ══ SVG ICON HELPER ══ */
.ico{display:inline-flex;align-items:center;justify-content:center}
.ico svg{stroke-linecap:round;stroke-linejoin:round;fill:none}

/* ══ NAV ══ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:16px 0;transition:all .35s}
.nav.sc{background:rgba(11,31,51,.96);backdrop-filter:blur(22px);padding:10px 0;box-shadow:0 2px 36px rgba(0,0,0,.35)}
.nav-in{display:flex;justify-content:space-between;align-items:center}
/* Horizontal logo for desktop/tablet */
.logo-h{display:flex;align-items:center}
.logo-h svg{height:42px;width:auto}
/* Vertical/stacked logo for mobile */
.logo-v{display:none;align-items:center}
.logo-v svg{height:48px;width:auto}
.nav-links{list-style:none;display:flex;align-items:center;gap:4px}
.nav-links a{color:rgba(255,255,255,.78);padding:8px 14px;border-radius:9px;font-size:.87rem;font-weight:500;transition:all .2s}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.1)}
.nav-cta{background:var(--a300)!important;color:var(--p400)!important;font-weight:800!important;border-radius:9px!important;padding:9px 22px!important}
.nav-cta:hover{background:var(--a200)!important;transform:translateY(-1px)}
.ham{display:none;background:none;border:none;cursor:pointer;color:#fff;padding:6px}

/* ══ HERO ══ */
.hero{min-height:100vh;position:relative;display:flex;align-items:center;padding-top:80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:linear-gradient(118deg,#050f1a 0%,#184674 38%,#06314d 65%,#0a2838 100%),radial-gradient(ellipse 90% 60% at 75% 15%,rgba(29,205,175,.12),transparent 55%);background-size:cover,cover;background-position:center 30%;animation:kb 20s ease-in-out infinite alternate}
@keyframes kb{from{transform:scale(1.04)}to{transform:scale(1.1) translate(-1%,-1%)}}
.hero-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(11,31,51,.93) 0%,rgba(2,107,192,.5) 55%,rgba(0,194,168,.18) 100%)}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(29,205,175,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(29,205,175,.055) 1px,transparent 1px);background-size:64px 64px}
.orb{position:absolute;border-radius:50%;filter:blur(110px);pointer-events:none}
.o1{width:700px;height:700px;background:radial-gradient(circle,rgba(2,107,192,.65),transparent 70%);top:-180px;right:-130px}
.o2{width:500px;height:500px;background:radial-gradient(circle,rgba(29,205,175,.3),transparent 70%);bottom:-100px;left:-80px}
.hero-in{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;padding:90px 0 110px}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:rgba(29,205,175,.13);border:1px solid rgba(29,205,175,.32);border-radius:100px;padding:8px 18px;font-size:.78rem;font-weight:800;color:var(--a300);width:fit-content;margin-bottom:22px;letter-spacing:.5px;text-transform:uppercase}
.pdot{width:8px;height:8px;background:var(--a300);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(1.7)}}
.hero-desc{color:rgba(255,255,255,.75);font-size:1.08rem;line-height:1.8;margin:20px 0 28px;max-width:520px}
.hero-checks{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:34px}
.hero-checks li{display:flex;align-items:center;gap:11px;color:rgba(255,255,255,.88);font-size:.95rem;font-weight:500}
.hchk{width:24px;height:24px;border-radius:50%;background:var(--a300);color:var(--p400);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hero-btns{display:flex;flex-wrap:wrap;gap:13px;margin-bottom:36px}
.trust-row{display:flex;align-items:center;flex-wrap:wrap;gap:14px}
.trust-lbl{font-size:.74rem;color:rgba(255,255,255,.48);font-weight:700;text-transform:uppercase;letter-spacing:1.2px}
.tpill{display:inline-flex;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:6px;padding:4px 12px;font-size:.74rem;font-weight:700;color:rgba(255,255,255,.72);gap:6px;flex-wrap:wrap}

/* Hero Form */
.hform-wrap{position:relative}
.fbadge{position:absolute;background:rgba(255,255,255,.97);border-radius:14px;padding:12px 16px;display:flex;align-items:center;gap:11px;box-shadow:var(--sh-dk);animation:flt 3.2s ease-in-out infinite;z-index:10}
.fb-ico{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fbadge strong{display:block;font-size:1.1rem;font-weight:900;color:var(--p400);line-height:1}
.fbadge small{font-size:.68rem;color:var(--muted)}
.fb1{top:-20px;left:-18px;animation-delay:0s}
.fb2{bottom:18px;right:-16px;animation-delay:1.6s}
@keyframes flt{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.fcard{background:rgba(255,255,255,.97);backdrop-filter:blur(28px);border-radius:var(--rl);padding:34px;box-shadow:var(--sh-dk);border:1px solid rgba(255,255,255,.28)}
.fcard-ey{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:1.8px;color:var(--a300);margin-bottom:5px}
.fcard h3{font-size:1.45rem;font-weight:900;color:var(--p400);margin-bottom:4px}
.fcard-sub{font-size:.82rem;color:var(--muted);margin-bottom:22px}
.dform{display:flex;flex-direction:column;gap:12px}
.ff{display:flex;flex-direction:column;gap:5px}
.ff label{font-size:.76rem;font-weight:700;color:var(--text);letter-spacing:.3px}
.ff input,.ff select{border:1.5px solid var(--border);border-radius:10px;font-size:.9rem;font-family:var(--font);color:var(--text);background:var(--light);outline:none;transition:all .2s}
.ff input{padding:12px 14px}
.ff input:focus,.ff select:focus{border-color:var(--p200);background:#fff;box-shadow:0 0 0 3px rgba(2,107,192,.1)}
.ff-sel-wrap{position:relative;display:block}
.ff-sel-wrap::after{content:'';position:absolute;right:13px;top:50%;transform:translateY(-50%);width:12px;height:7px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A6376' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain;pointer-events:none}
.ff-select{appearance:none;-webkit-appearance:none;width:100%;cursor:pointer}
.ff-select:invalid{color:var(--muted)}
.ff-select option[value=""]{color:var(--muted)}
.ff-select option{color:var(--text)}
.ffrow{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-legal{font-size:.7rem;color:var(--muted);text-align:center;margin-top:4px}
.form-ok{text-align:center;padding:30px}
.ok-ico{width:62px;height:62px;background:linear-gradient(135deg,var(--a300),var(--a400));border-radius:50%;margin:0 auto 14px;display:flex;align-items:center;justify-content:center}
.form-ok h4{font-size:1.15rem;font-weight:800;color:var(--p400);margin-bottom:8px}
.form-ok p{font-size:.87rem;color:var(--muted)}

/* ══ TRUST BAR ══ */
.tbar{background:var(--light);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:18px 0}
.tbar-in{display:flex;align-items:center;flex-wrap:wrap;gap:22px}
.tbar-lbl{font-size:.76rem;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;white-space:nowrap}
.tbar-logos{display:flex;flex-wrap:wrap;align-items:center;gap:28px 36px}
.tbar-logo{display:flex;align-items:center}
.tbar-logo img{height:34px;width:auto;max-width:130px;object-fit:contain;display:block}

/* ══ STATS SECTION ══ */
.stats-sec{position:relative;overflow:hidden;background:var(--p400)}
.stats-bg{position:absolute;inset:0;background:linear-gradient(125deg,#071525 0%,#1a4a6e 45%,#0d2133 100%),radial-gradient(circle at 30% 70%,rgba(29,205,175,.08),transparent 50%);background-size:cover,cover;background-position:center;filter:brightness(.85) saturate(1.15)}
.stats-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(11,31,51,.94),rgba(2,107,192,.72))}
.sgrid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(143,240,221,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(143,240,221,.04) 1px,transparent 1px);background-size:52px 52px}
.stats-in{position:relative;z-index:2;padding:108px 0}
.stats-head{text-align:center;margin-bottom:64px}
.scards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.scard{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.11);border-radius:var(--rl);padding:40px 24px;text-align:center;backdrop-filter:blur(12px);transition:all .3s;position:relative;overflow:hidden;cursor:default}
.scard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--a300),var(--p200));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.scard:hover{background:rgba(255,255,255,.11);transform:translateY(-8px);box-shadow:0 24px 56px rgba(0,0,0,.4)}
.scard:hover::before{transform:scaleX(1)}
.scard-icon{margin-bottom:18px;display:flex;justify-content:center}
.scard-icon svg{width:52px;height:52px;stroke:var(--a300);fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
/* Stat number: superscript symbol FIRST, then big number */
.snum-wrap{display:flex;align-items:flex-start;justify-content:center;gap:2px;line-height:1;margin-bottom:8px}
.snum-sym{font-size:2rem;font-weight:900;color:var(--a300);margin-top:4px}
.snum-val{font-size:4.2rem;font-weight:900;color:var(--a300);line-height:1}
.slbl{font-size:.9rem;color:rgba(255,255,255,.78);line-height:1.55;font-weight:500;margin-bottom:6px}
.ssrc{font-size:.68rem;color:rgba(255,255,255,.38);font-weight:600;text-transform:uppercase;letter-spacing:.8px}

/* ══ PROBLEMA SECTION — with bg images ══ */
.prob-sec{position:relative;overflow:hidden;background:var(--p400)}
.prob-bg{position:absolute;inset:0;background:linear-gradient(135deg,#060d18 0%,#1a3550 50%,#0a1628 100%),radial-gradient(ellipse 70% 50% at 50% 100%,rgba(2,107,192,.12),transparent);background-size:cover,cover;background-position:center 40%;filter:brightness(.9) saturate(1.05)}
.prob-ov{position:absolute;inset:0;background:linear-gradient(160deg,rgba(11,31,51,.97),rgba(24,70,116,.88))}
.prob-in{position:relative;z-index:2;padding:108px 0}
.prob-head{text-align:center;margin-bottom:52px}
/* Problem cards with individual background images */
.prob-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-bottom:0}
.pcard{border-radius:var(--rl);overflow:hidden;position:relative;min-height:240px;cursor:default;transition:transform .35s}
.pcard:hover{transform:translateY(-6px)}
.pcard-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .4s}
.pcard:hover .pcard-bg{transform:scale(1.04)}
.pcard-color-ov{position:absolute;inset:0;transition:opacity .3s}
.pcard:hover .pcard-color-ov{opacity:.82}
.pcard-content{position:relative;z-index:2;padding:30px 28px;height:100%;display:flex;flex-direction:column;justify-content:flex-end}
.pbadge{display:inline-flex;align-items:center;gap:5px;background:rgba(226,67,82,.25);border:1px solid rgba(226,67,82,.5);border-radius:6px;padding:4px 10px;font-size:.7rem;font-weight:800;color:#ffaab2;margin-bottom:9px;text-transform:uppercase;letter-spacing:.6px;width:fit-content}
.ptitle{color:#fff;font-size:1.08rem;font-weight:800;margin-bottom:6px;line-height:1.25}
.pdesc{color:rgba(255,255,255,.78);font-size:.84rem;line-height:1.6}

/* divider */
.sol-div{display:flex;flex-direction:column;align-items:center;gap:10px;padding:40px 0 30px}
.sdline{width:2px;height:52px;background:linear-gradient(180deg,rgba(226,67,82,.5),var(--a300))}
.sdtag{background:rgba(29,205,175,.13);border:1px solid rgba(29,205,175,.32);border-radius:100px;padding:7px 20px;font-size:.76rem;font-weight:800;color:var(--a300);text-transform:uppercase;letter-spacing:1.8px}
.sdarrow{color:var(--a300);font-size:1.8rem;animation:bdn .5s cubic-bezier(.4,0,.6,1) infinite alternate}
@keyframes bdn{from{transform:translateY(0)}to{transform:translateY(8px)}}

/* solution block */
.sol-block{background:linear-gradient(135deg,rgba(2,107,192,.22),rgba(29,205,175,.12));border:1px solid rgba(29,205,175,.32);border-radius:var(--rl);overflow:hidden;position:relative}
.sol-block::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--p200),var(--a300))}
.sol-inner{display:grid;grid-template-columns:1fr 1fr;gap:0}
.sol-l{padding:42px 38px;border-right:1px solid rgba(255,255,255,.1)}
.sol-l h3{font-size:1.55rem;font-weight:900;color:#fff;line-height:1.2;margin-bottom:13px}
.sol-l h3 em{color:var(--a300);font-style:normal}
.sol-l p{color:rgba(255,255,255,.72);font-size:.96rem;line-height:1.75;margin-bottom:24px}
.sol-r{padding:42px 38px;display:flex;flex-direction:column;gap:14px;justify-content:center}
.sfeat{display:flex;align-items:center;gap:14px}
.sf-ico{width:44px;height:44px;background:rgba(29,205,175,.15);border:1px solid rgba(29,205,175,.28);border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sf-ico svg{width:22px;height:22px;stroke:var(--a300);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.sf-text strong{display:block;color:#fff;font-size:.9rem;font-weight:700;margin-bottom:2px}
.sf-text span{font-size:.77rem;color:rgba(255,255,255,.55)}

/* ══ PROPUESTA VALOR ══ */
.valor-sec{position:relative;overflow:hidden;background:var(--p300)}
.valor-bg{position:absolute;inset:0;background:linear-gradient(140deg,#0f2740 0%,#184674 42%,#082238 100%),radial-gradient(circle at 20% 30%,rgba(29,205,175,.1),transparent 45%);background-size:cover,cover;background-position:center;filter:brightness(.88) saturate(1.12)}
.valor-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(24,70,116,.97),rgba(11,31,51,.86))}
.valor-in{position:relative;z-index:2;padding:108px 0;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.vchecks{list-style:none;display:flex;flex-direction:column;gap:14px;margin:24px 0 34px}
.vchecks li{display:flex;align-items:flex-start;gap:13px;color:rgba(255,255,255,.88);font-size:.95rem;line-height:1.5}
.vchk{width:26px;height:26px;background:var(--a300);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.vchk svg{width:14px;height:14px;stroke:var(--p400);fill:none;stroke-width:2.8;stroke-linecap:round;stroke-linejoin:round}
.valor-img-wrap{border-radius:var(--rl);overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.35)}
.valor-img{width:100%;height:auto;display:block;border-radius:var(--rl)}
.dw{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);border-radius:var(--rl);padding:30px;backdrop-filter:blur(16px)}
.dw-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.09)}
.dw-tag{background:var(--a300);color:var(--p400);font-size:.76rem;font-weight:800;padding:4px 11px;border-radius:6px}
.dw-meta{color:rgba(255,255,255,.55);font-size:.8rem;display:flex;align-items:center;gap:6px}
.live-dot{width:7px;height:7px;background:#4cff91;border-radius:50%;animation:pulse 1.5s infinite}
.dw-bars{display:flex;flex-direction:column;gap:15px;margin-bottom:22px}
.dw-br{display:flex;flex-direction:column;gap:6px}
.dw-bl{display:flex;justify-content:space-between}
.dw-bl span{font-size:.77rem;color:rgba(255,255,255,.65)}
.dw-bl strong{font-size:.77rem;color:rgba(255,255,255,.9);font-weight:700}
.dw-bt{height:8px;background:rgba(255,255,255,.09);border-radius:100px;overflow:hidden}
.dw-bf{height:100%;border-radius:100px}
.dw-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.dw-kpi{background:rgba(255,255,255,.06);border-radius:10px;padding:13px 10px;text-align:center}
.dw-kpi strong{display:block;font-size:1.35rem;font-weight:900;color:var(--a300);line-height:1;margin-bottom:3px}
.dw-kpi span{font-size:.7rem;color:rgba(255,255,255,.55);line-height:1.3}

/* ══ CÓMO FUNCIONA ══ */
.how-sec{background:var(--light)}
.how-grid{display:grid;grid-template-columns:300px 1fr;border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh-lg);margin-top:48px;border:1px solid var(--border)}
.how-side{background:var(--p400);padding:30px;display:flex;flex-direction:column;gap:6px}
.hbtn{background:none;border:none;cursor:pointer;border-radius:12px;padding:16px 17px;display:flex;align-items:center;gap:13px;width:100%;text-align:left;transition:all .22s;font-family:var(--font)}
.hbtn:hover{background:rgba(255,255,255,.09)}
.hbtn.act{background:rgba(29,205,175,.14);border:1px solid rgba(29,205,175,.33)}
.hbtn-num{color:var(--a300);font-size:.76rem;font-weight:800;min-width:26px}
.hbtn span:last-child{color:rgba(255,255,255,.72);font-size:.88rem;font-weight:500}
.hbtn.act span:last-child{color:#fff;font-weight:700}
.how-content{background:#fff;position:relative;min-height:340px}
.hpanel{position:absolute;inset:0;padding:46px 48px;opacity:0;pointer-events:none;transform:translateX(18px);transition:all .38s}
.hpanel.act{opacity:1;pointer-events:auto;transform:translateX(0)}
.hp-bignum{position:absolute;top:18px;right:32px;font-size:6.5rem;font-weight:900;line-height:1;color:var(--border)}
.hp-icon{width:64px;height:64px;background:linear-gradient(135deg,var(--a200),var(--a300));border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;box-shadow:0 8px 24px rgba(29,205,175,.3)}
.hp-icon svg{width:32px;height:32px;stroke:var(--p400);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.hpanel h3{font-size:1.5rem;font-weight:800;color:var(--p400);margin-bottom:11px}
.hpanel p{color:var(--muted);max-width:440px;line-height:1.78;margin-bottom:24px}
.btn-nxt{display:inline-flex;align-items:center;gap:8px;background:var(--p200);color:#fff;border:none;border-radius:10px;padding:11px 22px;font-size:.88rem;font-weight:700;cursor:pointer;font-family:var(--font);transition:all .22s}
.btn-nxt:hover{background:var(--p300);transform:translateY(-1px)}
.how-flow{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:0;margin-top:36px;background:var(--light);border:1px solid var(--border);border-radius:var(--r);padding:26px}
.fstep{display:flex;align-items:center;gap:12px}
.fstep-ico{width:56px;height:56px;background:#fff;border:1px solid var(--border);border-radius:15px;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh)}
.fstep-ico svg{width:28px;height:28px;stroke:var(--p200);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.fstep-lbl{font-size:.8rem;font-weight:600;color:var(--muted);max-width:78px;text-align:center}
.farrow{color:var(--a300);padding:0 14px;font-size:1.5rem;font-weight:700}

/* ══ BENEFICIOS — CAROUSEL ══ */
.ben-sec{background:var(--white);overflow:hidden}
.ben-carousel-wrap{position:relative;margin-top:48px}
.ben-track-outer{overflow:hidden;border-radius:var(--rl)}
.ben-track{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1);will-change:transform}
.ben-slide{min-width:calc(33.333% - 14px);margin-right:21px}
.ben-slide:last-child{margin-right:0}
.bcard{background:var(--white);border:1px solid var(--border);border-radius:var(--rl);padding:38px 32px;height:100%;transition:all .32s;position:relative;overflow:hidden;cursor:default}
.bcard::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--a300),var(--p200));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.bcard:hover{transform:translateY(-7px);box-shadow:var(--sh-lg);border-color:var(--a200)}
.bcard:hover::after{transform:scaleX(1)}
.bcard-icon{width:64px;height:64px;background:var(--light);border:1px solid var(--border);border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:all .3s}
.bcard:hover .bcard-icon{background:linear-gradient(135deg,var(--a200),var(--a300));border-color:var(--a300)}
.bcard-icon svg{width:30px;height:30px;stroke:var(--p200);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .3s}
.bcard:hover .bcard-icon svg{stroke:var(--p400)}
/* Big number accent in benefit cards */
.bcard-num{font-size:2.8rem;font-weight:900;color:var(--a300);line-height:1;margin-bottom:6px;display:block}
.bcard h3{font-size:1.1rem;font-weight:800;color:var(--p400);margin-bottom:8px}
.bcard p{font-size:.87rem;color:var(--muted);line-height:1.68}
/* Carousel controls */
.ben-controls{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:32px}
.ben-dot-wrap{display:flex;gap:8px;align-items:center}
.ben-dot{width:10px;height:10px;border-radius:50%;background:#b0cce0;cursor:pointer;transition:all .3s;border:none;padding:0}
.ben-dot.act{background:var(--p200);transform:scale(1.3)}
.ben-arr{width:44px!important;height:44px!important;min-width:44px!important;min-height:44px!important;border-radius:50%!important;border:1.5px solid var(--border)!important;background:var(--white)!important;cursor:pointer;display:flex!important;align-items:center!important;justify-content:center!important;transition:all .25s;color:var(--p300)!important;padding:0!important;font-size:0!important;line-height:1!important;box-sizing:border-box!important}
.ben-arr:hover{border-color:var(--p200)!important;background:var(--p200)!important;color:#fff!important}
.ben-arr svg{width:18px!important;height:18px!important;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;display:block!important;flex-shrink:0}

/* ══ DIFERENCIAL ══ */
.diff-sec{position:relative;overflow:hidden}
.diff-bg{position:absolute;inset:0;background:linear-gradient(120deg,#071422 0%,#184674 40%,#062a42 100%),radial-gradient(ellipse 80% 55% at 60% 20%,rgba(29,205,175,.1),transparent 50%);background-size:cover,cover;background-position:center 30%;filter:brightness(.88) saturate(1.15)}
.diff-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(11,31,51,.96) 0%,rgba(2,107,192,.72) 55%,rgba(0,194,168,.28) 100%)}
.diff-in{position:relative;z-index:2;padding:108px 0;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.diff-tags{display:flex;flex-wrap:wrap;gap:10px;margin:20px 0 30px}
.dtag{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.18);border-radius:100px;padding:7px 15px;font-size:.77rem;font-weight:600;color:rgba(255,255,255,.82)}

/* Metrics row: symbol superscript + big number, all on one line */
.diff-nums{display:flex;gap:0;border:1px solid rgba(255,255,255,.12);border-radius:var(--r);overflow:hidden;margin-top:6px}
.dnum-box{flex:1;padding:22px 14px;text-align:center;position:relative}
.dnum-box:not(:last-child){border-right:1px solid rgba(255,255,255,.12)}
.dnum-row{display:flex;align-items:flex-start;justify-content:center;gap:2px;line-height:1;margin-bottom:7px}
.dnum-sym{font-size:1.4rem;font-weight:900;color:var(--a300);margin-top:2px}
.dnum-val{font-size:2.8rem;font-weight:900;color:var(--a300);line-height:1}
.dnum-lbl{font-size:.82rem;color:rgba(255,255,255,.7);line-height:1.4;font-weight:700}

/* visual side */
.diff-vis{position:relative}
.diff-main-img{border-radius:var(--rl);overflow:hidden;position:relative;box-shadow:var(--sh-dk)}
.diff-main-img img{width:100%;height:370px;object-fit:cover;object-position:center 20%;filter:brightness(.85) saturate(1.2);display:block}
.dim-ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(11,31,51,.88) 100%)}
.dim-cap{position:absolute;bottom:24px;left:24px;right:24px;color:#fff}
.dim-cap strong{display:block;font-size:1rem;font-weight:800;margin-bottom:3px}
.dim-cap span{font-size:.8rem;color:rgba(255,255,255,.72)}
.diff-sec-img{margin-top:14px;border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-dk);position:relative}
.diff-sec-img img{width:100%;height:160px;object-fit:cover;display:block;filter:brightness(.72) saturate(1.2)}
.dsi-ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(2,107,192,.88),rgba(11,31,51,.4));display:flex;align-items:center;padding:24px}
.dsi-ov blockquote{color:#fff;font-size:.9rem;font-weight:600;line-height:1.5;max-width:280px;font-style:italic}
.dsi-ov blockquote::before{content:'"';font-size:2.2rem;line-height:0;vertical-align:-.45em;color:var(--a300);margin-right:5px}
.diff-fbadge{position:absolute;top:-20px;right:-16px;background:rgba(255,255,255,.97);border-radius:15px;padding:14px 18px;box-shadow:var(--sh-dk);display:flex;align-items:center;gap:12px;animation:flt 3.6s ease-in-out infinite;z-index:10}
.dfb-icon{width:46px;height:46px;background:linear-gradient(135deg,var(--a300),var(--a400));border-radius:11px;display:flex;align-items:center;justify-content:center}
.dfb-icon svg{width:24px;height:24px;stroke:var(--p400);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.diff-fbadge strong{display:block;font-size:1.05rem;font-weight:900;color:var(--p400);line-height:1}
.diff-fbadge small{font-size:.7rem;color:var(--muted)}

/* ══ MÉTRICAS STRIP ══ */
.metrics-sec{background:var(--light)}
/* Numbers: symbol first (superscript), then big counter, all one line */
.met-grid{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh)}
.mcard{flex:1;background:var(--white);padding:42px 20px;text-align:center;position:relative;transition:all .3s}
.mcard:not(:last-child){border-right:1px solid var(--border)}
.mcard::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--a300),var(--p200));transform:scaleX(0);transition:transform .4s;transform-origin:left}
.mcard:hover{background:var(--light)}
.mcard:hover::before{transform:scaleX(1)}
.mnum-row{display:flex;align-items:flex-start;justify-content:center;gap:2px;line-height:1;margin-bottom:10px}
.mnum-sym{font-size:1.8rem;font-weight:900;line-height:1;margin-top:4px}
.mnum-val{font-size:4rem;font-weight:900;line-height:1}
.mlbl{font-size:1rem;font-weight:700;color:var(--muted)}

/* ══ PRECIOS ══ */
.pricing-sec{background:var(--white)}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:48px;overflow:visible;padding-top:16px}
.pcard{background:var(--white);border:1.5px solid var(--border);border-radius:var(--rl);padding:38px 30px;display:flex;flex-direction:column;gap:0;transition:all .3s;position:relative}
.pgrid .pcard{overflow:visible}
.pcard:hover{transform:translateY(-7px);box-shadow:var(--sh-lg)}
.pcard.feat{border-color:var(--p200);box-shadow:0 0 0 1px var(--p200),var(--sh-lg)}
.p-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--a300);color:var(--p400);border-radius:100px;padding:5px 20px;font-size:.74rem;font-weight:800;white-space:nowrap}
.p-icon{width:58px;height:58px;border-radius:15px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.p-icon svg{width:28px;height:28px;stroke:var(--p400);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.pcard h3{font-size:1.4rem;font-weight:900;color:var(--p400);margin-bottom:6px}
.p-desc{font-size:.85rem;color:var(--muted);margin-bottom:18px}
.p-price{display:flex;align-items:baseline;gap:4px;margin-bottom:22px}
.p-price strong{font-size:1.85rem;font-weight:900;color:var(--p400)}
.p-price span{font-size:.85rem;color:var(--muted)}
.p-feats{list-style:none;display:flex;flex-direction:column;flex:1;gap:10px;margin-bottom:24px}
.p-feats li{display:flex;align-items:center;gap:10px;font-size:.87rem;color:var(--muted)}
.pchk{width:22px;height:22px;background:rgba(29,205,175,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pchk svg{width:12px;height:12px;stroke:var(--a300);fill:none;stroke-width:2.8;stroke-linecap:round;stroke-linejoin:round}
/* NEW — feature already in lower plan shown as dim */
.p-feats li.inherited{opacity:.5}

/* ══ EQUIPO ══ */
.team-sec{background:var(--light)}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:48px}
.tcard{background:var(--white);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;transition:all .3s;text-align:center}
.tcard:hover{transform:translateY(-7px);box-shadow:var(--sh-lg)}
.tcard-photo{width:100%;height:480px;object-fit:cover;object-position:center top;display:block;filter:saturate(1.05)}
.tcard-body{padding:24px 24px 28px}
.tcard h3{font-size:1.1rem;font-weight:800;color:var(--p400);margin-bottom:4px}
.trole{display:block;font-size:.82rem;font-weight:700;color:var(--p200);margin-bottom:12px}
.tcard p{font-size:.86rem;color:var(--muted);line-height:1.68}

/* ══ CONTACTO ══ */
.contact-sec{position:relative;overflow:hidden;background:var(--p400)}
.contact-bg{position:absolute;inset:0;background:linear-gradient(128deg,#061018 0%,#184674 45%,#0a2236 100%),radial-gradient(circle at 80% 60%,rgba(29,205,175,.09),transparent 50%);background-size:cover,cover;background-position:center;filter:brightness(.88) saturate(1.08)}
.contact-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(11,31,51,.96),rgba(24,70,116,.86))}
.contact-in{position:relative;z-index:2;padding:108px 0;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.cinfo h2{color:#fff;margin-bottom:16px}
.cinfo>p{color:rgba(255,255,255,.72);margin-bottom:30px;line-height:1.78}
.cchecks{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:36px}
.cchecks li{display:flex;align-items:center;gap:13px;font-size:.93rem;color:rgba(255,255,255,.88)}
.cchk{width:26px;height:26px;background:var(--a300);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cchk svg{width:13px;height:13px;stroke:var(--p400);fill:none;stroke-width:2.8;stroke-linecap:round;stroke-linejoin:round}
/* Closing statement box */
.closing-box{background:linear-gradient(135deg,rgba(29,205,175,.15),rgba(2,107,192,.15));border:1px solid rgba(29,205,175,.32);border-radius:var(--r);padding:24px 28px}
.closing-box .cb-ey{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--a300);margin-bottom:8px;display:block}
.closing-box p{font-size:.95rem;color:rgba(255,255,255,.85);line-height:1.7;font-weight:500}
.closing-box strong{color:var(--a300)}
.cfcard{background:rgba(255,255,255,.97);border-radius:var(--rl);padding:38px;box-shadow:var(--sh-dk)}
.cfcard h3{font-size:1.35rem;font-weight:900;color:var(--p400);margin-bottom:24px}

/* ══ FOOTER ══ */
.footer{background:#040d14;border-top:1px solid rgba(255,255,255,.06);padding:68px 0 26px}
/* Mobile: vertical logo in footer */
.footer-logo-wrap{margin-bottom:4px}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:52px;margin-bottom:52px}
.fbrand p{color:rgba(255,255,255,.5);font-size:.84rem;line-height:1.8;margin-top:16px;max-width:265px}
.fsoc{display:flex;gap:10px;margin-top:18px}
.fsoc a{width:40px;height:40px;background:rgba(255,255,255,.07);border-radius:10px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);font-size:.82rem;font-weight:700;transition:all .22s}
.fsoc a:hover{background:var(--p200);color:#fff}
.fcol h4{color:rgba(255,255,255,.85);font-size:.84rem;font-weight:800;margin-bottom:16px;text-transform:uppercase;letter-spacing:.8px}
.fcol a{display:block;color:rgba(255,255,255,.5);font-size:.84rem;margin-bottom:11px;transition:color .2s}
.fcol a:hover{color:var(--a300)}
.fbot{border-top:1px solid rgba(255,255,255,.06);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.fbot span{font-size:.76rem;color:rgba(255,255,255,.32)}

/* ══ RESPONSIVE ══ */
@media(max-width:1024px){
  .scards,.pgrid{grid-template-columns:repeat(2,1fr)}
  .diff-in{grid-template-columns:1fr;gap:52px}
  .fgrid{grid-template-columns:1fr 1fr}
  .ben-slide{min-width:calc(50% - 10px)}
  .met-grid{flex-wrap:wrap}
  .mcard{flex:1 1 calc(50% - 1px)}
}
@media(max-width:768px){
  .sec{padding:80px 0}
  .hero-in{grid-template-columns:1fr;gap:48px;padding:80px 0 80px}
  .hform-wrap{display:none}
  /* Mobile: hide horizontal, show vertical logo */
  .logo-h{display:none}
  .logo-v{display:flex}
  .nav-links{position:fixed;inset:0;background:rgba(11,31,51,.98);backdrop-filter:blur(22px);flex-direction:column;gap:8px;padding:90px 28px 40px;display:none}
  .nav-links.open{display:flex;z-index:50}
  .nav-links a{font-size:1.1rem;padding:14px 18px;border-radius:12px}
  .ham{display:flex;z-index:60}
  .scards{grid-template-columns:repeat(2,1fr)}
  .prob-grid,.sol-inner,.valor-in,.diff-in,.contact-in{grid-template-columns:1fr}
  .sol-l{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .how-grid{grid-template-columns:1fr}
  .how-side{flex-direction:row;flex-wrap:wrap;padding:16px}
  .hbtn{flex:1;justify-content:center;min-width:130px;padding:11px}
  .how-content{min-height:0}
  .hpanel{position:relative;inset:auto;padding:28px 22px;transform:none!important;transition:opacity .25s}
  .hpanel:not(.act){display:none;opacity:0}
  .hp-bignum{font-size:3.8rem;top:12px;right:18px}
  .hpanel h3{font-size:1.2rem}
  .hpanel p{max-width:100%}
  .ben-slide{min-width:calc(100% - 0px)}
  .pgrid,.tgrid{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .diff-nums{flex-direction:column}
  .dnum-box:not(:last-child){border-right:none;border-bottom:1px solid rgba(255,255,255,.12)}
  .dw-kpis{grid-template-columns:repeat(2,1fr)}
  .hero-btns{flex-direction:column}
  .btn{justify-content:center;text-align:center}
  .fbot{flex-direction:column;text-align:center}
  .met-grid{flex-direction:column}
  .mcard:not(:last-child){border-right:none;border-bottom:1px solid var(--border)}
}
@media(max-width:480px){
  .scards{grid-template-columns:1fr 1fr}
  .t-hero{font-size:2rem}
  .t-sec{font-size:1.7rem}
  .how-flow{display:none}
}

/* Franja superior: layout Astra (contenedores) + reset raíz y nav */
body #primary,
body .site-main,
body .site,
body .ast-container{margin-top:0!important;padding-top:0!important}
html, body {
    margin-top: 0 !important;
    padding-top: 0 !important;
}
.nav {
    top: 0 !important;
}

/* Reset Forzado: Eliminar franja blanca fantasma de WP */
html,
html[lang],
body.wp-theme-astra {
    margin-top: 0 !important;
    padding-top: 0 !important;
    transform: none !important;
}

/* Eliminar separación blanca entre última sección y footer */
body #primary,
body .site-main,
body #content,
body .ast-article-single,
body .ast-container,
body .entry-content,
body .page-content,
body .hentry,
body article.page,
body .ast-article-post{margin-bottom:0!important;padding-bottom:0!important}

/* Cero margin/padding alrededor del footer */
footer.footer{margin-top:0!important;margin-bottom:0!important}

/* Cualquier wrapper entre la última section y el footer */
section.contact-sec{margin-bottom:0!important}

/* Evitar que el body background blanco sea visible entre secciones */
:root{--wp--custom--ast-default-block-bottom-padding:0px}

#main-nav.nav {
    top: 0 !important;
    margin-top: 0 !important;
}