@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800;900&display=swap');

/* ===== RESET & VARIABLES ===== */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --orange:#f56d0e;
  --orange-light:#ff8c35;
  --orange-glow:rgba(245,109,14,0.25);
  --orange-soft:rgba(245,109,14,0.08);
  --orange-mid:rgba(245,109,14,0.15);
  --charcoal:#414244;
  --charcoal-mid:#5a5d60;
  --charcoal-light:#8a8d91;
  --bg-white:#ffffff;
  --bg-light:#f8f8f9;
  --bg-section:#f2f3f5;
  --border:#e8e9ec;
  --border-strong:#d0d2d6;
  --text-dark:#1a1b1e;
  --text-body:#414244;
  --text-muted:#6b6e73;
  --cyan:#0ea5c9;
  --cyan-text:#0780a0;
  --green:#10b981;
  --green-text:#0a8f61;
  --red:#ef4444;
  --white:#fff;
  --hero-dark:#0f153a;
  --hero-mid:#080c21;
}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg-white);color:var(--text-dark);overflow-x:hidden;line-height:1.6}

/* ===== NAVBAR ===== */
nav{position:fixed;top:0;width:100%;z-index:1000;padding:16px 48px;display:flex;justify-content:space-between;align-items:center;background:rgba(255,255,255,0.95);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);box-shadow:0 2px 20px rgba(0,0,0,0.06)}
.nav-logo img{height:32px}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{color:var(--charcoal-mid);text-decoration:none;font-size:14px;font-weight:500;transition:color .3s}
.nav-links a:hover{color:var(--orange)}
.nav-cta{background:var(--orange)!important;color:#fff!important;padding:10px 28px;border-radius:50px;font-weight:700!important;font-size:14px;transition:all .3s!important}
.nav-cta:hover{background:var(--orange-light)!important;transform:translateY(-2px);box-shadow:0 8px 30px var(--orange-glow)!important}

/* Dropdown */
.nav-dropdown{position:relative}
.nav-dropdown>a{display:flex;align-items:center;gap:4px}
.nav-dropdown>a::after{content:'';border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--charcoal-light);transition:transform .3s}
.nav-dropdown:hover>a::after{transform:rotate(180deg)}
.dropdown-menu{position:absolute;top:calc(100% + 12px);left:-10px;background:#fff;backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:12px;padding:8px 0;min-width:240px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .3s;box-shadow:0 12px 40px rgba(0,0,0,0.12)}
.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu a{display:block;padding:10px 20px;font-size:13px;color:var(--text-muted);white-space:nowrap}
.dropdown-menu a:hover{background:var(--orange-soft);color:var(--orange)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:1002}
.hamburger span{width:24px;height:2px;background:var(--charcoal);transition:all .3s;border-radius:2px}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile menu */
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(255,255,255,0.98);z-index:1001;flex-direction:column;padding:32px;overflow-y:auto}
.mobile-overlay.active{display:flex}
.mobile-close{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.mobile-close img{height:28px}
.mobile-close-btn{width:44px;height:44px;border-radius:12px;background:var(--bg-section);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s}
.mobile-close-btn:hover{background:var(--orange-soft);border-color:var(--orange-mid)}
.mobile-close-btn svg{width:20px;height:20px;color:var(--charcoal)}
.mobile-overlay a{color:var(--charcoal-mid);text-decoration:none;font-size:17px;font-weight:500;padding:14px 0;border-bottom:1px solid var(--border);transition:color .3s;display:block}
.mobile-overlay a:hover{color:var(--orange)}
.mobile-overlay .mobile-sub{padding-left:20px}
.mobile-overlay .mobile-sub a{font-size:15px;color:var(--charcoal-light)}
.mobile-overlay .mobile-cta{display:block;margin-top:24px;background:var(--orange);color:#fff;padding:16px 32px;border-radius:50px;font-weight:700;text-align:center;font-size:16px;border:none}

/* ===== BACK TO TOP ===== */
.back-top{position:fixed;bottom:166px;right:43px;width:38px;height:38px;border-radius:50%;background:var(--orange);color:#fff;border:none;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:999;box-shadow:0 4px 16px var(--orange-glow);transition:all .3s;opacity:0.85}
.back-top:hover{background:var(--orange-light);transform:translateY(-3px);box-shadow:0 8px 30px var(--orange-glow);opacity:1}
.back-top svg{width:18px;height:18px}
.back-top.show{display:flex}

/* ===== WHATSAPP FLOAT ===== */
.wa-float{position:fixed;bottom:32px;right:29px;z-index:999;display:flex;align-items:center;flex-direction:row-reverse;gap:0}
.wa-btn{width:66px;height:66px;border-radius:50%;background:#25d366;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px rgba(37,211,102,0.45);transition:all .3s;text-decoration:none;position:relative;flex-shrink:0}
.wa-btn:hover{background:#20bc5a;transform:scale(1.08);box-shadow:0 8px 32px rgba(37,211,102,0.55)}
.wa-btn svg{width:34px;height:34px}
.wa-pulse{position:absolute;inset:2px;border-radius:50%;border:2px solid rgba(37,211,102,0.45);animation:waPulse 2.5s ease-out infinite}
.wa-pulse2{position:absolute;inset:2px;border-radius:50%;border:2px solid rgba(37,211,102,0.25);animation:waPulse 2.5s ease-out infinite .8s}
@keyframes waPulse{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.5);opacity:0}}
.wa-tooltip{background:#1a1b1e;color:#fff;font-size:13px;font-weight:600;padding:8px 16px;border-radius:10px;white-space:nowrap;pointer-events:none;opacity:0;transform:translateX(8px);transition:all .25s;font-family:'Plus Jakarta Sans',sans-serif;box-shadow:0 4px 16px rgba(0,0,0,0.2);margin-right:14px;position:relative}
.wa-tooltip::after{content:'';position:absolute;right:-6px;top:50%;transform:translateY(-50%);border-top:6px solid transparent;border-bottom:6px solid transparent;border-left:6px solid #1a1b1e}
.wa-float:hover .wa-tooltip{opacity:1;transform:translateX(0)}
@media(max-width:1200px){.wa-float{bottom:24px;right:20px}.back-top{bottom:154px;right:29px;width:34px;height:34px}.back-top svg{width:16px;height:16px}.wa-btn{width:58px;height:58px}.wa-btn svg{width:30px;height:30px}.wa-tooltip{display:none}}

/* ===== COMMON ===== */
.highlight{background:linear-gradient(135deg,var(--orange),var(--orange-light),#ffaa40);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.btn-primary{background:linear-gradient(135deg,var(--orange),var(--orange-light));color:#fff!important;padding:16px 38px;border-radius:60px;font-weight:700;font-size:15px;text-decoration:none;transition:all .3s;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:10px;box-shadow:0 4px 25px var(--orange-glow);-webkit-text-fill-color:#fff}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(245,109,14,0.4)}
.btn-primary svg{transition:transform .3s}
.btn-primary:hover svg{transform:translateX(3px)}
.btn-secondary{background:rgba(65,66,68,0.06);color:var(--charcoal);padding:16px 38px;border-radius:60px;font-weight:600;font-size:15px;text-decoration:none;border:1.5px solid var(--border-strong);transition:all .3s;display:inline-flex;align-items:center;gap:10px}
.btn-secondary:hover{border-color:var(--orange);background:var(--orange-soft);color:var(--orange)}

/* ===== HERO ===== */
/* Hero retains dark background for impact – brand identity */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:140px 40px 80px;overflow:hidden;background:var(--hero-dark)}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}
.orb-1{width:700px;height:700px;background:radial-gradient(circle,rgba(245,109,14,0.2),transparent 70%);top:-250px;right:-150px;animation:fl 10s ease-in-out infinite}
.orb-2{width:500px;height:500px;background:radial-gradient(circle,rgba(8,12,33,0.8),transparent 70%);bottom:-150px;left:-100px;animation:fl 12s ease-in-out infinite reverse}
.orb-3{width:300px;height:300px;background:radial-gradient(circle,rgba(245,109,14,0.08),transparent 70%);top:40%;left:50%;animation:fl 8s ease-in-out infinite 2s}
@keyframes fl{0%,100%{transform:translate(0,0) scale(1);opacity:.5}50%{transform:translate(30px,-20px) scale(1.1);opacity:.8}}
.grid-pattern{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.04) 1px,transparent 1px);background-size:70px 70px;mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%)}
.speed-lines{position:absolute;inset:0;overflow:hidden}
.speed-line{position:absolute;height:2px;background:linear-gradient(90deg,transparent,rgba(245,109,14,0.5),rgba(255,140,53,0.3),transparent);animation:sl 4s linear infinite;border-radius:2px;box-shadow:0 0 8px rgba(245,109,14,0.2)}
.speed-line:nth-child(1){top:20%;width:350px;left:-350px}
.speed-line:nth-child(2){top:45%;width:250px;left:-250px;animation-delay:1.5s}
.speed-line:nth-child(3){top:70%;width:400px;left:-400px;animation-delay:3s}
.speed-line:nth-child(4){top:35%;width:300px;left:-300px;animation-delay:.8s}
.speed-line:nth-child(5){top:85%;width:220px;left:-220px;animation-delay:2.2s}
@keyframes sl{0%{transform:translateX(0)}100%{transform:translateX(calc(100vw + 400px))}}
.hero-content{position:relative;z-index:2;max-width:880px;text-align:center}
.hero-badge{display:inline-flex;align-items:center;gap:10px;padding:8px 22px;border-radius:50px;background:rgba(245,109,14,0.1);border:1px solid rgba(245,109,14,0.3);font-size:13px;color:var(--orange);font-weight:600;margin-bottom:32px;animation:fiD .8s ease}
.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--orange);animation:pd 2s infinite;box-shadow:0 0 8px var(--orange-glow)}
@keyframes pd{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.hero h1{font-size:clamp(34px,5.5vw,62px);font-weight:900;line-height:1.08;margin-bottom:24px;letter-spacing:-2px;color:#fff;animation:fiU .8s ease .2s both}
.hero-sub{font-size:clamp(15px,1.8vw,19px);color:rgba(255,255,255,0.7);max-width:680px;margin:0 auto 44px;line-height:1.75;animation:fiU .8s ease .4s both}
.hero-sub strong{color:#fff;font-weight:600}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;animation:fiU .8s ease .6s both}
.hero-stats{display:flex;gap:1px;justify-content:center;margin-top:72px;background:rgba(255,255,255,0.06);border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,0.08);animation:fiU .8s ease .8s both}
.stat{flex:1;text-align:center;padding:28px 32px;position:relative;transition:background .3s}
.stat:hover{background:rgba(245,109,14,0.05)}
.stat:not(:last-child)::after{content:'';position:absolute;right:0;top:20%;height:60%;width:1px;background:rgba(255,255,255,0.08)}
.stat-value{font-size:clamp(28px,3vw,38px);font-weight:900;background:linear-gradient(135deg,var(--orange),var(--orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2}
.stat-label{font-size:12px;color:rgba(255,255,255,0.5);margin-top:6px;font-weight:500;text-transform:uppercase;letter-spacing:1px}
@keyframes fiU{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fiD{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}

/* ===== SECTIONS ===== */
.sec{padding:80px 40px;position:relative;background:var(--bg-white)}
.sec.bg-light{background:var(--bg-section)}
.section-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 18px;border-radius:50px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.8px;margin-bottom:16px}
.tag-orange{background:rgba(245,109,14,0.08);color:var(--orange);border:1px solid rgba(245,109,14,0.2)}
.tag-cyan{background:rgba(14,165,201,0.08);color:var(--cyan);border:1px solid rgba(14,165,201,0.2)}
.tag-green{background:rgba(16,185,129,0.08);color:var(--green);border:1px solid rgba(16,185,129,0.2)}
.tag-purple{background:rgba(139,92,246,0.08);color:#8b5cf6;border:1px solid rgba(139,92,246,0.2)}
.sh{margin-bottom:60px;max-width:1200px;margin-left:auto;margin-right:auto}
.sh.c{text-align:center}
.st{font-size:clamp(28px,4vw,44px);font-weight:800;margin-bottom:18px;letter-spacing:-.5px;line-height:1.15;color:var(--text-dark)}
.ss{font-size:17px;color:var(--text-muted);max-width:620px;line-height:1.7}
.sh.c .ss{margin:0 auto}

/* ===== DIFERENCIACIÓN CARDS ===== */
.diff-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:1200px;margin:0 auto}
.dc{background:#fff;border:1px solid var(--border);border-radius:20px;padding:44px 32px;transition:all .45s;position:relative;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,0.05)}
.dc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--orange),var(--orange-light));transform:scaleX(0);transition:transform .4s;transform-origin:left}
.dc:hover::before{transform:scaleX(1)}
.dc:hover{transform:translateY(-8px);border-color:rgba(245,109,14,0.2);box-shadow:0 20px 50px rgba(0,0,0,0.1)}
.di{width:80px;height:80px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:28px}
.di.o{background:rgba(245,109,14,0.1)}.di.cy{background:rgba(14,165,201,0.1)}.di.g{background:rgba(16,185,129,0.1)}
.di svg{width:40px;height:40px}
.dc h3{font-size:20px;font-weight:700;margin-bottom:8px;color:var(--text-dark)}
.cb{display:inline-block;font-size:11px;font-weight:700;color:var(--orange);background:rgba(245,109,14,0.08);padding:3px 10px;border-radius:20px;margin-bottom:14px;letter-spacing:.5px}
.dc p{font-size:14.5px;color:var(--text-muted);line-height:1.75}

/* ===== RENDIMIENTO ===== */
.sec.perf{background:var(--bg-section)}
.sec.perf::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 20%,rgba(245,109,14,0.05),transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(14,165,201,0.04),transparent 50%);pointer-events:none}
.perf-layout{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.perf-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:420px}
.perf-circle{width:320px;height:320px;border-radius:50%;border:2px solid rgba(245,109,14,0.2);display:flex;align-items:center;justify-content:center;position:relative;animation:rs 30s linear infinite}
@keyframes rs{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}
.perf-circle::before{content:'';position:absolute;width:360px;height:360px;border-radius:50%;border:1px dashed rgba(14,165,201,0.18);animation:rs 45s linear infinite reverse}
.perf-circle::after{content:'';position:absolute;width:400px;height:400px;border-radius:50%;border:1px solid rgba(0,0,0,0.06)}
.perf-center{animation:rs 30s linear infinite reverse;text-align:center}
.perf-center .big-num{font-size:56px;font-weight:900;background:linear-gradient(135deg,var(--orange),var(--orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.perf-center .big-label{font-size:13px;color:var(--charcoal-light);margin-top:4px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px}
.od{position:absolute;width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;animation:rs 30s linear infinite reverse}
.od.d1{top:-10px;left:50%;transform:translateX(-50%);background:rgba(245,109,14,0.12);color:var(--orange)}
.od.d2{bottom:-10px;left:50%;transform:translateX(-50%);background:rgba(14,165,201,0.12);color:var(--cyan)}
.od.d3{top:50%;left:-10px;transform:translateY(-50%);background:rgba(16,185,129,0.12);color:var(--green)}
.od.d4{top:50%;right:-10px;transform:translateY(-50%);background:rgba(65,66,68,0.08);color:var(--charcoal)}
.perf-features{display:flex;flex-direction:column;gap:24px}
.pf{display:flex;gap:20px;padding:28px;border-radius:16px;background:#fff;border:1px solid var(--border);transition:all .4s;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.pf:hover{border-color:rgba(245,109,14,0.2);transform:translateX(8px);box-shadow:0 8px 30px rgba(0,0,0,0.08)}
.pfi{min-width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center}
.pfi svg{width:32px;height:32px}
.pfi.o{background:rgba(245,109,14,0.1)}.pfi.cy{background:rgba(14,165,201,0.1)}.pfi.g{background:rgba(16,185,129,0.1)}
.pf h4{font-size:17px;font-weight:700;margin-bottom:6px;color:var(--text-dark)}
.pf p{font-size:14px;color:var(--text-muted);line-height:1.7}

/* ===== VENTAJAS GRID (reemplaza comparativa) ===== */
.ventajas-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.ventaja-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:36px;display:flex;gap:24px;align-items:flex-start;transition:all .4s;box-shadow:0 2px 16px rgba(0,0,0,0.04)}
.ventaja-card:hover{border-color:rgba(245,109,14,0.2);transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,0.1)}
.vc-icon{min-width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.vc-icon.orange{background:rgba(245,109,14,0.1)}
.vc-icon.cyan{background:rgba(14,165,201,0.1)}
.vc-icon.green{background:rgba(16,185,129,0.1)}
.vc-icon.charcoal{background:rgba(65,66,68,0.08)}
.vc-icon svg{width:32px;height:32px}
.vc-body h4{font-size:18px;font-weight:700;color:var(--text-dark);margin-bottom:8px}
.vc-body p{font-size:14px;color:var(--text-muted);line-height:1.7}
.vc-badge{display:inline-block;margin-top:12px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;background:rgba(245,109,14,0.08);color:var(--orange);border:1px solid rgba(245,109,14,0.15)}

/* ===== EXTRAS GRID ===== */
.extras-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1200px;margin:60px auto 0}
.extra-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:28px 24px;text-align:center;transition:all .4s;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.extra-card:hover{border-color:rgba(245,109,14,0.2);transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,0.09)}
.extra-icon{width:64px;height:64px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}
.extra-icon.ring{border-radius:50%;border:3px solid var(--orange);position:relative}
.ring-value{font-size:16px;font-weight:900;color:var(--orange)}
.extra-card h4{font-size:16px;font-weight:700;margin-bottom:8px;color:var(--text-dark)}
.extra-card p{font-size:14px;color:var(--text-muted);line-height:1.6}

/* ===== SEGMENTOS ===== */
.seg-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:1200px;margin:0 auto}
.seg-card{border-radius:20px;padding:40px 32px;border:1px solid var(--border);background:#fff;transition:all .4s;text-align:center;box-shadow:0 2px 16px rgba(0,0,0,0.04)}
.seg-card:hover{transform:translateY(-8px);border-color:rgba(245,109,14,0.2);box-shadow:0 20px 50px rgba(0,0,0,0.1)}
.seg-card h3{font-size:20px;font-weight:700;margin-bottom:6px;color:var(--text-dark)}
.seg-card .seg-for{font-size:12px;font-weight:700;color:var(--orange);margin-bottom:14px;text-transform:uppercase;letter-spacing:1px}
.seg-card p{font-size:14px;color:var(--text-muted);line-height:1.7}

/* ===== PRICING ===== */
.price-card{border-radius:20px;padding:44px 32px;border:1px solid var(--border);background:#fff;transition:all .4s;text-align:center;position:relative;box-shadow:0 2px 16px rgba(0,0,0,0.05)}
.price-card:hover{transform:translateY(-8px);border-color:rgba(245,109,14,0.25);box-shadow:0 24px 60px rgba(0,0,0,0.12)}
.price-card.pop{border-color:rgba(245,109,14,0.35);background:linear-gradient(160deg,rgba(245,109,14,0.04),#fff)}
.pop-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--orange),var(--orange-light));color:#fff;padding:6px 20px;border-radius:0 0 12px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px}
.price-card .plan-name{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:8px}
.price-card .plan-range{font-size:15px;color:var(--charcoal-mid);margin-bottom:20px}
.price-card .plan-price{font-size:42px;font-weight:900;margin-bottom:2px;background:linear-gradient(135deg,var(--orange),var(--orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.price-card .plan-price .currency{font-size:20px;font-weight:600;vertical-align:top;line-height:2.5}
.price-card .plan-unit{font-size:13px;color:var(--text-muted);margin-bottom:6px}
.price-card .plan-fee{font-size:12px;color:var(--charcoal-light);margin-bottom:28px}
.plan-features{list-style:none;text-align:left;margin-bottom:32px;display:flex;flex-direction:column;gap:12px}
.plan-features li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--charcoal-mid)}
.plan-features li svg{min-width:18px;height:18px}
.btn-plan{display:block;width:100%;padding:14px;border-radius:50px;font-weight:700;font-size:14px;text-decoration:none;text-align:center;transition:all .3s;cursor:pointer;border:none}
.btn-plan.primary{background:linear-gradient(135deg,var(--orange),var(--orange-light));color:#fff;box-shadow:0 4px 20px var(--orange-glow)}
.btn-plan.primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(245,109,14,0.4)}
.btn-plan.outline{background:transparent;color:var(--charcoal);border:1.5px solid var(--border-strong)}
.btn-plan.outline:hover{border-color:var(--orange);color:var(--orange)}
.pricing-note{text-align:center;margin-top:32px;font-size:13px;color:var(--text-muted);max-width:700px;margin-left:auto;margin-right:auto;line-height:1.7}

/* ===== FAQ ===== */
.faq-wrap{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:all .3s;box-shadow:0 2px 10px rgba(0,0,0,0.04)}
.faq-item:hover{border-color:rgba(245,109,14,0.2);box-shadow:0 6px 24px rgba(0,0,0,0.08)}
.faq-q{padding:22px 28px;display:flex;align-items:center;cursor:pointer;font-weight:600;font-size:15px;gap:12px;user-select:none;color:var(--text-dark)}
.faq-q span:first-child{flex:1}
.faq-q .faq-cat{font-size:11px;font-weight:700;color:var(--orange);background:rgba(245,109,14,0.08);padding:3px 10px;border-radius:20px;white-space:nowrap;margin-left:auto;flex-shrink:0}
.faq-q svg{min-width:20px;transition:transform .3s;color:var(--charcoal-light)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a-inner{padding:0 28px 22px;font-size:14.5px;color:var(--text-muted);line-height:1.75}
.faq-item.open .faq-q svg{transform:rotate(45deg);color:var(--orange)}
.faq-item.open .faq-a{max-height:300px}
.faq-item.open{border-color:rgba(245,109,14,0.25);box-shadow:0 8px 32px rgba(245,109,14,0.08)}

/* ===== FOOTER ===== */
footer{padding:80px 40px 40px;border-top:1px solid var(--border);background:var(--charcoal)}
.footer-top{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}
.footer-brand{display:flex;flex-direction:column;gap:14px}
.footer-brand .f-logo img{height:30px}
.footer-brand p{font-size:14px;color:rgba(255,255,255,0.82);line-height:1.7;max-width:300px}
.footer-brand .dev-by{font-size:12px;color:rgba(255,255,255,0.70);margin-top:4px}
.footer-brand .dev-logo{margin-top:6px}
.footer-col h4{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.75);margin-bottom:20px}
.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,0.85);text-decoration:none;margin-bottom:12px;transition:color .3s}
.footer-col a:hover{color:var(--orange)}
.footer-contact-item{display:flex;align-items:center;gap:8px;font-size:14px;color:rgba(255,255,255,0.85);margin-bottom:12px}
.footer-bottom{max-width:1200px;margin:0 auto;padding-top:30px;border-top:1px solid rgba(255,255,255,0.15);text-align:center;font-size:13px;color:rgba(255,255,255,0.70)}

/* ===== PAGE HEADER (Secondary pages) ===== */
.page-header{padding:140px 40px 60px;position:relative;overflow:hidden;text-align:center;background:#0f153a}
.page-header::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.04) 1px,transparent 1px);background-size:70px 70px;mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%);pointer-events:none}
.page-header::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 0%,rgba(245,109,14,0.15),transparent 55%),radial-gradient(ellipse at 20% 100%,rgba(14,165,201,0.08),transparent 50%);pointer-events:none}
.page-header-lines{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.page-header-line{position:absolute;height:2px;background:linear-gradient(90deg,transparent,rgba(245,109,14,0.45),rgba(255,140,53,0.25),transparent);animation:sl 4s linear infinite;border-radius:2px;box-shadow:0 0 8px rgba(245,109,14,0.15)}
.page-header-line:nth-child(1){top:25%;width:300px;left:-300px}
.page-header-line:nth-child(2){top:55%;width:200px;left:-200px;animation-delay:1.8s}
.page-header-line:nth-child(3){top:75%;width:350px;left:-350px;animation-delay:3.2s}
.page-header h1{font-size:clamp(30px,4.5vw,48px);font-weight:900;letter-spacing:-1px;line-height:1.15;position:relative;z-index:2;color:#fff}
.page-header h1 .highlight{background:linear-gradient(135deg,var(--orange),var(--orange-light),#ffaa40);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.page-header p{font-size:17px;color:rgba(255,255,255,0.7);max-width:700px;margin:16px auto 0;position:relative;z-index:2;line-height:1.7}
.page-header .last-updated{font-size:13px;color:rgba(255,255,255,0.45);margin-top:12px;position:relative;z-index:2}
.breadcrumbs{position:relative;z-index:2}

/* ===== BREADCRUMBS ===== */
.breadcrumbs{max-width:900px;margin:0 auto;padding:0 40px;position:relative;z-index:2}
.breadcrumbs ul{display:flex;align-items:center;gap:8px;list-style:none;flex-wrap:wrap}
.breadcrumbs li{font-size:13px;color:rgba(255,255,255,0.5);display:flex;align-items:center;gap:8px}
.breadcrumbs li a{color:rgba(255,255,255,0.55);text-decoration:none;transition:color .3s}
.breadcrumbs li a:hover{color:var(--orange)}
.breadcrumbs li.active{color:var(--orange);font-weight:600}
.breadcrumbs .sep{color:rgba(255,255,255,0.3);font-size:11px}

/* ===== CONTENT (Secondary pages) ===== */
.content-section{max-width:900px;margin:0 auto;padding:60px 40px 80px}
.content-section h2{font-size:24px;font-weight:800;margin:48px 0 16px;color:var(--text-dark);letter-spacing:-.3px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.content-section h2:first-child{margin-top:0}
.content-section h3{font-size:19px;font-weight:700;margin:36px 0 12px;color:var(--orange)}
.content-section h3.prohibited{color:var(--red)}
.content-section h4{font-size:16px;font-weight:700;margin:24px 0 8px;color:var(--text-dark)}
.content-section p{font-size:15px;color:var(--charcoal-mid);line-height:1.8;margin-bottom:16px}
.content-section a{color:var(--orange);text-decoration:none;font-weight:600;transition:color .3s}
.content-section a:hover{color:var(--orange-light)}
.content-section strong{color:var(--text-dark);font-weight:600}
.content-section em{color:var(--charcoal-light);font-style:italic;font-size:14px}
.content-section ul,.content-section ol{margin:12px 0 20px 24px;display:flex;flex-direction:column;gap:10px}
.content-section ul li,.content-section ol li{font-size:15px;color:var(--charcoal-mid);line-height:1.7}

/* ===== CONTENT TABLES ===== */
.content-table{width:100%;border-collapse:collapse;margin:20px 0 28px;border-radius:12px;overflow:hidden;border:1px solid var(--border)}
.content-table th,.content-table td{padding:14px 20px;text-align:left;font-size:14px;border-bottom:1px solid var(--border)}
.content-table thead th{background:rgba(245,109,14,0.06);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--orange)}
.content-table td{color:var(--charcoal-mid)}
.content-table td:first-child{color:var(--text-dark);font-weight:600}
.content-table tbody tr:hover{background:var(--bg-section)}
.content-table tbody tr:last-child td{border-bottom:none}
.content-table code{background:rgba(0,0,0,0.04);padding:3px 8px;border-radius:6px;font-size:13px;color:var(--cyan);font-family:'Plus Jakarta Sans',sans-serif}

/* ===== EXAMPLE BLOCKS ===== */
.example-correct,.example-incorrect{padding:16px 20px;border-radius:12px;margin:12px 0;font-size:14px;line-height:1.7;color:var(--charcoal-mid)}
.example-correct{background:rgba(16,185,129,0.04);border:1px solid rgba(16,185,129,0.15)}
.example-correct::before{content:'✅ Correcto: ';font-weight:700;color:var(--green)}
.example-incorrect{background:rgba(239,68,68,0.04);border:1px solid rgba(239,68,68,0.12)}
.example-incorrect::before{content:'❌ Incorrecto: ';font-weight:700;color:var(--red)}
.content-divider{border:none;border-top:1px solid var(--border);margin:48px 0}

/* ===== CTA BOX ===== */
.cta-box{background:linear-gradient(160deg,rgba(245,109,14,0.06),var(--bg-section));border:1px solid rgba(245,109,14,0.2);border-radius:20px;padding:36px;margin-top:48px;text-align:center}
.cta-box h3{font-size:20px;font-weight:700;color:var(--text-dark);margin-bottom:10px}
.cta-box p{font-size:15px;color:var(--text-muted);margin-bottom:20px;line-height:1.7}
.cta-box .cta-links{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;font-size:14px}
.cta-box .cta-links a{color:var(--orange);text-decoration:none;font-weight:600;display:flex;align-items:center;gap:6px}

/* ===== FEATURE GRID ===== */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:24px 0 32px}
.feat-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:28px 24px;transition:all .4s;box-shadow:0 2px 10px rgba(0,0,0,0.04)}
.feat-card:hover{border-color:rgba(245,109,14,0.2);transform:translateY(-4px);box-shadow:0 15px 40px rgba(0,0,0,0.08)}
.feat-card h4{font-size:16px;font-weight:700;color:var(--text-dark);margin-bottom:8px}
.feat-card p{font-size:14px;color:var(--text-muted);line-height:1.7;margin:0}

/* ===== PRICING MINI ===== */
.pricing-mini{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:24px 0 32px}
.pm-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:28px 24px;text-align:center;transition:all .4s;box-shadow:0 2px 10px rgba(0,0,0,0.04)}
.pm-card:hover{border-color:rgba(245,109,14,0.2);transform:translateY(-4px);box-shadow:0 15px 40px rgba(0,0,0,0.08)}
.pm-card.popular{border-color:rgba(245,109,14,0.3);background:linear-gradient(160deg,rgba(245,109,14,0.04),#fff)}
.pm-card .pm-name{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:6px}
.pm-card .pm-range{font-size:13px;color:var(--charcoal-mid);margin-bottom:16px}
.pm-card .pm-price{font-size:36px;font-weight:900;background:linear-gradient(135deg,var(--orange),var(--orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2}
.pm-card .pm-unit{font-size:13px;color:var(--text-muted);margin-top:2px}
.pm-card .pm-fee{font-size:11px;color:var(--charcoal-light);margin-top:8px}
.pm-card .pm-desc{font-size:13px;color:var(--charcoal-mid);margin-top:14px;line-height:1.6}
.pm-badge{display:inline-block;background:linear-gradient(135deg,var(--orange),var(--orange-light));color:#fff;padding:4px 14px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}

/* ===== STEPS ===== */
.steps{display:flex;flex-direction:column;gap:16px;margin:24px 0 32px}
.step{display:flex;gap:20px;align-items:flex-start;padding:20px 24px;border-radius:14px;background:#fff;border:1px solid var(--border);transition:all .3s;box-shadow:0 2px 10px rgba(0,0,0,0.04)}
.step:hover{border-color:rgba(245,109,14,0.2);transform:translateX(6px)}
.step-num{min-width:40px;height:40px;border-radius:12px;background:rgba(245,109,14,0.1);color:var(--orange);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800}
.step-text h4{font-size:15px;font-weight:700;color:var(--text-dark);margin-bottom:4px}
.step-text p{font-size:14px;color:var(--text-muted);line-height:1.6;margin:0}

/* ===== FEATURE BLOCKS (Recursos section) ===== */
.feature-block{max-width:1200px;margin:0 auto 80px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.feature-block:last-child{margin-bottom:0}
.feature-block--reverse{direction:rtl}
.feature-block--reverse>*{direction:ltr}

/* Visual panel */
.fb-visual{position:relative;border:1px solid var(--border);border-radius:28px;overflow:hidden;min-height:400px;padding:0}
.fb-visual::before{content:'';position:absolute;inset:0;pointer-events:none}
.fb-visual--short::before{background:none}
.fb-visual--sandbox::before{background:none}
.fb-badge{padding:6px 18px;border-radius:50px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:2px;background:rgba(245,109,14,0.1);color:var(--orange);border:1px solid rgba(245,109,14,0.2);align-self:flex-start}

/* API diagram */
.fb-diagram{position:relative;width:180px;height:180px;display:flex;align-items:center;justify-content:center}
.fb-node--center{width:64px;height:64px;border-radius:50%;background:rgba(245,109,14,0.1);border:2px solid rgba(245,109,14,0.3);display:flex;align-items:center;justify-content:center;z-index:2}
.fb-orbit{position:absolute;inset:0;animation:rs 8s linear infinite}
.fb-orbit--2{animation-duration:12s;animation-direction:reverse}
.fb-satellite{position:absolute;top:50%;left:50%;width:48px;height:24px;transform:translate(-50%,-50%) rotate(var(--angle)) translateX(80px) rotate(calc(-1 * var(--angle)));background:#fff;border:1px solid var(--border);border-radius:20px;display:flex;align-items:center;justify-content:center}
.fb-satellite span{font-size:10px;font-weight:700;color:var(--charcoal-mid)}
.fb-dot{position:absolute;top:50%;left:50%;width:8px;height:8px;border-radius:50%;transform:translate(-50%,-50%) rotate(var(--angle)) translateX(60px);background:rgba(245,109,14,0.3)}
.fb-code-preview{width:100%;background:rgba(0,0,0,0.03);border:1px solid var(--border);border-radius:12px;padding:14px 18px;display:flex;flex-direction:column;gap:6px}
.fb-code-line{font-size:12px;font-family:'Plus Jakarta Sans',monospace;color:var(--charcoal-mid)}
.fb-token-key{color:var(--orange);font-weight:700}
.fb-token-url{color:var(--cyan)}
.fb-token-val{color:var(--charcoal-light)}
.fb-token-ok{color:var(--green);font-weight:700}

/* Phone mock */
.fb-phone-mock{background:#1a1b1e;border-radius:20px;padding:20px 16px;width:220px;display:flex;flex-direction:column;gap:12px;box-shadow:0 12px 40px rgba(0,0,0,0.15)}
.fb-phone-notch{width:60px;height:6px;background:rgba(255,255,255,0.1);border-radius:3px;margin:0 auto 6px}
.fb-sms-bubble{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:12px;padding:10px 12px}
.fb-sms-bubble--2{opacity:.7}
.fb-sms-sender{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--cyan);margin-bottom:5px}
.fb-sms-text{font-size:12px;color:rgba(255,255,255,0.8);line-height:1.5}
.fb-sms-text strong{color:#fff}
.fb-carriers{display:flex;gap:8px}
.fb-carriers span{font-size:11px;font-weight:600;color:var(--charcoal-light);background:rgba(14,165,201,0.06);border:1px solid rgba(14,165,201,0.15);padding:4px 10px;border-radius:20px}

/* Terminal */
.fb-terminal{width:100%;border-radius:14px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,0.12)}
.fb-terminal-bar{background:#2d2f36;padding:10px 14px;display:flex;align-items:center;gap:6px}
.fb-dot-r{width:10px;height:10px;border-radius:50%;background:#ef4444}
.fb-dot-y{width:10px;height:10px;border-radius:50%;background:#f59e0b}
.fb-dot-g{width:10px;height:10px;border-radius:50%;background:#10b981}
.fb-terminal-title{font-size:11px;color:rgba(255,255,255,0.4);margin-left:6px;font-weight:500}
.fb-terminal-body{background:#1a1d23;padding:16px 18px;display:flex;flex-direction:column;gap:5px}
.fb-line{font-size:12px;font-family:'Plus Jakarta Sans',monospace;color:rgba(255,255,255,0.5);line-height:1.6}
.fb-prompt{color:var(--green);margin-right:6px;font-weight:700}
.fb-line--out{color:rgba(255,255,255,0.35)}
.fb-line--success{color:var(--green);font-weight:600}
.fb-ok{color:var(--green);font-weight:700}
.fb-cursor{color:var(--green);animation:blink 1s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.fb-stats-row{display:flex;gap:16px;width:100%}
.fb-mini-stat{flex:1;background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px;text-align:center;box-shadow:0 2px 8px rgba(0,0,0,0.05)}
.fb-mini-stat span{display:block;font-size:15px;font-weight:800;color:var(--text-dark);line-height:1}
.fb-mini-stat span.fb-ok{color:var(--green)}
.fb-mini-stat small{font-size:10px;color:var(--text-muted);margin-top:4px;display:block;font-weight:600;text-transform:uppercase;letter-spacing:.5px}

.fb-img{width:100%;height:100%;min-height:400px;object-fit:cover;display:block;border-radius:0}

/* Content side */
.fb-title{font-size:clamp(24px,3vw,36px);font-weight:800;letter-spacing:-.5px;line-height:1.2;margin-bottom:16px;color:var(--text-dark)}
.fb-desc{font-size:15px;color:var(--text-muted);line-height:1.8;margin-bottom:24px}
.fb-list{list-style:none;margin:0 0 32px;display:flex;flex-direction:column;gap:10px}
.fb-list li{display:flex;align-items:center;gap:10px;font-size:14.5px;color:var(--charcoal-mid);font-weight:500}
.fb-cta{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:50px;font-size:14px;font-weight:700;text-decoration:none;border:1.5px solid rgba(245,109,14,0.25);background:rgba(245,109,14,0.06);color:var(--orange);transition:all .3s}
.fb-cta:hover{transform:translateX(4px);box-shadow:0 6px 24px rgba(0,0,0,0.1)}
.fb-cta svg{transition:transform .3s}
.fb-cta:hover svg{transform:translateX(3px)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .diff-grid,.seg-grid,.ventajas-grid{grid-template-columns:1fr 1fr}
  .extras-grid{grid-template-columns:1fr 1fr}
  .pricing-grid-4{grid-template-columns:repeat(2,1fr)!important}
  .infra-grid-3{grid-template-columns:1fr 1fr!important}
  .footer-top{grid-template-columns:1fr 1fr}
  .feat-grid,.pricing-mini{grid-template-columns:1fr 1fr}
}
@media(max-width:1200px){
  nav{padding:14px 20px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .hero{padding:120px 20px 60px}
  .hero-stats{flex-direction:column;gap:0}
  .stat:not(:last-child)::after{right:20%;top:auto;bottom:0;height:1px;width:60%}
  .hero-ctas{flex-direction:column;align-items:center}
  .diff-grid,.seg-grid,.extras-grid,.ventajas-grid{grid-template-columns:1fr}
  .perf-layout{grid-template-columns:1fr;gap:40px}
  .perf-visual{min-height:300px}
  .perf-circle{width:240px;height:240px}
  .perf-circle::before{width:280px;height:280px}
  .perf-circle::after{width:310px;height:310px}
  .perf-center .big-num{font-size:40px}
  .pricing-grid-4{grid-template-columns:1fr!important}
  .infra-grid-3{grid-template-columns:1fr!important}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:12px}
  .feature-block{grid-template-columns:1fr;gap:32px}
  .feature-block--reverse{direction:ltr}
  .fb-visual{min-height:auto}
  .fb-diagram{width:140px;height:140px}
  .fb-phone-mock{width:100%;max-width:280px}
  
  .page-header{padding:120px 20px 40px}
  .content-section{padding:40px 20px 60px}
  .breadcrumbs{padding:0 20px}
  .feat-grid,.pricing-mini{grid-template-columns:1fr}
  .content-table th,.content-table td{padding:10px 14px}
  .cta-box .cta-links{flex-direction:column;gap:12px}
}

/* ===== CONTACT PAGE SPECIFIC STYLES ===== */
.contact-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:48px;max-width:1100px;margin:0 auto;padding:60px 40px 80px;align-items:start}

/* Info panel */
.contact-info{display:flex;flex-direction:column;gap:28px;position:sticky;top:100px}
.contact-info-block{background:#fff;border:1px solid var(--border);border-radius:20px;padding:28px;box-shadow:0 2px 16px rgba(0,0,0,0.05);transition:all .3s}
.contact-info-block:hover{border-color:rgba(245,109,14,0.2);box-shadow:0 8px 32px rgba(0,0,0,0.08)}
.cib-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.cib-icon.orange{background:rgba(245,109,14,0.1)}
.cib-icon.cyan{background:rgba(14,165,201,0.1)}
.cib-icon.green{background:rgba(16,185,129,0.1)}
.cib-icon.charcoal{background:rgba(65,66,68,0.08)}
.cib-icon svg{width:24px;height:24px}
.cib-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:10px}
.cib-content{font-size:14px;color:var(--charcoal-mid);line-height:1.8}
.cib-content a{color:var(--orange);text-decoration:none;font-weight:600;transition:color .3s}
.cib-content a:hover{color:var(--orange-light)}
.cib-content strong{color:var(--text-dark);font-weight:600}
.cib-map-link{display:inline-flex;align-items:center;gap:6px;margin-top:10px;font-size:13px;font-weight:700;color:var(--orange);text-decoration:none;transition:all .3s}
.cib-map-link:hover{color:var(--orange-light);transform:translateX(3px)}
.cib-map-link svg{width:14px;height:14px;transition:transform .3s}
.cib-map-link:hover svg{transform:translateX(2px)}
.schedule-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:14px}
.schedule-row:last-child{border-bottom:none;padding-bottom:0}
.schedule-row .day{color:var(--charcoal-mid);font-weight:500}
.schedule-row .hours{color:var(--text-dark);font-weight:600}
.schedule-row .closed{color:#ef4444;font-weight:600}

/* Form panel */
.contact-form-wrap{background:#fff;border:1px solid var(--border);border-radius:24px;padding:40px;box-shadow:0 4px 32px rgba(0,0,0,0.06)}
.form-intro{font-size:14.5px;color:var(--text-muted);margin-bottom:8px;line-height:1.7}
.form-required-note{font-size:12px;color:var(--charcoal-light);margin-bottom:28px}
.form-required-note span{color:var(--orange);font-weight:700}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}
.form-group:last-child{margin-bottom:0}
.form-label{font-size:13px;font-weight:700;color:var(--text-dark);display:flex;align-items:center;gap:4px}
.form-label .req{color:var(--orange)}
.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:12px;font-size:14px;font-family:'Plus Jakarta Sans',sans-serif;color:var(--text-dark);background:#fff;transition:all .3s;outline:none;appearance:none;-webkit-appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(245,109,14,0.1)}
.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:var(--border-strong)}
.form-input.error,.form-select.error,.form-textarea.error{border-color:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,0.08)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--charcoal-light)}
.form-textarea{resize:vertical;min-height:120px;line-height:1.6}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23414244' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer}

/* Checkboxes */
.checkboxes-group{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}
.checkbox-item{display:flex;align-items:center;gap:10px;cursor:pointer;padding:10px 14px;border-radius:10px;border:1.5px solid var(--border);transition:all .3s;background:#fff}
.checkbox-item:hover{border-color:rgba(245,109,14,0.3);background:rgba(245,109,14,0.03)}
.checkbox-item input[type="checkbox"]{width:18px;height:18px;accent-color:var(--orange);cursor:pointer;flex-shrink:0}
.checkbox-item label{font-size:14px;color:var(--charcoal-mid);cursor:pointer;font-weight:500;line-height:1.3}
.checkbox-item:has(input:checked){border-color:rgba(245,109,14,0.4);background:rgba(245,109,14,0.04)}
.otro-input{margin-top:10px;display:none}
.otro-input.visible{display:block}

/* Terms checkbox */
.terms-check{display:flex;align-items:flex-start;gap:12px;padding:16px;border-radius:12px;border:1.5px solid var(--border);background:rgba(245,109,14,0.02);margin-bottom:28px;transition:all .3s}
.terms-check:has(input:checked){border-color:rgba(245,109,14,0.3);background:rgba(245,109,14,0.04)}
.terms-check input[type="checkbox"]{width:18px;height:18px;accent-color:var(--orange);cursor:pointer;flex-shrink:0;margin-top:2px}
.terms-check label{font-size:14px;color:var(--charcoal-mid);cursor:pointer;line-height:1.6}
.terms-check label a{color:var(--orange);font-weight:600;text-decoration:none}
.terms-check label a:hover{text-decoration:underline}

/* Form buttons */
.form-actions{display:flex;gap:16px;align-items:center}
.btn-submit{background:linear-gradient(135deg,var(--orange),var(--orange-light));color:#fff;padding:14px 36px;border-radius:50px;font-weight:700;font-size:15px;border:none;cursor:pointer;transition:all .3s;display:inline-flex;align-items:center;gap:10px;box-shadow:0 4px 20px rgba(245,109,14,0.3);font-family:'Plus Jakarta Sans',sans-serif}
.btn-submit:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(245,109,14,0.4)}
.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}
.btn-reset{background:transparent;color:var(--charcoal-mid);padding:14px 28px;border-radius:50px;font-weight:600;font-size:15px;border:1.5px solid var(--border-strong);cursor:pointer;transition:all .3s;font-family:'Plus Jakarta Sans',sans-serif}
.btn-reset:hover{border-color:var(--charcoal);color:var(--charcoal)}

/* Field error messages */
.field-error{font-size:12px;color:#ef4444;font-weight:600;margin-top:4px;display:none}
.field-error.visible{display:block}

/* Success / Error alert */
.form-alert{display:none;padding:18px 24px;border-radius:16px;margin-bottom:24px;font-size:14.5px;font-weight:600;line-height:1.6;align-items:flex-start;gap:14px}
.form-alert.visible{display:flex}
.form-alert.success{background:rgba(16,185,129,0.08);border:1.5px solid rgba(16,185,129,0.25);color:#065f46}
.form-alert.error-alert{background:rgba(239,68,68,0.06);border:1.5px solid rgba(239,68,68,0.2);color:#991b1b}
.alert-icon{width:24px;height:24px;flex-shrink:0;margin-top:1px}
.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,0.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

/* Responsive */
@media(max-width:1024px){.contact-layout{grid-template-columns:1fr;gap:32px;padding:40px 20px 60px}.contact-info{position:static}.checkboxes-group{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column;align-items:stretch}.btn-submit,.btn-reset{text-align:center;justify-content:center}}

/* ============================================================
   MODO OSCURO — Dark Mode
   Activado por: body.dark
   ============================================================ */

body.dark {
  --bg-white:#0f1117;
  --bg-light:#0f1117;
  --bg-section:#161b27;
  --border:#2a2d3a;
  --border-strong:#3a3d4a;
  --text-dark:#eef0f4;
  --text-body:#c8ccd6;
  --text-muted:#8e94a4;
  --charcoal-mid:#a0a6b8;
  --charcoal-light:#6b7080;
  --orange-soft:rgba(245,109,14,0.12);
  --orange-mid:rgba(245,109,14,0.2);
  --orange-glow:rgba(245,109,14,0.3);
}

/* Navbar */
body.dark nav{background:rgba(15,17,23,0.97);border-bottom-color:var(--border);box-shadow:0 2px 20px rgba(0,0,0,0.4)}
body.dark .nav-logo img{content:url('images/logo_smsya_blanco.webp')}
body.dark .mobile-close img{content:url('images/logo_smsya_blanco.webp')}
body.dark .dropdown-menu{background:#1a1f2e;border-color:var(--border);box-shadow:0 12px 40px rgba(0,0,0,0.5)}
body.dark .dropdown-menu a{color:var(--text-muted)}
body.dark .hamburger span{background:var(--text-dark)}

/* Mobile menu */
body.dark .mobile-overlay{background:rgba(15,17,23,0.99)}
body.dark .mobile-close{border-bottom-color:var(--border)}
body.dark .mobile-close-btn{background:var(--bg-section);border-color:var(--border)}
body.dark .mobile-close-btn svg{color:var(--text-dark)}
body.dark .mobile-overlay a{color:var(--text-muted);border-bottom-color:var(--border)}

/* Body & sections */
body.dark{background:var(--bg-white);color:var(--text-dark)}
body.dark .sec{background:var(--bg-white)}
body.dark .sec.bg-light{background:var(--bg-section)}
body.dark .sec.perf{background:var(--bg-section)}

/* Page header (secondary pages) */
body.dark .page-header{background:var(--hero-mid)}

/* Cards — diferenciación */
body.dark .dc{background:#1a1f2e;border-color:var(--border);box-shadow:0 2px 16px rgba(0,0,0,0.3)}
body.dark .dc:hover{border-color:rgba(245,109,14,0.3);box-shadow:0 20px 50px rgba(0,0,0,0.5)}

/* Cards — ventajas */
body.dark .ventaja-card{background:#1a1f2e;border-color:var(--border);box-shadow:0 2px 16px rgba(0,0,0,0.3)}
body.dark .ventaja-card:hover{border-color:rgba(245,109,14,0.3);box-shadow:0 16px 48px rgba(0,0,0,0.5)}

/* Cards — extra / segmentos / pricing */
body.dark .extra-card{background:#1a1f2e;border-color:var(--border);box-shadow:0 2px 12px rgba(0,0,0,0.3)}
body.dark .extra-card:hover{border-color:rgba(245,109,14,0.3)}
body.dark .seg-card{background:#1a1f2e;border-color:var(--border);box-shadow:0 2px 16px rgba(0,0,0,0.3)}
body.dark .seg-card:hover{box-shadow:0 20px 50px rgba(0,0,0,0.5)}
body.dark .price-card{background:#1a1f2e;border-color:var(--border);box-shadow:0 2px 16px rgba(0,0,0,0.3)}
body.dark .price-card:hover{box-shadow:0 24px 60px rgba(0,0,0,0.5)}
body.dark .price-card.pop{background:linear-gradient(160deg,rgba(245,109,14,0.08),#1a1f2e)}

/* Performance cards */
body.dark .pf{background:#1a1f2e;border-color:var(--border);box-shadow:0 2px 12px rgba(0,0,0,0.3)}
body.dark .pf:hover{border-color:rgba(245,109,14,0.25);box-shadow:0 8px 30px rgba(0,0,0,0.4)}

/* Feature blocks (recursos) */
body.dark .fb-visual{background:#1a1f2e;border-color:var(--border)}
body.dark .fb-code-preview{background:rgba(0,0,0,0.3);border-color:var(--border)}

/* FAQ */
body.dark .faq-item{background:#1a1f2e;border-color:var(--border);box-shadow:0 2px 10px rgba(0,0,0,0.3)}
body.dark .faq-item:hover{border-color:rgba(245,109,14,0.25);box-shadow:0 6px 24px rgba(0,0,0,0.4)}
body.dark .faq-q{color:var(--text-dark)}
body.dark .faq-item.open{border-color:rgba(245,109,14,0.3);box-shadow:0 8px 32px rgba(0,0,0,0.4)}

/* Content sections (secondary pages) */
body.dark .content-section h2{color:var(--text-dark);border-bottom-color:var(--border)}
body.dark .content-section h3{color:var(--orange)}
body.dark .content-section p,body.dark .content-section li{color:var(--text-muted)}
body.dark .content-table{border-color:var(--border)}
body.dark .content-table th,body.dark .content-table td{border-bottom-color:var(--border)}
body.dark .content-table thead th{background:rgba(245,109,14,0.1)}
body.dark .content-table td{color:var(--text-muted)}
body.dark .content-table td:first-child{color:var(--text-dark)}
body.dark .content-table tbody tr:hover{background:rgba(255,255,255,0.03)}
body.dark .content-table code{background:rgba(255,255,255,0.06);color:var(--cyan)}

/* Feat grid cards */
body.dark .feat-card{background:#1a1f2e;border-color:var(--border);box-shadow:0 2px 10px rgba(0,0,0,0.3)}
body.dark .feat-card:hover{border-color:rgba(245,109,14,0.25);box-shadow:0 15px 40px rgba(0,0,0,0.4)}
body.dark .feat-card h4{color:var(--text-dark)}
body.dark .feat-card p{color:var(--text-muted)}

/* Steps */
body.dark .step{background:#1a1f2e;border-color:var(--border)}
body.dark .step:hover{border-color:rgba(245,109,14,0.25)}
body.dark .step-text h4{color:var(--text-dark)}
body.dark .step-text p{color:var(--text-muted)}

/* CTA box */
body.dark .cta-box{background:linear-gradient(160deg,rgba(245,109,14,0.08),rgba(22,27,39,0.9));border-color:rgba(245,109,14,0.25)}
body.dark .cta-box h3{color:var(--text-dark)}
body.dark .cta-box p{color:var(--text-muted)}

/* Pricing mini (que-es-sms-ya) */
body.dark .pm-card{background:#1a1f2e;border-color:var(--border)}
body.dark .pm-card.popular{background:linear-gradient(160deg,rgba(245,109,14,0.08),#1a1f2e)}

/* Btn secondary */
body.dark .btn-secondary{background:rgba(255,255,255,0.04);color:var(--text-dark);border-color:var(--border)}
body.dark .btn-secondary:hover{border-color:var(--orange);background:var(--orange-soft);color:var(--orange)}

/* Contact page */
body.dark .contact-info-block{background:#1a1f2e;border-color:var(--border);box-shadow:0 2px 16px rgba(0,0,0,0.3)}
body.dark .contact-info-block:hover{border-color:rgba(245,109,14,0.25)}
body.dark .cib-title{color:var(--text-muted)}
body.dark .cib-content{color:var(--charcoal-mid)}
body.dark .schedule-row{border-bottom-color:var(--border)}
body.dark .schedule-row .day{color:var(--text-muted)}
body.dark .schedule-row .hours{color:var(--text-dark)}
body.dark .contact-form-wrap{background:#1a1f2e;border-color:var(--border)}
body.dark .form-intro{color:var(--text-muted)}
body.dark .form-label{color:var(--text-dark)}
body.dark .form-input,body.dark .form-select,body.dark .form-textarea{background:#0f1117;border-color:var(--border);color:var(--text-dark)}
body.dark .form-input:hover,body.dark .form-select:hover,body.dark .form-textarea:hover{border-color:var(--border-strong)}
body.dark .form-input:focus,body.dark .form-select:focus,body.dark .form-textarea:focus{border-color:var(--orange);background:#0f1117}
body.dark .form-input::placeholder,body.dark .form-textarea::placeholder{color:var(--charcoal-light)}
body.dark .checkbox-item{background:#0f1117;border-color:var(--border)}
body.dark .checkbox-item:hover{border-color:rgba(245,109,14,0.3);background:rgba(245,109,14,0.05)}
body.dark .checkbox-item:has(input:checked){background:rgba(245,109,14,0.06)}
body.dark .checkbox-item label{color:var(--text-muted)}
body.dark .terms-check{background:rgba(245,109,14,0.04);border-color:var(--border)}
body.dark .terms-check label{color:var(--text-muted)}
body.dark .btn-reset{color:var(--text-muted);border-color:var(--border)}
body.dark .btn-reset:hover{border-color:var(--text-dark);color:var(--text-dark)}

/* Example blocks */
body.dark .example-correct{background:rgba(16,185,129,0.06);border-color:rgba(16,185,129,0.2)}
body.dark .example-incorrect{background:rgba(239,68,68,0.06);border-color:rgba(239,68,68,0.15)}

/* Breadcrumbs */
body.dark .breadcrumbs li{color:var(--text-muted)}
body.dark .breadcrumbs li a{color:var(--text-muted)}

/* Hero stats (dark override — hero already dark) */
body.dark .hero-stats{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.06)}

/* ===== DARK MODE TOGGLE BUTTON ===== */
.dm-toggle{position:fixed;bottom:116px;right:43px;width:38px;height:38px;border-radius:50%;background:var(--bg-section);border:1.5px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:999;box-shadow:0 2px 12px rgba(0,0,0,0.12);transition:all .3s;color:var(--charcoal-mid)}
.dm-toggle:hover{border-color:var(--orange);color:var(--orange);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,0.15)}
.dm-toggle svg{width:18px;height:18px;transition:all .3s}
.dm-toggle .icon-moon{display:block}
.dm-toggle .icon-sun{display:none}
body.dark .dm-toggle{background:#1a1f2e;border-color:var(--border);color:#c8ccd6;box-shadow:0 2px 12px rgba(0,0,0,0.4)}
body.dark .dm-toggle:hover{border-color:var(--orange);color:var(--orange)}
body.dark .dm-toggle .icon-moon{display:none}
body.dark .dm-toggle .icon-sun{display:block}
@media(max-width:1200px){.dm-toggle{bottom:104px;right:29px;width:34px;height:34px}.dm-toggle svg{width:16px;height:16px}}

/* Dark mode — pricing cards text & buttons */
body.dark .price-card .plan-name{color:var(--text-muted)}
body.dark .price-card .plan-range{color:var(--text-muted)}
body.dark .price-card .plan-unit{color:var(--text-muted)}
body.dark .price-card .plan-fee{color:var(--charcoal-light)}
body.dark .plan-features li{color:rgba(255,255,255,0.75)}
body.dark .btn-plan.outline{background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.85);border-color:rgba(255,255,255,0.2)}
body.dark .btn-plan.outline:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-soft)}
