/* === XFLOWD — base styles === */
:root{
  --teal:#2BA5A0;
  --teal-dark:#1F8F8A;
  --teal-soft:#E8F5F4;
  --navy:#0E2A3A;
  --navy-soft:#3D5566;
  --coral:#FF6B5C;
  --coral-dark:#E8503F;
  --bg:#FFFFFF;
  --bg-soft:#F6F9FA;
  --border:#E3E9EC;
  --text:#102A3A;
  --muted:#5A6E7B;
  --shadow:0 10px 40px rgba(14,42,58,.06);
  --radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.55;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--teal-dark)}
.container{max-width:1180px;margin:0 auto;padding:0 24px}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--border);
  transition:transform .35s ease;
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:74px;
}
.nav .logo{height:32px;width:auto;max-width:190px;object-fit:contain}
.nav ul{display:flex;gap:34px;list-style:none}
.nav ul a{color:var(--navy);font-weight:500;font-size:15px}
.nav ul a:hover{color:var(--teal)}
.nav .cta-row{display:flex;gap:12px;align-items:center}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 22px;border-radius:10px;font-weight:600;font-size:15px;
  border:0;cursor:pointer;transition:all .2s;
  white-space:nowrap;
}
.btn-primary{background:var(--coral);color:#fff}
.btn-primary:hover{background:var(--coral-dark);color:#fff;transform:translateY(-1px)}
.btn-secondary{background:var(--teal);color:#fff}
.btn-secondary:hover{background:var(--teal-dark);color:#fff}
.btn-ghost{background:transparent;color:var(--navy);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn-lg{padding:16px 28px;font-size:16px}

/* Hero */
.hero{
  padding:90px 0 80px;
  background:
    radial-gradient(900px 420px at 90% -10%, rgba(43,165,160,.12), transparent 60%),
    linear-gradient(180deg,#FAFCFC 0%,#FFFFFF 100%);
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.eyebrow{
  display:inline-block;padding:6px 14px;border-radius:999px;
  background:var(--teal-soft);color:var(--teal-dark);
  font-size:13px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;
  margin-bottom:22px;
}
h1{
  font-size:54px;line-height:1.08;letter-spacing:-1.2px;
  color:var(--navy);font-weight:800;margin-bottom:22px;
}
h1 .accent{color:var(--teal)}
.lead{font-size:19px;color:var(--muted);max-width:540px;margin-bottom:32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{display:flex;gap:24px;margin-top:30px;color:var(--muted);font-size:14px}
.hero-meta span{display:flex;align-items:center;gap:8px}
.hero-meta span::before{content:"✓";color:var(--teal);font-weight:700}

/* Hero card mockup */
.mockup{
  background:linear-gradient(160deg,#1F8F8A 0%, #2BA5A0 100%);
  border-radius:20px;padding:28px;color:#fff;
  box-shadow:0 30px 60px rgba(31,143,138,.28);
  position:relative;
}
.mockup-inner{background:rgba(255,255,255,.12);border-radius:14px;padding:18px;backdrop-filter:blur(10px)}
.mockup-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.18)}
.mockup-row:last-child{border-bottom:0}
.mockup-row .time{font-weight:700;font-size:14px;width:60px}
.mockup-row .name{flex:1;font-size:14px}
.mockup-row .tag{font-size:11px;background:rgba(255,255,255,.22);padding:3px 8px;border-radius:6px;font-weight:600}
.mockup h4{font-size:12px;font-weight:700;letter-spacing:1.2px;opacity:.85;margin-bottom:14px;text-transform:uppercase}
.mockup-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}
.stat-card{background:rgba(255,255,255,.14);border-radius:12px;padding:16px}
.stat-card .label{font-size:11px;opacity:.85;text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.stat-card .value{font-size:28px;font-weight:800;margin-top:6px}
.stat-card .delta{font-size:12px;opacity:.9;margin-top:2px}

/* Sections */
section{padding:90px 0}
.section-eyebrow{
  display:inline-block;color:var(--teal-dark);font-weight:700;
  font-size:13px;letter-spacing:.6px;text-transform:uppercase;margin-bottom:14px;
}
h2{
  font-size:40px;line-height:1.15;letter-spacing:-.7px;
  color:var(--navy);font-weight:800;margin-bottom:18px;
}
h3{font-size:22px;line-height:1.25;color:var(--navy);font-weight:700;margin-bottom:10px}
.section-lead{font-size:18px;color:var(--muted);max-width:680px;margin-bottom:50px}
.section-head-center{text-align:center;margin:0 auto 56px;max-width:760px}
.section-head-center .section-lead{margin:0 auto}

/* Pillars */
.bg-soft{background:var(--bg-soft)}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pillar{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:32px 28px;transition:transform .2s, box-shadow .2s;
}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pillar .num{
  width:38px;height:38px;border-radius:50%;
  background:var(--teal);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;margin-bottom:18px;
}
.pillar p{color:var(--muted);font-size:15px}

/* Solution cards (problem→solution alternating) */
.solution{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;margin-bottom:120px}
.solution:last-child{margin-bottom:0}
.solution.reverse .text{order:2}
.solution.reverse .visual{order:1}
.solution .problem-tag{
  display:inline-block;background:#FFF1EE;color:var(--coral-dark);
  padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;margin-bottom:16px;
}
.solution h2{font-size:34px;margin-bottom:18px}
.solution p{color:var(--muted);font-size:17px;margin-bottom:20px}
.solution ul{list-style:none;margin-bottom:24px}
.solution ul li{padding:8px 0 8px 30px;position:relative;color:var(--text)}
.solution ul li::before{
  content:"";position:absolute;left:0;top:14px;width:18px;height:18px;
  background:var(--teal-soft);border-radius:50%;
}
.solution ul li::after{
  content:"";position:absolute;left:5px;top:20px;width:8px;height:4px;
  border-left:2px solid var(--teal);border-bottom:2px solid var(--teal);
  transform:rotate(-45deg);
}
.visual-card{
  background:#fff;border:1px solid var(--border);border-radius:18px;
  padding:24px;box-shadow:var(--shadow);
}
.visual-card .v-head{display:flex;justify-content:space-between;margin-bottom:16px;font-size:13px;color:var(--muted);font-weight:600}
.visual-card .bar{height:8px;background:var(--bg-soft);border-radius:4px;overflow:hidden;margin:8px 0}
.visual-card .bar > div{height:100%;background:var(--teal);border-radius:4px}

/* Pricing structure (home) — radial layout */
.pricing-vis{
  background:linear-gradient(180deg, #FFFFFF 0%, #F4FAFA 100%);
  border:1px solid var(--border);border-radius:24px;
  padding:50px 30px;text-align:center;
}
.radial-wrap{position:relative;max-width:960px;margin:0 auto}
.radial-lines{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;z-index:1;
}
.radial-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto auto;
  gap:22px 30px;
  position:relative;z-index:2;
  align-items:center;
}
.radial-card{
  background:#fff;border:1px solid var(--border);border-radius:12px;
  padding:14px 16px;box-shadow:0 6px 20px rgba(14,42,58,.06);
  border-top:3px solid var(--teal);
  text-align:left;transition:transform .2s,box-shadow .2s;
}
.radial-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(14,42,58,.1)}
.radial-card.c1{border-top-color:#2BA5A0}
.radial-card.c2{border-top-color:#7C5CFF}
.radial-card.c3{border-top-color:#3B82F6}
.radial-card.c4{border-top-color:#FF6B5C}
.radial-card.c5{border-top-color:#22C55E}
.radial-card.c6{border-top-color:#0EA5E9}
.radial-card.c7{border-top-color:#EC4899}
.radial-card.c8{border-top-color:#F39247}
.rc-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}
.rc-name{font-weight:700;color:var(--navy);font-size:14px;line-height:1.25}
.rc-price{color:var(--coral-dark);font-weight:800;font-size:13px;flex-shrink:0}
.rc-desc{color:var(--muted);font-size:12px;line-height:1.35}

.radial-center{display:flex;justify-content:center;align-items:center}
.hex-shape{
  width:200px;height:220px;
  background:linear-gradient(160deg,#1F8F8A 0%, #2BA5A0 100%);
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  box-shadow:0 14px 40px rgba(31,143,138,.35);
}
.hex-inner{text-align:center;padding:10px}
.hex-label{font-size:11px;letter-spacing:2px;opacity:.85;margin-bottom:2px;font-weight:600}
.hex-name{font-size:36px;font-weight:900;letter-spacing:1px;line-height:1}
.hex-sub{font-size:10px;letter-spacing:1.2px;opacity:.9;margin-top:10px;font-weight:600}
.hex-pcts{font-size:12px;letter-spacing:1px;margin-top:4px;font-weight:700}

/* Plans summary cards (home) */
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.plan-card{
  background:#fff;border:1px solid var(--border);border-radius:18px;
  padding:32px;transition:all .2s;display:flex;flex-direction:column;
}
.plan-card:hover{border-color:var(--teal);transform:translateY(-4px);box-shadow:var(--shadow)}
.plan-card.featured{border:2px solid var(--teal);position:relative}
.plan-card.featured::before{
  content:"Más popular";position:absolute;top:-12px;right:24px;
  background:var(--teal);color:#fff;padding:5px 12px;border-radius:999px;
  font-size:12px;font-weight:700;
}
.plan-card .plan-name{font-size:13px;color:var(--teal-dark);font-weight:700;letter-spacing:1px;text-transform:uppercase}
.plan-card .plan-title{font-size:24px;font-weight:800;color:var(--navy);margin:8px 0 12px}
.plan-card .plan-price{font-size:36px;font-weight:900;color:var(--navy);margin:14px 0 2px}
.plan-card .plan-price small{font-size:15px;font-weight:600;color:var(--muted)}
.plan-card .plan-min{font-size:13px;color:var(--muted);margin-bottom:20px}
.plan-card .plan-desc{color:var(--muted);font-size:15px;margin-bottom:20px;flex:1}
.plan-card .btn{width:100%}

/* CTA banner */
.cta-banner{
  background:linear-gradient(135deg,#1F8F8A 0%, #2BA5A0 100%);
  color:#fff;border-radius:24px;padding:60px 50px;
  display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap;
}
.cta-banner h2{color:#fff;margin-bottom:8px;font-size:32px}
.cta-banner p{opacity:.9;font-size:17px}

/* Contact form */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-info p{color:var(--muted);margin-bottom:20px;font-size:16px}
.contact-info .info-row{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px}
.contact-info .info-row .icon{
  width:40px;height:40px;border-radius:10px;background:var(--teal-soft);
  color:var(--teal-dark);display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-info .info-row strong{display:block;color:var(--navy);font-size:15px;margin-bottom:2px}
.contact-info .info-row span{color:var(--muted);font-size:15px}
.form{background:#fff;border:1px solid var(--border);border-radius:18px;padding:36px;box-shadow:var(--shadow)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form label{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:6px}
.form input,.form select,.form textarea{
  width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:10px;
  font-family:inherit;font-size:15px;color:var(--text);background:#fff;
  transition:border-color .15s;
}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--teal)}
.form textarea{min-height:120px;resize:vertical}
.form .field{margin-bottom:14px}
.form .btn{width:100%;margin-top:8px}

/* Footer */
.footer{background:#0A1F2C;color:#C7D5DC;padding:70px 0 30px;font-size:14px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
.footer h5{color:#fff;font-size:14px;font-weight:700;margin-bottom:18px;text-transform:uppercase;letter-spacing:.6px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:10px}
.footer a{color:#C7D5DC}
.footer a:hover{color:var(--teal)}
.footer .brand p{margin-top:18px;color:#94A6AF;line-height:1.6}
.footer-bottom{border-top:1px solid #1A3140;padding-top:24px;display:flex;justify-content:space-between;color:#7E8F98;font-size:13px;flex-wrap:wrap;gap:12px}

/* WhatsApp floating */
.wa-float{
  position:fixed;bottom:24px;right:24px;z-index:100;
  display:flex;align-items:center;gap:12px;
  background:#25D366;color:#fff;
  padding:14px 20px 14px 14px;border-radius:999px;
  box-shadow:0 12px 30px rgba(37,211,102,.4);
  font-weight:600;font-size:15px;
  transition:transform .2s,box-shadow .2s;
}
.wa-float:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(37,211,102,.5);color:#fff}
.wa-float .wa-icon{
  width:32px;height:32px;background:#fff;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.wa-float svg{width:20px;height:20px;fill:#25D366}

/* === planes.html specifics === */
.page-hero{
  padding:80px 0 50px;
  background:linear-gradient(180deg,#F4FAFA 0%, #FFFFFF 100%);
  text-align:center;
}
.page-hero h1{font-size:44px;margin-bottom:16px}
.page-hero p{font-size:18px;color:var(--muted);max-width:640px;margin:0 auto}

.tabs{display:flex;justify-content:center;gap:12px;margin:40px 0 0}
.tab{
  padding:12px 24px;border-radius:999px;border:1px solid var(--border);
  background:#fff;cursor:pointer;font-weight:600;font-size:15px;color:var(--navy);
  transition:all .2s;
}
.tab.active{background:var(--teal);color:#fff;border-color:var(--teal)}

.plan-detail{
  background:#fff;border:1px solid var(--border);border-radius:20px;
  padding:42px;margin-bottom:24px;display:none;
}
.plan-detail.active{display:block}
.plan-detail-head{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:start;margin-bottom:30px}
.plan-detail .badge{
  display:inline-block;background:var(--navy);color:#fff;
  padding:6px 14px;border-radius:8px;font-size:12px;font-weight:700;letter-spacing:.6px;
  margin-bottom:14px;
}
.plan-detail h2{font-size:36px;margin-bottom:8px}
.plan-detail .slogan{font-size:18px;color:var(--teal-dark);font-weight:600;margin-bottom:14px}
.plan-detail .desc{color:var(--muted);font-size:16px}
.plan-price-box{
  background:linear-gradient(135deg,#1F8F8A,#2BA5A0);color:#fff;
  border-radius:16px;padding:28px;text-align:center;
}
.plan-price-box .pct{font-size:48px;font-weight:900;line-height:1}
.plan-price-box .of{font-size:16px;font-weight:600;margin-top:4px}
.plan-price-box .min{font-size:13px;opacity:.9;margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.2)}

.includes{border-top:1px solid var(--border);padding-top:28px}
.includes h4{font-size:14px;color:var(--navy);font-weight:700;letter-spacing:.6px;text-transform:uppercase;margin-bottom:18px}
.includes-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.includes-grid li{list-style:none;padding:6px 0 6px 28px;position:relative;font-size:15px;color:var(--text)}
.includes-grid li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:800}

/* Modules grid */
.modules-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.mod-card{
  background:#fff;border:1px solid var(--border);border-radius:14px;padding:24px;
  border-top:4px solid var(--teal);
}
.mod-card.c1{border-top-color:#2BA5A0}
.mod-card.c2{border-top-color:#FF6B5C}
.mod-card.c3{border-top-color:#7C5CFF}
.mod-card.c4{border-top-color:#F39247}
.mod-card.c5{border-top-color:#22C55E}
.mod-card.c6{border-top-color:#3B82F6}
.mod-card.c7{border-top-color:#EC4899}
.mod-card.c8{border-top-color:#0EA5E9}
.mod-card .head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:6px}
.mod-card .name{font-size:20px;font-weight:800;color:var(--navy)}
.mod-card .tag{
  background:var(--navy);color:#fff;padding:5px 12px;border-radius:999px;
  font-weight:700;font-size:13px;flex-shrink:0;
}
.mod-card .slogan{color:var(--teal-dark);font-weight:600;font-size:14px;margin-bottom:8px}
.mod-card .desc{color:var(--muted);font-size:14px;margin-bottom:14px}
.mod-card ul{list-style:none}
.mod-card ul li{padding:4px 0 4px 22px;position:relative;font-size:14px;color:var(--text)}
.mod-card ul li::before{content:"•";position:absolute;left:6px;color:var(--teal);font-weight:800}

/* Simulator */
.simulator{
  background:linear-gradient(180deg,#0E2A3A 0%, #133A4E 100%);
  color:#fff;border-radius:24px;padding:36px;
}
.simulator h2{color:#fff;font-size:28px;margin-bottom:6px}
.simulator > p{color:#A4BFCE;font-size:15px;margin-bottom:20px;max-width:640px}
.sim-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px}
.sim-form .field{margin-bottom:14px}
.sim-form label{display:block;font-size:14px;color:#C7D5DC;margin-bottom:8px;font-weight:600}
.sim-form input[type="number"],.sim-form input[type="text"],.sim-form select{
  width:100%;padding:14px 16px;border-radius:10px;border:1px solid #2A4A5C;
  background:#0A1F2C;color:#fff;font-size:16px;font-family:inherit;
}
.sim-form input:focus,.sim-form select:focus{outline:none;border-color:var(--teal)}
.base-options{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.base-opt{
  cursor:pointer;border:1px solid #2A4A5C;border-radius:12px;padding:14px 12px;
  text-align:center;background:#0A1F2C;transition:all .2s;
}
.base-opt:hover{border-color:var(--teal)}
.base-opt.selected{border-color:var(--teal);background:rgba(43,165,160,.15)}
.base-opt .b-name{font-weight:700;font-size:14px;color:#fff;margin-bottom:4px}
.base-opt .b-pct{font-size:12px;color:var(--teal)}

.modules-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:start}
.mod-block{display:flex;flex-direction:column}
.toggle-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 10px 10px 12px;background:#0A1F2C;border:1px solid #2A4A5C;
  border-radius:10px;cursor:pointer;transition:all .2s;gap:8px;
}
.toggle-row:hover{border-color:var(--teal)}
.toggle-row.active{border-color:var(--teal);background:rgba(43,165,160,.12)}
.mod-block.expanded .toggle-row{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent}
.toggle-row .info{display:flex;align-items:center;gap:10px;min-width:0;flex:1}
.toggle-row .check{
  width:20px;height:20px;border-radius:6px;border:2px solid #2A4A5C;
  display:flex;align-items:center;justify-content:center;font-size:13px;color:transparent;flex-shrink:0;
}
.toggle-row.active .check{background:var(--teal);border-color:var(--teal);color:#fff}
.toggle-row .m-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.toggle-row .m-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.toggle-row .m-pct{color:var(--teal);font-weight:700;font-size:12px}
.toggle-row .m-info{
  background:transparent;border:0;color:#7E9AAA;cursor:pointer;
  width:24px;height:24px;border-radius:6px;font-size:14px;
  display:flex;align-items:center;justify-content:center;transition:all .15s;
}
.toggle-row .m-info:hover{background:rgba(43,165,160,.18);color:var(--teal)}
.mod-block.expanded .m-info{transform:rotate(180deg);color:var(--teal)}

.mod-detail{
  display:none;
  background:#0A1F2C;border:1px solid var(--teal);
  border-top:0;
  border-radius:0 0 10px 10px;
  padding:14px 14px 14px 42px;
  margin-top:-1px;
}
.mod-block.expanded .mod-detail{display:block}
.mod-detail .md-slogan{
  color:var(--teal);font-weight:700;font-size:13px;
  margin-bottom:8px;
}
.mod-detail ul{list-style:none;padding:0;margin:0}
.mod-detail ul li{
  position:relative;padding:3px 0 3px 14px;
  font-size:12.5px;color:#C7D5DC;line-height:1.45;
}
.mod-detail ul li::before{
  content:"";position:absolute;left:0;top:11px;
  width:5px;height:5px;border-radius:50%;background:var(--teal);
}

.sim-result{
  background:#fff;color:var(--navy);border-radius:18px;padding:24px;
  position:sticky;top:16px;
}
.sim-result h3{font-size:17px;color:var(--navy);margin-bottom:14px}
.result-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--border);font-size:14px}
.result-row strong{font-weight:700}
.result-total{
  margin-top:14px;padding:18px;background:linear-gradient(135deg,#1F8F8A,#2BA5A0);
  color:#fff;border-radius:14px;text-align:center;
}
.result-total .label{font-size:12px;letter-spacing:.6px;text-transform:uppercase;opacity:.9}
.result-total .amount{font-size:36px;font-weight:900;margin:4px 0 2px}
.result-total .per{font-size:13px;opacity:.9}
.result-note{font-size:12px;color:var(--muted);margin-top:12px;text-align:center;line-height:1.5}

/* === FAQ === */
.faq-wrap{max-width:860px;margin:0 auto}
.faq-item{
  background:#fff;border:1px solid var(--border);border-radius:14px;
  margin-bottom:12px;overflow:hidden;
  transition:border-color .2s, box-shadow .2s;
}
.faq-item:hover{border-color:#BFD4D8}
.faq-item[open]{border-color:var(--teal);box-shadow:var(--shadow)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:22px 26px;cursor:pointer;list-style:none;
  font-weight:600;color:var(--navy);font-size:17px;line-height:1.4;
  transition:color .15s;
}
.faq-q::-webkit-details-marker{display:none}
.faq-q:hover{color:var(--teal-dark)}
.faq-icon{
  flex-shrink:0;width:32px;height:32px;border-radius:50%;
  background:var(--teal-soft);color:var(--teal-dark);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:500;line-height:1;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), background .2s, color .2s;
}
.faq-item[open] .faq-icon{
  background:var(--teal);color:#fff;transform:rotate(45deg);
}
.faq-a{
  padding:2px 26px 26px 26px;color:var(--muted);font-size:16px;line-height:1.65;
  animation:faqIn .25s ease;
}
.faq-a p{margin-bottom:10px}
.faq-a p:last-child{margin-bottom:0}
.faq-a strong{color:var(--navy);font-weight:600}
.faq-a ul{margin:8px 0 0;padding:0;list-style:none}
.faq-a ul li{padding:4px 0 4px 18px;position:relative}
.faq-a ul li::before{content:"•";position:absolute;left:4px;color:var(--teal);font-weight:800}
@keyframes faqIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

.faq-home-cta{display:flex;justify-content:center;margin-top:36px}

/* FAQ dedicated page */
.faq-page-hero{
  padding:70px 0 30px;
  background:linear-gradient(180deg,#F4FAFA 0%, #FFFFFF 100%);
  text-align:center;
}
.faq-page-hero h1{font-size:46px;margin-bottom:14px}
.faq-page-hero p{font-size:18px;color:var(--muted);max-width:560px;margin:0 auto}

.faq-cat-nav{
  position:sticky;top:74px;z-index:30;
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--border);
  padding:14px 0;
}
.faq-cat-scroll{
  display:flex;gap:8px;flex-wrap:wrap;justify-content:center;
}
.faq-cat-pill{
  padding:9px 16px;border-radius:999px;
  background:#fff;border:1px solid var(--border);
  color:var(--navy);font-weight:600;font-size:14px;
  transition:all .15s;
  white-space:nowrap;
}
.faq-cat-pill:hover{border-color:var(--teal);color:var(--teal-dark);background:var(--teal-soft)}

.faq-section{padding:60px 0 0;scroll-margin-top:170px}
.faq-section:last-of-type{padding-bottom:40px}
.faq-section-head{
  display:flex;align-items:center;gap:16px;margin-bottom:28px;
}
.faq-section-num{
  width:40px;height:40px;border-radius:12px;
  background:var(--teal-soft);color:var(--teal-dark);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:16px;flex-shrink:0;
}
.faq-section h2{font-size:28px;margin:0;letter-spacing:-.3px}

.faq-bottom-cta{
  margin-top:72px;padding:42px 36px;
  background:linear-gradient(135deg,#F4FAFA 0%, #E8F5F4 100%);
  border:1px solid var(--border);border-radius:20px;
  display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;
}
.faq-bottom-cta h3{font-size:22px;color:var(--navy);margin-bottom:6px}
.faq-bottom-cta p{color:var(--muted);font-size:15px;margin:0}

/* ===== HAMBURGER BUTTON ===== */
.hamburger{
  display:none;
  flex-direction:column;justify-content:center;gap:5px;
  width:44px;height:44px;cursor:pointer;
  border:none;background:none;border-radius:10px;
  transition:background .15s;flex-shrink:0;padding:10px;
}
.hamburger:hover{background:var(--bg-soft)}
.hamburger span{
  display:block;width:22px;height:2px;
  background:var(--navy);border-radius:2px;
  transition:all .3s ease;transform-origin:center;
}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== MOBILE NAV DRAWER ===== */
.mobile-nav-overlay{
  display:none;position:fixed;
  inset:0;top:74px;
  background:rgba(10,31,44,0.32);
  z-index:48;
}
.mobile-nav-overlay.open{display:block}

.mobile-nav-drawer{
  display:none;position:fixed;
  top:74px;left:0;right:0;
  background:#fff;z-index:49;
  padding:12px 16px 24px;
  border-bottom:1px solid var(--border);
  box-shadow:0 16px 40px rgba(14,42,58,.16);
}
.mobile-nav-drawer.open{display:block}
.mobile-nav-drawer ul{list-style:none;padding:0;margin:0 0 14px}
.mobile-nav-drawer ul li a{
  display:block;padding:12px 14px;border-radius:10px;
  color:var(--navy);font-weight:600;font-size:16px;
  transition:background .15s,color .15s;
}
.mobile-nav-drawer ul li a:hover,
.mobile-nav-drawer ul li a:focus{background:var(--teal-soft);color:var(--teal-dark)}
.mob-cta{width:100%;justify-content:center}

/* ===== RESPONSIVE — 920px ===== */
@media (max-width:920px){
  /* Header: show hamburger, hide desktop nav + CTA */
  .hamburger{display:flex}
  .nav ul{display:none}
  .cta-row{display:none}
  .nav .logo{height:26px;max-width:150px}
  .mob-cta{padding:10px 16px;font-size:14px}

  /* Typography */
  h1{font-size:38px}
  h2{font-size:30px}

  /* Layout */
  .hero{padding:60px 0 40px}
  section{padding:60px 0}
  .hero-grid,.contact-grid,.solution,.solution.reverse,
  .plan-detail-head,.sim-grid{grid-template-columns:1fr;gap:36px}
  .solution.reverse .text{order:1}
  .solution.reverse .visual{order:2}
  .pillars,.plans-grid,.modules-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cta-banner{padding:36px 28px;flex-direction:column;text-align:center}
  .form .row{grid-template-columns:1fr}

  /* Plans — includes list: 1 col on mobile */
  .includes-grid{grid-template-columns:1fr}

  /* Simulator: result panel handled per-page on mobile */
  .sim-result{position:static;top:auto}

  /* Pricing radial */
  .pricing-vis{padding:36px 20px}
  .radial-lines{display:none}
  .radial-grid{grid-template-columns:1fr 1fr;gap:12px}
  .radial-center{grid-column:1 / -1;order:-1;margin-bottom:8px}
  .hex-shape{width:180px;height:200px}
  .hex-name{font-size:32px}

  /* Simulator form */
  .simulator{padding:30px 24px}
  .base-options{grid-template-columns:1fr}
  .modules-toggle{grid-template-columns:1fr}

  /* WhatsApp: icon only */
  .wa-float{padding:12px;border-radius:50%}
  .wa-float .wa-text{display:none}

  /* FAQ: mobile adjustments */
  .faq-q{padding:18px 20px;font-size:16px;gap:14px}
  .faq-a{padding:2px 20px 22px 20px;font-size:15px}
  .faq-page-hero{padding:50px 0 20px}
  .faq-page-hero h1{font-size:32px}
  .faq-page-hero p{font-size:16px}
  .faq-section h2{font-size:22px}
  .faq-section-num{width:34px;height:34px;font-size:14px}
  /* Fix: cat nav must stick below the sticky header, not overlap it */
  .faq-cat-nav{top:74px;padding:10px 0}
  .faq-cat-scroll{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px}
  .faq-cat-scroll::-webkit-scrollbar{display:none}
  .faq-cat-pill{flex-shrink:0;padding:8px 14px;font-size:13px}
  .faq-bottom-cta{padding:28px 22px;flex-direction:column;text-align:center}
}

/* ===== RESPONSIVE — 600px (pantallas muy pequeñas) ===== */
@media (max-width:600px){
  .nav .logo{height:24px;max-width:128px}

  h1{font-size:28px;letter-spacing:-.8px}
  h2{font-size:22px}
  .hero{padding:48px 0 32px}
  section{padding:48px 0}

  /* Footer: 1 columna en móvil pequeño */
  .footer-grid{grid-template-columns:1fr}

  /* Hero lead text */
  .lead{font-size:16px}

  /* CTA banner */
  .cta-banner{padding:28px 18px}
  .cta-banner h2{font-size:20px}
  .cta-banner p{font-size:15px}

  /* Plans page */
  .page-hero h1{font-size:26px}
  .page-hero p{font-size:16px}
  .plan-detail{padding:24px 18px}
  .plan-detail h2{font-size:24px}
  .plan-price-box .pct{font-size:38px}
  .tabs{gap:8px}
  .tab{padding:10px 16px;font-size:14px}

  /* Simulator */
  .simulator{padding:22px 16px}
  .sim-result{padding:24px 18px}
  .result-total .amount{font-size:32px}
  .base-opt{padding:12px 10px}

  /* FAQ */
  .faq-page-hero{padding:40px 0 14px}
  .faq-page-hero h1{font-size:24px}
  .faq-page-hero p{font-size:14px}
  .faq-q{padding:16px 16px;font-size:15px}
  .faq-a{padding:2px 16px 20px 16px;font-size:14px}
  .faq-bottom-cta{padding:20px 16px}
  .faq-bottom-cta h3{font-size:18px}
  .faq-section{padding:36px 0 0}

  /* Contact */
  .form{padding:22px 18px}

  /* Comparativa */
  .cmp-hero h1{font-size:26px !important}
}
