/* ═══════════════════════════════════════════════════════
   Global GPS Perú — Landing 2025
   Paleta corporativa existente + sistema moderno
═══════════════════════════════════════════════════════ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --azul-marino:#1B2B6B;
  --azul-electrico:#2351E0;
  --azul-claro:#EFF4FB;
  --blanco:#ffffff;
  --gris-50:#f8fafc;
  --gris-100:#f1f5f9;
  --gris-200:#e2e8f0;
  --gris-400:#94a3b8;
  --gris-600:#475569;
  --gris-800:#1e293b;
  --naranja:#FF6B35;
  --naranja-oscuro:#e55a2b;
  --verde:#00C851;
  --navy-oscuro:#0D1425;
  --radius:8px;
  --radius-lg:14px;
  --shadow-sm:0 1px 3px rgba(15,23,42,.1);
  --shadow-md:0 4px 12px rgba(15,23,42,.08);
  --shadow-lg:0 16px 40px rgba(15,23,42,.12);
  --shadow-xl:0 24px 60px rgba(15,23,42,.18);
  --font-title:'Syne',sans-serif;
  --font-body:'Inter',sans-serif;
}

html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--gris-600);line-height:1.6;background:#fff;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,h6{font-family:var(--font-title);color:var(--azul-marino);line-height:1.15;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{cursor:pointer;border:none;font-family:inherit}
input,select,textarea{font-family:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* ── NOTIFICATION BAR ── */
.notif-bar{background:var(--naranja);color:#fff;text-align:center;padding:10px 40px;font-size:13.5px;font-weight:500;position:relative;z-index:100;min-height:40px;display:flex;align-items:center;justify-content:center}
.notif-bar .notif-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;color:#fff;font-size:22px;padding:0 8px;line-height:1}

/* ── NAVBAR ── */
.navbar{position:sticky;top:0;z-index:99;background:var(--azul-marino);transition:box-shadow .2s}
.navbar.scrolled{box-shadow:0 4px 20px rgba(0,0,0,.25)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px;gap:16px}
.logo-link{display:flex;align-items:center;gap:10px;color:#fff}
.logo-link img{border-radius:6px}
.logo-text{font-family:var(--font-title);font-size:18px;font-weight:800;color:#fff;letter-spacing:.02em}
.logo-text b{color:var(--naranja)}
.nav-links{display:flex;gap:28px;list-style:none}
.nav-links a{color:#fff;font-size:14.5px;font-weight:500;position:relative;padding:4px 0;transition:color .2s}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--naranja);transition:width .2s}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:14px}
.nav-phone{color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;gap:6px;opacity:.9}
.nav-phone:hover{opacity:1}

.btn-cta{background:var(--azul-electrico);color:#fff;padding:10px 22px;border-radius:var(--radius);font-weight:600;font-size:14px;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;border:2px solid transparent;line-height:1.2}
.btn-cta:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(35,81,224,.35)}
.btn-cta:active{transform:translateY(0)}
.btn-cta-naranja{background:var(--naranja)}
.btn-cta-naranja:hover{box-shadow:0 8px 20px rgba(255,107,53,.35);background:var(--naranja-oscuro)}
.btn-cta-outline{background:transparent;border-color:currentColor}
.btn-cta-outline:hover{background:rgba(255,255,255,.1)}
.btn-cta-lg{padding:14px 28px;font-size:15.5px}
.btn-cta-block{width:100%;padding:14px}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;padding:6px;width:36px}
.hamburger span{display:block;width:22px;height:2px;background:#fff;transition:all .2s}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--azul-marino);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:26px;padding:24px}
.mobile-menu.active{display:flex}
.mobile-menu a{color:#fff;font-size:20px;font-weight:600}
.mobile-close{position:absolute;top:18px;right:18px;background:none;color:#fff;font-size:38px;line-height:1}

/* ── HERO ── */
.hero{position:relative;background:linear-gradient(135deg,#1B2B6B 0%,#0D1425 100%);color:#fff;padding:70px 0 0;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:
  radial-gradient(circle at 20% 80%,rgba(255,107,53,.15) 0,transparent 50%),
  radial-gradient(circle at 80% 20%,rgba(35,81,224,.25) 0,transparent 50%);
  pointer-events:none}
.hero-inner{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:50px;align-items:center;padding-bottom:80px}
.hero-badge{display:inline-block;background:rgba(255,107,53,.2);color:#FFBFA3;padding:6px 14px;border-radius:100px;font-size:12.5px;font-weight:600;margin-bottom:18px;border:1px solid rgba(255,107,53,.35)}
.hero-content h1{color:#fff;font-size:clamp(32px,4.5vw,52px);line-height:1.05;margin-bottom:18px}
.hero-subtitle{font-size:17px;color:#cbd5e1;margin-bottom:30px;max-width:540px}
.hero-actions{display:flex;gap:12px;margin-bottom:32px;flex-wrap:wrap}
.hero-features{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px;max-width:500px;font-size:14px;color:#e2e8f0}
.hero-features li{display:flex;gap:6px;align-items:center}

.hero-visual{position:relative}
.hero-card{background:rgba(255,255,255,.08);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-xl)}
.hero-map{position:relative;height:280px;border-radius:var(--radius);overflow:hidden;background:#0D1425;border:1px solid rgba(255,255,255,.1)}
.map-grid{position:absolute;inset:0;background-image:
  linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:30px 30px}
.map-pulse{position:absolute;width:14px;height:14px;background:var(--naranja);border-radius:50%;box-shadow:0 0 0 0 rgba(255,107,53,.7);animation:pulse 2s infinite}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(255,107,53,.7)}
  70%{box-shadow:0 0 0 16px rgba(255,107,53,0)}
  100%{box-shadow:0 0 0 0 rgba(255,107,53,0)}
}
.map-route{position:absolute;inset:0;width:100%;height:100%;opacity:.9;animation:dash 3s linear infinite}
@keyframes dash{to{stroke-dashoffset:-40}}
.hero-card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px;text-align:center}
.hero-card-stats>div{background:rgba(255,255,255,.05);padding:12px 8px;border-radius:var(--radius);font-size:11px;color:#94a3b8}
.hero-card-stats b{display:block;color:#fff;font-family:var(--font-title);font-size:20px;margin-bottom:2px}

/* Stats bar */
.stats-bar{background:rgba(13,20,37,.6);border-top:1px solid rgba(255,255,255,.1);padding:20px 0}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat b{display:block;font-family:var(--font-title);font-size:28px;color:#fff;line-height:1}
.stat span{font-size:12.5px;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-top:4px;display:block}

/* ── SECTIONS ── */
.section{padding:80px 0}
.section-alt{background:var(--gris-50)}
.section-dark{background:linear-gradient(135deg,#0D1425 0%,#1B2B6B 100%);color:#fff}
.section-tag{display:inline-block;background:rgba(35,81,224,.1);color:var(--azul-electrico);padding:5px 12px;border-radius:100px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}
.section-tag-light{background:rgba(255,255,255,.1);color:#fff}
.section-title{font-size:clamp(26px,3.5vw,38px);margin-bottom:12px;max-width:800px}
.section-lead{font-size:17px;color:var(--gris-600);margin-bottom:40px;max-width:700px}
.section-dark .section-lead{color:#cbd5e1}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}

/* Cards */
.card-feature{background:#fff;border:1px solid var(--gris-200);border-radius:var(--radius-lg);padding:28px;transition:all .25s;position:relative;overflow:hidden}
.card-feature::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--naranja);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.card-feature:hover{border-color:var(--azul-electrico);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.card-feature:hover::before{transform:scaleX(1)}
.card-icon{font-size:38px;margin-bottom:14px;display:inline-block}
.card-feature h3{font-size:19px;margin-bottom:8px}
.card-feature p{font-size:14.5px}

/* Planes */
.plans{margin-bottom:24px}
.plan{background:#fff;border:2px solid var(--gris-200);border-radius:var(--radius-lg);padding:30px 26px;position:relative;transition:all .25s;display:flex;flex-direction:column}
.plan:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.plan-featured{border-color:var(--azul-electrico);background:linear-gradient(180deg,#EFF4FB 0%,#fff 50%)}
.plan-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--naranja);color:#fff;padding:5px 14px;border-radius:100px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.plan-head{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--gris-200)}
.plan-head h3{font-size:22px;margin-bottom:6px;color:var(--azul-marino)}
.plan-price{font-family:var(--font-title);margin:8px 0;color:var(--azul-marino)}
.plan-price small{font-size:13px;font-weight:400;color:var(--gris-600);font-family:var(--font-body)}
.plan-price b{font-size:36px;margin:0 2px}
.plan-desc{font-size:13px;color:var(--gris-600);margin-top:4px}
.plan-features{list-style:none;margin-bottom:20px;flex:1}
.plan-features li{padding:7px 0;font-size:14px;color:var(--gris-800)}
.plans-note{text-align:center;font-size:14px;color:var(--gris-600);margin-top:20px}

/* Industrias */
.industry{background:#fff;border:1px solid var(--gris-200);border-radius:var(--radius);padding:24px 18px;text-align:center;transition:all .25s}
.industry:hover{transform:translateY(-3px);border-color:var(--naranja);box-shadow:var(--shadow-md)}
.industry-icon{font-size:40px;margin-bottom:10px}
.industry h4{font-size:15.5px;margin-bottom:4px;color:var(--azul-marino)}
.industry p{font-size:12.5px}

/* Testimonios */
.testimonios .testimonio{background:#fff;border-radius:var(--radius-lg);padding:24px;border:1px solid var(--gris-200);position:relative}
.testimonio-stars{color:#f59e0b;margin-bottom:10px;font-size:18px;letter-spacing:2px}
.testimonio p{font-size:15px;color:var(--gris-800);line-height:1.6;margin-bottom:16px;font-style:italic}
.testimonio footer{font-style:normal}
.testimonio footer b{display:block;color:var(--azul-marino);font-size:14.5px;font-family:var(--font-title)}
.testimonio footer span{font-size:12.5px;color:var(--gris-600)}

.trust-logos{margin-top:40px;text-align:center;padding:28px;background:#fff;border-radius:var(--radius-lg);border:1px dashed var(--gris-200)}
.trust-logos>span{display:block;font-size:12px;color:var(--gris-400);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;font-weight:600}
.trust-badges{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.trust-badge{background:var(--azul-marino);color:#fff;padding:8px 20px;border-radius:6px;font-size:13px;font-weight:700;letter-spacing:.05em}

/* FAQ */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--gris-200);border-radius:var(--radius);margin-bottom:10px;overflow:hidden;transition:border-color .2s}
.faq-item[open]{border-color:var(--azul-electrico);box-shadow:var(--shadow-sm)}
.faq-item summary{padding:18px 22px;font-weight:600;color:var(--azul-marino);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;font-size:15.5px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:22px;font-weight:300;color:var(--azul-electrico);transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{padding:0 22px 20px;font-size:14.5px;color:var(--gris-600)}

/* Contacto */
.grid-contact{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.contact-methods{display:grid;gap:12px;margin-top:8px}
.contact-method{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:14px;transition:all .2s}
.contact-method:hover{background:rgba(255,255,255,.1);transform:translateX(3px)}
.contact-method>span{font-size:24px}
.contact-method b{color:#fff;font-size:15px;display:block;font-family:var(--font-body)}
.contact-method small{color:#cbd5e1;font-size:12px}

.contact-form{background:#fff;color:var(--gris-800);padding:34px;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl)}
.contact-form h3{color:var(--azul-marino);font-size:24px;margin-bottom:4px}
.contact-form label{display:block;font-size:13px;color:var(--gris-600);margin-bottom:14px;font-weight:500}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;padding:11px 14px;border:1.5px solid var(--gris-200);border-radius:var(--radius);font-size:14.5px;color:var(--gris-800);margin-top:5px;outline:none;transition:border-color .15s}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{border-color:var(--azul-electrico);box-shadow:0 0 0 3px rgba(35,81,224,.1)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-note{font-size:12px;color:var(--gris-600);text-align:center;margin-top:12px}

/* Footer */
.footer{background:var(--navy-oscuro);color:#94a3b8;padding:50px 0 20px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:36px;margin-bottom:32px}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.footer-brand img{border-radius:6px}
.footer-brand span{font-family:var(--font-title);font-size:19px;font-weight:800;color:#fff}
.footer-brand b{color:var(--naranja)}
.footer h4{color:#fff;font-size:14.5px;margin-bottom:14px;font-family:var(--font-body);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.footer ul{list-style:none}
.footer li{padding:5px 0;font-size:14px}
.footer a{color:#94a3b8;transition:color .15s}
.footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px}

/* WhatsApp flotante */
.wa-float{position:fixed;bottom:22px;left:22px;width:56px;height:56px;background:#25d366;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(37,211,102,.5);z-index:99;transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}

/* ═══════════════════════════════════════════════════════
   CHAT WIDGET
═══════════════════════════════════════════════════════ */
.chat-widget{position:fixed;bottom:22px;right:22px;z-index:100}
.chat-launcher{background:linear-gradient(135deg,var(--azul-marino),var(--azul-electrico));color:#fff;border-radius:100px;padding:14px 22px;display:flex;align-items:center;gap:10px;font-weight:600;font-size:14.5px;box-shadow:0 8px 24px rgba(35,81,224,.4);transition:all .2s;position:relative}
.chat-launcher:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(35,81,224,.5)}
.chat-launcher-icon{font-size:20px}
.chat-launcher-dot{position:absolute;top:-4px;right:-4px;width:12px;height:12px;background:var(--naranja);border-radius:50%;border:2px solid #fff;animation:pulse 1.5s infinite}

.chat-panel{position:absolute;bottom:calc(100% + 14px);right:0;width:370px;max-width:calc(100vw - 30px);max-height:calc(100vh - 100px);background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:none;flex-direction:column;overflow:hidden;animation:slideUp .25s ease}
.chat-panel.open{display:flex}
@keyframes slideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.chat-head{background:linear-gradient(135deg,var(--azul-marino),var(--azul-electrico));color:#fff;padding:16px 18px;display:flex;justify-content:space-between;align-items:center}
.chat-head-info{display:flex;gap:12px;align-items:center}
.chat-head-avatars{display:flex;gap:-4px}
.chat-head-avatars span{width:28px;height:28px;border-radius:50%;background:#FFD7C2;border:2px solid #fff;margin-right:-8px;display:inline-block}
.chat-head-avatars span:nth-child(2){background:#C7D8FF}
.chat-head-avatars span:nth-child(3){background:#FFE4A1}
.chat-head b{display:block;font-size:15px}
.chat-head small{font-size:11.5px;opacity:.85}
.chat-close{background:rgba(255,255,255,.15);color:#fff;padding:4px 10px;border-radius:4px;font-size:14px;line-height:1}

.chat-prechat{padding:18px;overflow-y:auto}
.chat-intro{font-size:14px;color:var(--gris-800);margin-bottom:14px;line-height:1.5}
.chat-prechat label{display:block;font-size:12.5px;color:var(--gris-600);margin-bottom:10px;font-weight:500}
.chat-prechat input,.chat-prechat select,.chat-prechat textarea{width:100%;padding:9px 11px;border:1.5px solid var(--gris-200);border-radius:6px;font-size:13.5px;margin-top:4px;outline:none}
.chat-prechat input:focus,.chat-prechat select:focus,.chat-prechat textarea:focus{border-color:var(--azul-electrico)}
.chat-note{font-size:11.5px;color:var(--gris-600);margin-top:10px;text-align:center}
.chat-emergency-btn{display:block;width:100%;background:#fee2e2;color:#991b1b;padding:7px;border-radius:6px;font-size:11.5px;font-weight:600;margin-top:5px;border:1px solid #fecaca;cursor:pointer;transition:background .15s}
.chat-emergency-btn.active{background:#dc2626;color:#fff}
.chat-emergency-btn:hover{background:#fecaca}
.chat-emergency-btn.active:hover{background:#b91c1c}

.chat-body{flex:1;overflow-y:auto;padding:16px;background:var(--gris-50);display:flex;flex-direction:column;gap:8px}
.chat-msg{max-width:80%;padding:9px 13px;border-radius:12px;font-size:13.5px;line-height:1.45;word-wrap:break-word;white-space:pre-wrap}
.chat-msg.in{background:#fff;border:1px solid var(--gris-200);align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg.out{background:var(--azul-electrico);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-time{font-size:10.5px;color:var(--gris-400);margin-top:3px}
.chat-msg.out .chat-time{color:rgba(255,255,255,.8);text-align:right}

.chat-input-area{display:flex;gap:6px;padding:12px;border-top:1px solid var(--gris-200);background:#fff}
.chat-input-area input{flex:1;padding:9px 13px;border:1.5px solid var(--gris-200);border-radius:100px;font-size:13.5px;outline:none}
.chat-input-area input:focus{border-color:var(--azul-electrico)}
.chat-input-area button{background:var(--azul-electrico);color:#fff;width:40px;height:40px;border-radius:50%;font-size:18px}

/* Toast */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--azul-marino);color:#fff;padding:12px 22px;border-radius:100px;font-size:14px;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:all .25s;z-index:1000;max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.success{background:#059669}
.toast.error{background:#dc2626}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════ */
@media (max-width:980px){
  .nav-links,.nav-phone{display:none}
  .hamburger{display:flex}
  .nav-actions{gap:8px}
  .hero-inner{grid-template-columns:1fr;gap:30px;text-align:center;padding-bottom:50px}
  .hero-features{margin:0 auto}
  .hero-actions{justify-content:center}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-contact{grid-template-columns:1fr;gap:30px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:26px}
  .stats-inner{grid-template-columns:repeat(2,1fr);gap:18px}
}
@media (max-width:640px){
  .section{padding:50px 0}
  .grid-3,.grid-4{grid-template-columns:1fr}
  .hero-features{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{padding:40px 0 0}
  .hero-content h1{font-size:30px}
  .hero-subtitle{font-size:15px}
  .hero-actions{flex-direction:column;gap:10px}
  .hero-actions .btn-cta{width:100%}
  .btn-cta{padding:10px 16px;font-size:13.5px}
  .btn-cta-lg{padding:12px 20px;font-size:14.5px}
  .nav-actions .btn-cta{padding:8px 14px;font-size:13px}
  .chat-launcher-label{display:none}
  .chat-launcher{padding:14px;border-radius:50%;width:56px;height:56px;justify-content:center}
  .chat-panel{width:calc(100vw - 20px);right:-10px}
  .footer-bottom{flex-direction:column;text-align:center}
  .form-row{grid-template-columns:1fr}
  .stats-inner{grid-template-columns:1fr 1fr}
  .hero-map{height:200px}
  .wa-float{bottom:90px}
}
