/* ══════════════════════════════════════════════════════════════
   WhatsFire — Design System v2.0
   Paleta: Fondo #F9FBFF · Menta #4CAF93 · Azul Profundo #0D2137
   Fuentes: Lexend (títulos) + Inter (cuerpo)
   Modo: CLARO — NO OSCURO
   ══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Lexend:wght@300;400;500;600;700;800&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --bg:           #F9FBFF;
  --surface:      #FFFFFF;
  --surface-2:    #F1F5FB;
  --surface-3:    #EBF0F8;
  --border:       #E4EAF2;
  --border-2:     #D0DAE9;
  --mint:         #4CAF93;
  --mint-dark:    #38A174;
  --mint-darker:  #2A7A57;
  --mint-light:   #E8F5F1;
  --mint-glow:    rgba(76,175,147,.25);
  --blue-deep:    #0D2137;
  --blue-mid:     #1A3A5C;
  --blue-light:   #EEF4FF;
  --blue-accent:  #2563EB;
  --text-1:       #0D2137;
  --text-2:       #4A5568;
  --text-3:       #94A3B8;
  --red:          #EF4444;
  --red-light:    #FEF2F2;
  --yellow:       #F59E0B;
  --yellow-light: #FFFBEB;
  --purple:       #8B5CF6;
  --purple-light: #EDE9FE;
  --shadow-xs:  0 1px 2px rgba(13,33,55,.05);
  --shadow-sm:  0 1px 3px rgba(13,33,55,.07),0 1px 2px rgba(13,33,55,.04);
  --shadow-md:  0 4px 20px rgba(13,33,55,.09),0 2px 6px rgba(13,33,55,.04);
  --shadow-lg:  0 12px 40px rgba(13,33,55,.12),0 4px 12px rgba(13,33,55,.05);
  --shadow-xl:  0 24px 60px rgba(13,33,55,.15),0 8px 20px rgba(13,33,55,.07);
  --shadow-mint: 0 8px 28px rgba(76,175,147,.35);
  --r-xs:  6px; --r-sm: 10px; --r-md: 16px; --r-lg: 24px; --r-xl: 32px;
  --transition: all .2s cubic-bezier(.4,0,.2,1);
  --transition-slow: all .35s cubic-bezier(.4,0,.2,1);
  --max-w: 1280px;
  --nav-h: 68px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text-1);line-height:1.6;min-height:100vh;overflow-x:hidden;}
img{max-width:100%;height:auto;display:block;}
a{color:var(--mint);text-decoration:none;transition:var(--transition);}
a:hover{color:var(--mint-dark);}
h1,h2,h3,h4{font-family:'Lexend',sans-serif;font-weight:700;line-height:1.15;color:var(--blue-deep);}
h1{font-size:clamp(1.85rem,4.5vw,2.75rem);}
h2{font-size:clamp(1.3rem,3vw,1.9rem);}
h3{font-size:1.15rem;}h4{font-size:1rem;}
p{color:var(--text-2);line-height:1.75;}
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:10px;}
::-webkit-scrollbar-thumb:hover{background:var(--mint);}

/* ── NAVBAR ── */
.navbar{background:rgba(255,255,255,.92);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200;padding:0 32px;transition:box-shadow .3s;}
.navbar.scrolled{box-shadow:var(--shadow-md);}
.navbar-inner{max-width:var(--max-w);margin:0 auto;display:flex;align-items:center;gap:20px;height:var(--nav-h);}
.navbar-logo{font-family:'Lexend',sans-serif;font-weight:800;font-size:1.3rem;color:var(--blue-deep);text-decoration:none;display:flex;align-items:center;gap:8px;flex-shrink:0;}
.logo-flame{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#FF7A00,#FF3D00);display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:0 4px 12px rgba(255,80,0,.3);flex-shrink:0;}
.navbar-logo .logo-fire{color:var(--mint);}
.navbar-spacer{flex:1;}
.navbar-nav{display:flex;align-items:center;gap:2px;}
.navbar-nav a{color:var(--text-2);padding:8px 14px;border-radius:var(--r-sm);font-size:.875rem;font-weight:500;transition:var(--transition);}
.navbar-nav a:hover,.navbar-nav a.active{background:var(--mint-light);color:var(--mint-dark);}
.navbar-cta{display:flex;gap:10px;align-items:center;}
.navbar-user{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:500;color:var(--text-2);}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--mint),var(--blue-mid));display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Lexend',sans-serif;font-weight:700;font-size:.85rem;flex-shrink:0;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none;border-radius:var(--r-xs);}
.hamburger span{display:block;width:22px;height:2px;background:var(--blue-deep);border-radius:2px;transition:all .3s;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--r-sm);font-family:'Lexend',sans-serif;font-weight:600;font-size:.9rem;border:none;cursor:pointer;transition:var(--transition);text-decoration:none;white-space:nowrap;line-height:1;}
.btn-primary{background:linear-gradient(135deg,var(--mint) 0%,var(--mint-dark) 100%);color:#fff;box-shadow:var(--shadow-mint);}
.btn-primary:hover{background:linear-gradient(135deg,var(--mint-dark) 0%,var(--mint-darker) 100%);transform:translateY(-2px);box-shadow:0 12px 36px rgba(76,175,147,.45);color:#fff;}
.btn-secondary{background:var(--surface);color:var(--text-1);border:1.5px solid var(--border);}
.btn-secondary:hover{background:var(--surface-2);transform:translateY(-1px);color:var(--text-1);}
.btn-outline-mint{background:transparent;color:var(--mint);border:1.5px solid var(--mint);}
.btn-outline-mint:hover{background:var(--mint-light);transform:translateY(-1px);color:var(--mint-dark);}
.btn-dark{background:var(--blue-deep);color:#fff;}
.btn-dark:hover{background:var(--blue-mid);transform:translateY(-1px);color:#fff;}
.btn-danger{background:var(--red);color:#fff;}
.btn-danger:hover{background:#DC2626;transform:translateY(-1px);color:#fff;}
.btn-nequi{background:linear-gradient(135deg,#8B5CF6,#6D28D9);color:#fff;box-shadow:0 4px 16px rgba(109,40,217,.3);}
.btn-nequi:hover{background:linear-gradient(135deg,#7C3AED,#5B21B6);transform:translateY(-1px);color:#fff;}
.btn-bancolombia{background:linear-gradient(135deg,#FFCC00,#F0B500);color:#1A1A1A;box-shadow:0 4px 16px rgba(240,181,0,.3);}
.btn-bancolombia:hover{background:linear-gradient(135deg,#FFDD00,#F0C000);transform:translateY(-1px);color:#1A1A1A;}
.btn-wa{background:linear-gradient(135deg,#25D366,#128C7E);color:#fff;box-shadow:0 4px 16px rgba(37,211,102,.3);}
.btn-wa:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(37,211,102,.4);color:#fff;}
.btn-lg{padding:16px 36px;font-size:1rem;border-radius:var(--r-md);}
.btn-sm{padding:8px 16px;font-size:.8rem;}
.btn-xs{padding:6px 12px;font-size:.75rem;}
.btn-full{width:100%;justify-content:center;}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important;box-shadow:none!important;}

/* ── CARDS ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-sm);transition:var(--transition-slow);}
.card:hover{box-shadow:var(--shadow-md);}
.card-header{margin-bottom:20px;}
.card-title{font-family:'Lexend',sans-serif;font-weight:700;font-size:1rem;color:var(--blue-deep);}
.card-subtitle{font-size:.8rem;color:var(--text-3);margin-top:2px;}
.card-accent{border-top:3px solid var(--mint);}
.card-mint{background:var(--mint-light);border-color:rgba(76,175,147,.25);}

/* ── BENTO GRID ── */
.bento-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px;}
.bento-1{grid-column:span 3;}.bento-2{grid-column:span 4;}.bento-3{grid-column:span 6;}
.bento-4{grid-column:span 8;}.bento-5{grid-column:span 9;}.bento-full{grid-column:span 12;}
@media(max-width:1024px){.bento-1,.bento-2{grid-column:span 6;}.bento-3{grid-column:span 12;}.bento-4,.bento-5{grid-column:span 12;}}
@media(max-width:640px){.bento-grid{grid-template-columns:1fr;gap:16px;}.bento-1,.bento-2,.bento-3,.bento-4,.bento-5,.bento-full{grid-column:span 1;}}

/* ── APP LAYOUT ── */
.app-layout{display:flex;min-height:calc(100vh - var(--nav-h));}
.sidebar{width:240px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);padding:24px 16px;position:sticky;top:var(--nav-h);height:calc(100vh - var(--nav-h));overflow-y:auto;}
.sidebar-section{margin-bottom:28px;}
.sidebar-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);padding:0 12px;margin-bottom:8px;}
.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-sm);color:var(--text-2);font-size:.875rem;font-weight:500;transition:var(--transition);text-decoration:none;margin-bottom:2px;}
.sidebar-link:hover{background:var(--surface-2);color:var(--text-1);}
.sidebar-link.active{background:var(--mint-light);color:var(--mint-dark);font-weight:600;}
.sidebar-link .icon{width:18px;text-align:center;font-size:1rem;}
.main-content{flex:1;padding:32px;max-width:100%;overflow-x:hidden;}

/* ── FORMS ── */
.form-group{margin-bottom:20px;}
.form-label{display:block;margin-bottom:6px;font-family:'Lexend',sans-serif;font-weight:600;font-size:.85rem;color:var(--blue-deep);}
.form-control{width:100%;padding:12px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:.925rem;color:var(--text-1);transition:var(--transition);font-family:'Inter',sans-serif;}
.form-control:focus{outline:none;border-color:var(--mint);box-shadow:0 0 0 3px rgba(76,175,147,.15);background:#fff;}
.form-control::placeholder{color:var(--text-3);}
.form-hint{font-size:.78rem;color:var(--text-3);margin-top:5px;}
.form-error{font-size:.78rem;color:var(--red);margin-top:5px;}
.pwd-wrap{position:relative;}
.pwd-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-3);font-size:1rem;transition:var(--transition);}
.pwd-toggle:hover{color:var(--text-2);}
.strength-bar{height:4px;border-radius:4px;background:var(--border);overflow:hidden;margin-top:6px;}
.strength-fill{height:100%;border-radius:4px;transition:all .4s ease;width:0;}
.plan-sel{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px;}
.plan-opt{padding:12px 8px;border-radius:var(--r-sm);border:1.5px solid var(--border);cursor:pointer;text-align:center;transition:var(--transition);background:var(--bg);}
.plan-opt:hover{border-color:var(--mint);}
.plan-opt.sel{border-color:var(--mint);background:var(--mint-light);}
.po-name{font-size:.78rem;font-weight:700;color:var(--blue-deep);}
.po-price{font-size:.7rem;color:var(--text-3);}

/* ── ALERTS ── */
.alert{padding:14px 18px;border-radius:var(--r-sm);font-size:.875rem;margin-bottom:20px;display:flex;align-items:flex-start;gap:10px;animation:slideDown .3s ease;}
.alert-success{background:#F0FDF4;border:1px solid #BBF7D0;color:#166534;}
.alert-error{background:var(--red-light);border:1px solid #FECACA;color:#991B1B;}
.alert-warning{background:var(--yellow-light);border:1px solid #FDE68A;color:#92400E;}
.alert-info{background:var(--blue-light);border:1px solid #BFDBFE;color:#1E40AF;}
.msg-box{padding:11px 15px;border-radius:var(--r-sm);margin-bottom:12px;font-size:.84rem;font-weight:500;display:none;gap:8px;align-items:flex-start;}
.msg-box.success{background:var(--mint-light);border:1px solid rgba(76,175,147,.3);color:var(--mint-darker);display:flex;}
.msg-box.error{background:var(--red-light);border:1px solid #FECACA;color:#991B1B;display:flex;}
.msg-box.info{background:var(--blue-light);border:1px solid #BFDBFE;color:#1E40AF;display:flex;}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px);}to{opacity:1;transform:translateY(0);}}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:50px;font-size:.75rem;font-weight:700;font-family:'Lexend',sans-serif;}
.badge-green{background:#D1FAE5;color:#065F46;}
.badge-red{background:#FEE2E2;color:#991B1B;}
.badge-yellow{background:#FEF3C7;color:#92400E;}
.badge-blue{background:var(--blue-light);color:var(--blue-mid);}
.badge-gray{background:var(--surface-2);color:var(--text-2);}
.badge-mint{background:var(--mint-light);color:var(--mint-dark);}
.badge-purple{background:var(--purple-light);color:var(--purple);}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor;}

/* ── STAT CARD ── */
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-sm);}
.stat-label{font-size:.78rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;}
.stat-value{font-family:'Lexend',sans-serif;font-size:2rem;font-weight:800;color:var(--blue-deep);line-height:1;}
.stat-sub{font-size:.8rem;color:var(--text-3);margin-top:6px;}
.stat-icon{font-size:2rem;margin-bottom:12px;}
.stat-trend-up{color:#16A34A;font-size:.78rem;font-weight:600;}
.stat-trend-down{color:var(--red);font-size:.78rem;font-weight:600;}

/* ── PROGRESS ── */
.progress-bar{background:var(--border);border-radius:50px;height:8px;overflow:hidden;}
.progress-fill{height:100%;border-radius:50px;background:linear-gradient(90deg,var(--mint),var(--mint-dark));transition:width .5s ease;}
.progress-sm{height:5px;}.progress-lg{height:12px;}

/* ── TABLE ── */
.table-wrap{overflow-x:auto;border-radius:var(--r-md);border:1px solid var(--border);}
table{width:100%;border-collapse:collapse;}
thead tr{background:var(--surface-2);}
th{padding:12px 16px;text-align:left;font-family:'Lexend',sans-serif;font-weight:700;font-size:.78rem;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);}
td{padding:12px 16px;font-size:.875rem;color:var(--text-2);border-bottom:1px solid var(--border);}
tr:last-child td{border-bottom:none;}
tbody tr{transition:var(--transition);}
tbody tr:hover{background:var(--surface-2);}

/* ── LICENSE ── */
.license-box{background:var(--blue-deep);border-radius:var(--r-md);padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.license-key-text{font-family:'Courier New',monospace;font-size:1.1rem;font-weight:700;color:var(--mint);letter-spacing:2px;}
.license-copy-btn{background:rgba(76,175,147,.2);border:1px solid rgba(76,175,147,.4);color:var(--mint);border-radius:var(--r-sm);padding:8px 16px;font-size:.8rem;cursor:pointer;transition:var(--transition);font-weight:600;font-family:'Lexend',sans-serif;}
.license-copy-btn:hover{background:rgba(76,175,147,.35);}

/* ── DOWNLOAD HERO (dashboard) ── */
.download-hero{background:linear-gradient(135deg,var(--blue-deep) 0%,var(--blue-mid) 100%);border-radius:var(--r-xl);padding:40px;color:#fff;position:relative;overflow:hidden;}
.download-hero::after{content:'🔥';position:absolute;right:32px;top:50%;transform:translateY(-50%);font-size:6rem;opacity:.08;}
.download-hero h2{color:#fff;font-size:1.5rem;margin-bottom:8px;}
.download-hero p{color:rgba(255,255,255,.75);margin-bottom:24px;font-size:.9rem;}

/* ── DEVICE CARD ── */
.device-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px 24px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.device-icon{font-size:2rem;flex-shrink:0;}
.device-info{flex:1;min-width:0;}
.device-name{font-family:'Lexend',sans-serif;font-weight:600;font-size:.9rem;color:var(--blue-deep);}
.device-meta{font-size:.78rem;color:var(--text-3);margin-top:2px;font-family:'Courier New',monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

/* ── AUTH PAGES ── */
.auth-page{min-height:100vh;display:flex;background:linear-gradient(135deg,#EEF4FF 0%,var(--bg) 50%,#E8F5F1 100%);}
.auth-left{flex:1;background:var(--blue-deep);display:flex;flex-direction:column;justify-content:center;padding:60px;position:relative;overflow:hidden;}
.auth-left::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:rgba(76,175,147,.15);}
.auth-left::after{content:'';position:absolute;bottom:-80px;left:-80px;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.04);}
.auth-brand{position:relative;z-index:1;margin-bottom:48px;}
.auth-brand-logo{font-family:'Lexend',sans-serif;font-weight:800;font-size:2rem;color:#fff;margin-bottom:8px;}
.auth-brand-logo span{color:var(--mint);}
.auth-tagline{color:rgba(255,255,255,.65);font-size:1rem;line-height:1.6;}
.auth-features{position:relative;z-index:1;}
.auth-feature{display:flex;align-items:center;gap:14px;margin-bottom:20px;}
.auth-feature-icon{width:44px;height:44px;border-radius:12px;background:rgba(76,175,147,.2);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
.auth-feature-text h4{color:#fff;font-size:.9rem;margin-bottom:2px;}
.auth-feature-text p{color:rgba(255,255,255,.55);font-size:.8rem;}
.auth-right{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;}
.auth-card{background:var(--surface);border-radius:var(--r-xl);padding:48px;width:100%;max-width:480px;box-shadow:var(--shadow-lg);}
.auth-card h2{margin-bottom:6px;}
.auth-card .auth-sub{color:var(--text-3);font-size:.9rem;margin-bottom:32px;}

/* ── PRICING CARDS ── */
.pricing-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--r-xl);padding:36px 32px;transition:var(--transition-slow);position:relative;}
.pricing-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.pricing-card.popular{border-color:var(--mint);box-shadow:0 0 0 4px rgba(76,175,147,.1),var(--shadow-md);}
.popular-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--mint),var(--mint-dark));color:#fff;font-family:'Lexend',sans-serif;font-weight:700;font-size:.75rem;padding:5px 18px;border-radius:50px;white-space:nowrap;}
.pricing-price{font-family:'Lexend',sans-serif;margin:16px 0;}
.pricing-amount{font-size:3rem;font-weight:800;color:var(--blue-deep);line-height:1;}
.pricing-currency{font-size:1.25rem;font-weight:600;color:var(--text-3);}
.pricing-period{font-size:.875rem;color:var(--text-3);}
.pricing-usd{font-size:.78rem;color:var(--text-3);margin-bottom:20px;}
.pricing-features{margin:24px 0;}
.pricing-feature{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:.875rem;color:var(--text-2);border-bottom:1px solid var(--border);}
.pricing-feature:last-child{border-bottom:none;}
.pricing-feature .check{color:var(--mint);font-weight:700;}
.pricing-feature .cross{color:var(--text-3);}
.pricing-pay-label{font-size:.7rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;text-align:center;}
.pricing-divider{display:flex;align-items:center;gap:10px;margin:10px 0;}
.pricing-divider::before,.pricing-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.pricing-divider span{font-size:.7rem;color:var(--text-3);white-space:nowrap;}

/* ── PAYMENT BANNER ── */
.payment-banner{margin-top:40px;padding:22px 28px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:20px;}
.payment-banner-label{font-size:.75rem;color:var(--text-3);text-align:center;width:100%;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:2px;}
.pay-method-pill{display:flex;align-items:center;gap:10px;padding:10px 20px;background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r-md);transition:var(--transition);}
.pay-method-pill:hover{border-color:var(--mint);background:var(--mint-light);}
.pay-method-pill .pm-icon{font-size:1.5rem;}
.pay-method-pill .pm-name{font-family:'Lexend',sans-serif;font-weight:700;font-size:.88rem;color:var(--blue-deep);}
.pay-method-pill .pm-sub{font-size:.68rem;color:var(--text-3);margin-top:1px;}
.payment-banner-note{font-size:.72rem;color:var(--text-3);text-align:center;width:100%;margin-top:6px;}

/* ── MODALS ── */
.modal-overlay{position:fixed;inset:0;z-index:500;background:rgba(13,33,55,.5);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;padding:20px;}
.modal-overlay.active{opacity:1;pointer-events:all;}
.modal{background:var(--surface);border-radius:var(--r-xl);width:100%;max-width:480px;max-height:92vh;overflow-y:auto;padding:40px;box-shadow:var(--shadow-xl);position:relative;border:1px solid var(--border);transform:translateY(16px) scale(.98);transition:transform .3s;}
.modal-overlay.active .modal{transform:translateY(0) scale(1);}
.modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:var(--r-xs);background:var(--surface-2);border:1px solid var(--border);cursor:pointer;font-size:.9rem;color:var(--text-3);display:flex;align-items:center;justify-content:center;transition:var(--transition);}
.modal-close:hover{background:var(--red-light);color:var(--red);border-color:#FECACA;}
.modal-title{font-family:'Lexend',sans-serif;font-weight:800;font-size:1.4rem;color:var(--blue-deep);margin-bottom:5px;}
.modal-sub{font-size:.85rem;color:var(--text-3);margin-bottom:26px;}
.modal-tabs{display:flex;gap:4px;background:var(--surface-2);border-radius:var(--r-sm);padding:4px;margin-bottom:24px;}
.modal-tab{flex:1;padding:9px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--text-3);transition:var(--transition);font-family:'Lexend',sans-serif;}
.modal-tab.active{background:var(--surface);color:var(--blue-deep);box-shadow:var(--shadow-sm);}
.spinner{width:16px;height:16px;border:2.5px solid rgba(255,255,255,.35);border-top-color:white;border-radius:50%;animation:spin .7s linear infinite;display:none;flex-shrink:0;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── PAY MODAL INNER ── */
.pay-total-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:18px;}
.pay-total-label{font-size:.87rem;color:var(--text-2);}
.pay-total-val{font-family:'Lexend',sans-serif;font-size:1.25rem;font-weight:800;color:var(--blue-deep);}
.pay-method-tabs{display:flex;gap:8px;margin-bottom:16px;}
.pmt-tab{flex:1;padding:10px;border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--bg);color:var(--text-2);font-size:.82rem;font-weight:600;cursor:pointer;font-family:'Lexend',sans-serif;transition:var(--transition);text-align:center;}
.pmt-tab.active{border-color:var(--mint);background:var(--mint-light);color:var(--mint-dark);}
.nequi-box{background:linear-gradient(135deg,#F5F3FF,#EDE9FE);border:1px solid #C4B5FD;border-radius:var(--r-md);padding:20px;}
.nequi-key{font-family:'Courier New',monospace;font-size:1.3rem;font-weight:800;color:#5B21B6;text-align:center;padding:12px;background:#fff;border-radius:var(--r-sm);border:2px dashed #C4B5FD;margin:12px 0;letter-spacing:.04em;}
.nequi-steps{list-style:none;}
.nequi-steps li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;font-size:.84rem;color:#4C1D95;border-bottom:1px solid #EDE9FE;}
.nequi-steps li:last-child{border-bottom:none;}
.nequi-step-num{width:22px;height:22px;border-radius:50%;background:#7C3AED;color:white;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-family:'Lexend',sans-serif;}
.bancolombia-box{background:linear-gradient(135deg,#FFFBEB,#FEF3C7);border:1px solid #FDE68A;border-radius:var(--r-md);padding:20px;}
.bancolombia-key{font-family:'Courier New',monospace;font-size:1.1rem;font-weight:800;color:#92400E;text-align:center;padding:12px;background:#fff;border-radius:var(--r-sm);border:2px dashed #FDE68A;margin:12px 0;letter-spacing:.04em;}
.bancolombia-steps{list-style:none;}
.bancolombia-steps li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;font-size:.84rem;color:#78350F;border-bottom:1px solid #FDE68A;}
.bancolombia-steps li:last-child{border-bottom:none;}
.bancolombia-step-num{width:22px;height:22px;border-radius:50%;background:#B45309;color:white;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-family:'Lexend',sans-serif;}
.btn-copy{padding:6px 14px;border-radius:var(--r-xs);border:1.5px solid var(--border-2);background:var(--surface);color:var(--text-2);font-size:.78rem;font-weight:600;cursor:pointer;transition:var(--transition);font-family:'Lexend',sans-serif;}
.btn-copy:hover{background:var(--mint);color:#fff;border-color:var(--mint);}

/* ── LANDING HERO ── */
.hero-section{min-height:calc(100vh - var(--nav-h));display:flex;align-items:center;padding:80px 32px;position:relative;overflow:hidden;}
.hero-bg-grid{position:absolute;inset:0;z-index:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:56px 56px;opacity:.5;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 80%);}
.hero-glow{position:absolute;z-index:0;border-radius:50%;pointer-events:none;}
.hero-glow-1{width:600px;height:600px;top:-10%;left:-15%;background:radial-gradient(circle,rgba(76,175,147,.1) 0%,transparent 65%);}
.hero-glow-2{width:500px;height:500px;bottom:-10%;right:-10%;background:radial-gradient(circle,rgba(37,99,235,.07) 0%,transparent 65%);}
.hero-inner{position:relative;z-index:1;max-width:var(--max-w);margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--mint-light);color:var(--mint-dark);font-size:.74rem;font-weight:700;padding:5px 14px;border-radius:100px;margin-bottom:22px;border:1px solid rgba(76,175,147,.3);letter-spacing:.05em;text-transform:uppercase;}
.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--mint);animation:blink 1.5s ease-in-out infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.hero-title{font-family:'Lexend',sans-serif;font-size:clamp(2rem,4.5vw,3rem);font-weight:800;line-height:1.08;color:var(--blue-deep);margin-bottom:20px;}
.hero-title .accent{color:var(--mint);}
.hero-title .accent-blue{color:var(--blue-accent);}
.hero-desc{font-size:1.05rem;color:var(--text-2);margin-bottom:36px;max-width:500px;line-height:1.78;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px;}
.hero-stats{display:flex;gap:36px;}
.hs-num{font-family:'Lexend',sans-serif;font-size:1.6rem;font-weight:800;color:var(--blue-deep);line-height:1;}
.hs-num .hn-accent{color:var(--mint);}
.hs-lbl{font-size:.75rem;color:var(--text-3);margin-top:3px;}
.hero-divider{width:1px;background:var(--border);height:40px;margin-top:4px;}

/* Hero Mock Card */
.hero-visual{position:relative;}
.mock-card{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-xl);padding:22px;position:relative;overflow:hidden;}
.mock-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--mint),var(--blue-accent));}
.mock-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.mock-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);}
.mock-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:13px;}
.mock-stat{background:var(--surface-2);border-radius:var(--r-sm);padding:13px;border:1px solid var(--border);}
.ms-icon{font-size:1.1rem;margin-bottom:4px;}
.ms-val{font-family:'Lexend',sans-serif;font-weight:700;font-size:1.1rem;color:var(--blue-deep);}
.ms-lbl{font-size:.68rem;color:var(--text-3);margin-top:1px;}
.ms-bar{height:4px;background:var(--border);border-radius:100px;overflow:hidden;margin-top:5px;}
.ms-fill{height:100%;border-radius:100px;background:linear-gradient(90deg,var(--mint),var(--blue-accent));}
.mock-row{display:flex;align-items:center;gap:9px;background:var(--surface-2);border-radius:9px;padding:9px 12px;margin-bottom:6px;border:1px solid var(--border);}
.mock-row:last-child{margin-bottom:0;}
.mr-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.mr-text{font-size:.73rem;color:var(--text-2);flex:1;}
.mr-badge{font-size:.64rem;font-weight:700;padding:2px 8px;border-radius:100px;white-space:nowrap;}
.float-pill{position:absolute;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 13px;box-shadow:var(--shadow-md);font-size:.73rem;font-weight:600;display:flex;align-items:center;gap:7px;white-space:nowrap;color:var(--text-1);z-index:2;}
.fp-top{top:-14px;right:-10px;}
.fp-bot{bottom:-14px;left:-10px;}
.fp-live{width:8px;height:8px;border-radius:50%;background:var(--mint);box-shadow:0 0 8px rgba(76,175,147,.6);animation:blink 1.5s ease-in-out infinite;}

/* ── TRUST BAR ── */
.trust-bar{padding:20px 32px;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.trust-inner{max-width:var(--max-w);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.trust-item{display:flex;align-items:center;gap:9px;font-size:.83rem;color:var(--text-2);}
.trust-item strong{color:var(--text-1);font-family:'Lexend',sans-serif;font-weight:600;}
.trust-icon{font-size:1.15rem;}
.trust-sep{width:1px;height:26px;background:var(--border);}

/* ── SECTIONS ── */
.section{padding:96px 32px;}
.section-alt{background:var(--surface);}
.section-inner{max-width:var(--max-w);margin:0 auto;}
.section-header{margin-bottom:52px;}
.sec-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--mint-dark);display:block;margin-bottom:10px;}
.sec-title{font-family:'Lexend',sans-serif;font-weight:800;font-size:clamp(1.7rem,3vw,2.4rem);color:var(--blue-deep);line-height:1.12;margin-bottom:14px;}
.sec-desc{color:var(--text-2);font-size:1rem;max-width:560px;line-height:1.78;}

/* ── FEATURE GRID ── */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:52px;}
.feature-card{background:var(--surface);border-radius:var(--r-md);border:1px solid var(--border);padding:26px;transition:var(--transition-slow);position:relative;overflow:hidden;}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--border-2);}
.feature-card.span2{grid-column:span 2;}
.feature-card.highlight{border-color:rgba(76,175,147,.35);background:linear-gradient(135deg,var(--mint-light) 0%,var(--surface) 100%);}
.feature-card.blue-hl{border-color:rgba(37,99,235,.2);background:linear-gradient(135deg,#EEF4FF 0%,var(--surface) 100%);}
.feature-icon{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:16px;background:var(--surface-2);border:1px solid var(--border);}
.highlight .feature-icon{background:var(--mint-light);border-color:rgba(76,175,147,.25);}
.blue-hl .feature-icon{background:var(--blue-light);border-color:rgba(37,99,235,.15);}
.feature-title{font-family:'Lexend',sans-serif;font-weight:700;font-size:1.05rem;color:var(--blue-deep);margin-bottom:8px;}
.feature-desc{font-size:.86rem;color:var(--text-2);line-height:1.72;}
.feature-tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 10px;border-radius:100px;margin-top:12px;background:var(--mint-light);color:var(--mint-dark);border:1px solid rgba(76,175,147,.25);}
.feature-tag.blue-tag{background:var(--blue-light);color:var(--blue-mid);border-color:rgba(37,99,235,.15);}
.fp-row{display:flex;gap:8px;align-items:center;margin-bottom:6px;}
.fp-row:last-child{margin-bottom:0;}
.fp-lbl{font-size:.7rem;color:var(--text-3);width:80px;flex-shrink:0;}
.fp-bar{flex:1;height:5px;border-radius:100px;background:var(--border);overflow:hidden;}
.fp-fill{height:100%;border-radius:100px;background:linear-gradient(90deg,var(--mint),var(--blue-accent));}
.fp-pct{font-size:.68rem;color:var(--text-3);width:34px;text-align:right;flex-shrink:0;}
.feature-prog{margin-top:14px;background:var(--surface-2);border-radius:var(--r-sm);padding:12px;border:1px solid var(--border);}
.country-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:12px;}
.cc-chip{font-size:.68rem;padding:3px 9px;background:var(--surface-2);border:1px solid var(--border);border-radius:100px;color:var(--text-2);}

/* ── STEPS ── */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:52px;position:relative;}
.steps-grid::before{content:'';position:absolute;top:28px;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--mint),transparent);z-index:0;}
.step-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:28px 22px;text-align:center;position:relative;z-index:1;transition:var(--transition-slow);}
.step-card:hover{transform:translateY(-4px);border-color:rgba(76,175,147,.35);box-shadow:var(--shadow-md);}
.step-num{width:52px;height:52px;border-radius:50%;background:var(--surface);border:2px solid var(--mint);display:flex;align-items:center;justify-content:center;font-family:'Lexend',sans-serif;font-weight:800;font-size:1.1rem;color:var(--mint);margin:0 auto 16px;box-shadow:0 0 0 4px rgba(76,175,147,.1);}
.step-title{font-family:'Lexend',sans-serif;font-weight:700;font-size:.95rem;color:var(--blue-deep);margin-bottom:8px;}
.step-desc{font-size:.82rem;color:var(--text-2);line-height:1.68;}

/* ── TESTIMONIALS ── */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px;}
.testimonial-card{background:var(--surface);border-radius:var(--r-md);border:1px solid var(--border);padding:26px;transition:var(--transition-slow);}
.testimonial-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.tc-stars{color:#FBBF24;font-size:.95rem;letter-spacing:2px;margin-bottom:14px;}
.tc-text{font-size:.875rem;color:var(--text-2);line-height:1.78;margin-bottom:20px;font-style:italic;}
.tc-author{display:flex;align-items:center;gap:12px;}
.tc-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--mint),var(--blue-mid));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;flex-shrink:0;font-family:'Lexend',sans-serif;}
.tc-name{font-family:'Lexend',sans-serif;font-size:.84rem;font-weight:600;color:var(--blue-deep);}
.tc-role{font-size:.73rem;color:var(--text-3);margin-top:1px;}

/* ── FAQ ── */
.faq-list{margin-top:44px;max-width:800px;}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:8px;overflow:hidden;transition:var(--transition);}
.faq-item:hover{border-color:var(--border-2);}
.faq-item.open{border-color:rgba(76,175,147,.4);}
.faq-q{padding:18px 22px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:500;color:var(--text-1);user-select:none;font-size:.93rem;transition:background .2s;}
.faq-q:hover{background:var(--surface-2);}
.faq-arr{transition:transform .3s;color:var(--text-3);font-size:.75rem;flex-shrink:0;}
.faq-item.open .faq-arr{transform:rotate(180deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s;padding:0 22px;font-size:.875rem;color:var(--text-2);line-height:1.78;}
.faq-item.open .faq-a{max-height:280px;padding:0 22px 18px;}

/* ── DOWNLOAD CTA ── */
.dl-cta-box{background:linear-gradient(135deg,var(--blue-deep) 0%,var(--blue-mid) 100%);border-radius:var(--r-xl);padding:52px 56px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center;position:relative;overflow:hidden;}
.dl-cta-box::before{content:'';position:absolute;top:-100px;right:-100px;width:350px;height:350px;border-radius:50%;background:radial-gradient(circle,rgba(76,175,147,.15) 0%,transparent 70%);pointer-events:none;}
.dl-cta-box::after{content:'🔥';position:absolute;right:240px;top:50%;transform:translateY(-50%);font-size:5rem;opacity:.06;pointer-events:none;}
.dl-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mint);display:block;margin-bottom:10px;}
.dl-title{font-family:'Lexend',sans-serif;font-size:clamp(1.6rem,2.5vw,2.1rem);font-weight:800;color:#fff;margin-bottom:12px;}
.dl-desc{color:rgba(255,255,255,.7);font-size:.93rem;margin-bottom:22px;line-height:1.75;max-width:520px;}
.dl-tags{display:flex;flex-wrap:wrap;gap:10px;}
.dl-tag{display:flex;align-items:center;gap:6px;font-size:.76rem;color:rgba(255,255,255,.65);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-xs);padding:5px 12px;font-weight:500;}
.btn-dl{display:flex;flex-direction:column;align-items:center;gap:6px;background:linear-gradient(135deg,var(--mint),var(--mint-dark));color:#fff;padding:18px 38px;border-radius:var(--r-md);font-family:'Lexend',sans-serif;font-weight:800;font-size:1rem;border:none;cursor:pointer;box-shadow:var(--shadow-mint);transition:var(--transition-slow);white-space:nowrap;position:relative;z-index:1;}
.btn-dl:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(76,175,147,.55);background:linear-gradient(135deg,var(--mint-dark),var(--mint-darker));}
.btn-dl-sub{font-size:.7rem;font-weight:400;opacity:.8;font-family:'Inter',sans-serif;}

/* ── FOOTER ── */
.footer{background:var(--blue-deep);color:rgba(255,255,255,.6);padding:60px 32px 28px;}
.footer-in{max-width:var(--max-w);margin:0 auto;}
.footer-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:48px;margin-bottom:44px;}
.footer-brand-name{font-family:'Lexend',sans-serif;font-weight:800;font-size:1.3rem;color:#fff;display:flex;align-items:center;gap:9px;margin-bottom:12px;}
.footer-brand-desc{font-size:.82rem;line-height:1.78;}
.footer-wa{display:inline-flex;align-items:center;gap:7px;color:var(--mint);font-size:.82rem;font-weight:600;margin-top:14px;transition:var(--transition);}
.footer-wa:hover{color:var(--mint-dark);}
.footer-col-title{font-family:'Lexend',sans-serif;font-weight:700;color:#fff;font-size:.82rem;margin-bottom:14px;letter-spacing:.05em;text-transform:uppercase;}
.footer-col ul{list-style:none;}
.footer-col li{margin-bottom:9px;}
.footer-col a{color:rgba(255,255,255,.55);font-size:.82rem;transition:var(--transition);cursor:pointer;}
.footer-col a:hover{color:var(--mint);}
.footer-bot{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;display:flex;justify-content:space-between;align-items:center;font-size:.75rem;flex-wrap:wrap;gap:10px;}
.footer-badges{display:flex;gap:8px;flex-wrap:wrap;}
.footer-badge{padding:3px 10px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:100px;font-size:.68rem;color:rgba(255,255,255,.5);}

/* ── EVA ASISTENTE ── */
#eva-container{position:fixed;bottom:28px;right:28px;z-index:999;display:flex;flex-direction:column;align-items:flex-end;gap:12px;}
#eva-btn{width:64px;height:64px;border-radius:50%;border:none;cursor:pointer;background:linear-gradient(135deg,var(--blue-deep),var(--blue-mid));box-shadow:0 0 0 3px rgba(76,175,147,.4),var(--shadow-lg);position:relative;transition:var(--transition-slow);flex-shrink:0;display:flex;align-items:center;justify-content:center;}
#eva-btn:hover{transform:scale(1.08);box-shadow:0 0 0 4px rgba(76,175,147,.55),0 12px 40px rgba(76,175,147,.25);}
#eva-btn.active{box-shadow:0 0 0 4px rgba(76,175,147,.6),0 12px 40px rgba(76,175,147,.3);}
.eva-face{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#0D2A4E,var(--blue-deep));border:2px solid rgba(76,175,147,.5);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.eva-visor{width:30px;height:12px;background:var(--mint);border-radius:100px;box-shadow:0 0 10px var(--mint-glow),inset 0 0 6px rgba(255,255,255,.3);animation:eva-scan 2.5s ease-in-out infinite;}
@keyframes eva-scan{0%,100%{box-shadow:0 0 10px var(--mint-glow),inset 0 0 6px rgba(255,255,255,.3);}50%{box-shadow:0 0 20px rgba(76,175,147,.8),inset 0 0 10px rgba(255,255,255,.5);}}
.eva-orbit{position:absolute;top:-5px;right:-5px;width:18px;height:18px;border-radius:50%;background:var(--mint);border:2px solid #fff;display:flex;align-items:center;justify-content:center;font-size:.6rem;animation:blink 2s ease-in-out infinite;}
#eva-panel{width:340px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xl);display:none;flex-direction:column;max-height:490px;animation:eva-open .3s ease;}
@keyframes eva-open{from{opacity:0;transform:translateY(10px) scale(.97);}to{opacity:1;transform:translateY(0) scale(1);}}
#eva-panel.open{display:flex;}
.eva-header{background:linear-gradient(135deg,var(--blue-deep),var(--blue-mid));padding:14px 18px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;}
.eva-header-face{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#0D2A4E,var(--blue-deep));border:1.5px solid rgba(76,175,147,.5);flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.eva-header-visor{width:20px;height:8px;background:var(--mint);border-radius:100px;box-shadow:0 0 8px var(--mint-glow);animation:eva-scan 2.5s ease-in-out infinite;}
.eva-header-info .eva-name{font-family:'Lexend',sans-serif;font-weight:800;font-size:.9rem;color:#fff;}
.eva-header-info .eva-status{font-size:.72rem;color:var(--mint);display:flex;align-items:center;gap:5px;}
.eva-header-info .eva-status::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--mint);display:inline-block;box-shadow:0 0 6px var(--mint);animation:blink 1.5s ease-in-out infinite;}
.eva-header button{margin-left:auto;background:none;border:none;color:rgba(255,255,255,.55);cursor:pointer;font-size:1rem;transition:var(--transition);}
.eva-header button:hover{color:#fff;}
.eva-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;}
.eva-messages::-webkit-scrollbar{width:4px;}
.eva-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px;}
.eva-msg{display:flex;gap:8px;align-items:flex-end;}
.eva-msg.user{flex-direction:row-reverse;}
.eva-bubble{max-width:76%;padding:9px 13px;border-radius:14px;font-size:.82rem;line-height:1.62;word-break:break-word;}
.eva-msg.bot .eva-bubble{background:var(--surface-2);color:var(--text-1);border:1px solid var(--border);border-radius:4px 14px 14px 14px;}
.eva-msg.user .eva-bubble{background:var(--mint);color:#fff;border-radius:14px 4px 14px 14px;font-weight:500;}
.eva-avatar-wrap{width:26px;height:26px;flex-shrink:0;}
.eva-avatar-face{width:100%;height:100%;background:linear-gradient(135deg,var(--blue-mid),var(--blue-deep));border:1.5px solid rgba(76,175,147,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.eva-avatar-visor{width:13px;height:5px;background:var(--mint);border-radius:100px;box-shadow:0 0 4px var(--mint);}
.eva-typing{display:flex;gap:4px;align-items:center;padding:9px 13px;}
.eva-typing span{width:7px;height:7px;border-radius:50%;background:var(--text-3);animation:t-bounce .8s ease-in-out infinite;}
.eva-typing span:nth-child(2){animation-delay:.15s;}
.eva-typing span:nth-child(3){animation-delay:.3s;}
@keyframes t-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px);background:var(--mint);}}
.eva-quick{padding:0 14px 10px;display:flex;flex-wrap:wrap;gap:6px;}
.eva-qb{font-size:.72rem;padding:5px 11px;border-radius:100px;background:var(--mint-light);border:1px solid rgba(76,175,147,.25);color:var(--mint-dark);cursor:pointer;font-family:'Lexend',sans-serif;transition:var(--transition);font-weight:600;}
.eva-qb:hover{background:rgba(76,175,147,.2);color:var(--mint-darker);}
.eva-input-row{padding:12px 14px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0;}
.eva-input{flex:1;padding:9px 14px;border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--bg);color:var(--text-1);font-family:'Inter',sans-serif;font-size:.84rem;outline:none;transition:var(--transition);}
.eva-input:focus{border-color:var(--mint);background:var(--surface);box-shadow:0 0 0 3px rgba(76,175,147,.12);}
.eva-input::placeholder{color:var(--text-3);}
.eva-send{width:36px;height:36px;border-radius:var(--r-sm);background:var(--mint);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:var(--transition);flex-shrink:0;}
.eva-send:hover{background:var(--mint-dark);transform:scale(1.05);}
.eva-notification{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 16px;font-size:.8rem;color:var(--text-1);max-width:260px;box-shadow:var(--shadow-lg);animation:eva-open .4s ease;display:none;line-height:1.6;cursor:pointer;}
.eva-notification.show{display:block;}
.eva-notif-name{font-family:'Lexend',sans-serif;font-weight:700;color:var(--mint-dark);font-size:.82rem;display:flex;align-items:center;gap:6px;margin-bottom:4px;}

/* ── FADE UP ── */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .hero-section,.section,.trust-bar{padding-left:24px;padding-right:24px;}
  .hero-inner{grid-template-columns:1fr;gap:48px;}
  .hero-visual{display:none;}
  .feature-grid{grid-template-columns:1fr 1fr;}
  .feature-card.span2{grid-column:1;}
  .steps-grid{grid-template-columns:1fr 1fr;}
  .steps-grid::before{display:none;}
  .testimonials-grid{grid-template-columns:1fr;max-width:520px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px;}
  .dl-cta-box{grid-template-columns:1fr;padding:40px 32px;gap:28px;}
  .dl-cta-box::after{display:none;}
}
@media(max-width:768px){
  .navbar{padding:0 16px;}
  .navbar-nav{display:none;}
  .hamburger{display:flex;}
  .navbar-nav.open{display:flex;flex-direction:column;position:fixed;top:var(--nav-h);left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);padding:12px 16px;gap:2px;box-shadow:var(--shadow-md);z-index:199;}
  .navbar-nav.open a{color:var(--text-1);padding:12px 16px;}
  .hero-section{padding:60px 20px;}
  .section{padding:60px 20px;}
  .trust-bar{padding:16px 20px;}
  .trust-sep{display:none;}
  .trust-inner{justify-content:center;gap:12px;}
  .feature-grid{grid-template-columns:1fr;}
  .hero-stats{gap:24px;}
  .footer-top{grid-template-columns:1fr;}
  .dl-cta-box{padding:32px 24px;}
  .auth-left{display:none;}
  .auth-card{padding:32px 24px;}
  .app-layout{flex-direction:column;}
  .sidebar{width:100%;height:auto;position:static;display:flex;padding:12px 16px;overflow-x:auto;gap:4px;border-right:none;border-bottom:1px solid var(--border);}
  .sidebar-section{margin-bottom:0;display:flex;gap:4px;}
  .sidebar-label{display:none;}
  .sidebar-link{white-space:nowrap;padding:8px 12px;}
  .main-content{padding:20px 16px;}
  #eva-container{bottom:16px;right:16px;}
  #eva-panel{width:300px;}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .hero-section{padding:50px 14px;}
  .section{padding:50px 14px;}
  .hero-stats{gap:14px;}
  .hs-num{font-size:1.35rem;}
  .license-key-text{font-size:.85rem;letter-spacing:1px;}
  .stat-value{font-size:1.5rem;}
  .pricing-amount{font-size:2.5rem;}
  .modal{padding:24px 16px;}
  .auth-card{padding:26px 18px;}
  .dl-cta-box{padding:26px 18px;}
}

/* ── UTILITIES ── */
.text-center{text-align:center;}.text-muted{color:var(--text-3);}.text-mint{color:var(--mint);}.text-blue{color:var(--blue-deep);}
.mt-1{margin-top:8px;}.mt-2{margin-top:16px;}.mt-3{margin-top:24px;}.mt-4{margin-top:32px;}
.mb-1{margin-bottom:8px;}.mb-2{margin-bottom:16px;}.mb-3{margin-bottom:24px;}.mb-4{margin-bottom:32px;}
.flex{display:flex;}.flex-center{display:flex;align-items:center;}.flex-between{display:flex;align-items:center;justify-content:space-between;}
.gap-1{gap:8px;}.gap-2{gap:16px;}.gap-3{gap:24px;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.page-header{margin-bottom:32px;}.page-header h1{font-size:1.75rem;}.page-header p{color:var(--text-3);margin-top:6px;}
.divider{height:1px;background:var(--border);margin:24px 0;}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
/* ══════════════════════════════════════════════════════════════
   WhatsFire — Adiciones al Design System
   Complementa app.css existente con nuevos tokens y clases
   ══════════════════════════════════════════════════════════════ */

/* ── Fuente actualizada a Plus Jakarta Sans ── */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Inter:wght@400;500;600&display=swap');

h1,h2,h3,h4,.btn,.card-title,.sidebar-label,.stat-value,.license-key-text,.badge,
.auth-brand-logo,.navbar-logo,.pricing-amount,.plan-price-cop {
  font-family: 'Plus Jakarta Sans', sans-serif;
}

/* ── Navbar logo imagen ── */
.navbar-logo-img {
  height: 34px;
  width: auto;
  object-fit: contain;
  border-radius: 6px;
}
.navbar-logo-text {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800;
  font-size: 1.25rem;
  color: var(--blue-deep);
  display: flex;
  align-items: center;
  gap: 4px;
}

/* ── Auth brand logo imagen ── */
.auth-brand-logo-img {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
}

/* ── Sidebar bottom support box ── */
.sidebar-bottom {
  margin-top: auto !important;
}
.support-box {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px;
  background: var(--surface-2);
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
}

/* ── Stat icon wrap (reemplaza emoji stat-icon) ── */
.stat-icon-wrap {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
  flex-shrink: 0;
}

/* ── Device icon wrap ── */
.device-icon-wrap {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: var(--surface-2);
}
.device-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  transition: var(--transition);
}
.device-card:hover { border-color: var(--mint); box-shadow: var(--shadow-sm); }
.device-card.revoked { opacity: .55; }
.device-dates {
  font-size: .75rem;
  color: var(--text-3);
  margin-top: 4px;
}

/* ── Download hero ── */
.download-hero {
  background: linear-gradient(135deg, var(--blue-deep) 0%, var(--blue-mid) 100%);
  border-radius: var(--r-xl);
  padding: 40px;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.download-hero::before {
  content: '';
  position: absolute;
  top: -80px;
  right: -80px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: rgba(76, 175, 147, .12);
  pointer-events: none;
}
.download-hero--inactive {
  background: linear-gradient(135deg, #334155, #475569);
}
.download-hero-body { position: relative; z-index: 1; }
.download-hero h2 { color: #fff; font-size: 1.5rem; margin-bottom: 8px; }
.download-hero p  { color: rgba(255,255,255,.72); margin-bottom: 24px; font-size: .92rem; }
.download-count { color: rgba(255,255,255,.45); font-size: .8rem; margin-left: 16px; }

/* ── Section eyebrow ── */
.sec-eyebrow {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--mint-dark);
}

/* ── Pricing plan price styles (COP first) ── */
.plan-price-cop {
  font-size: 3.2rem;
  font-weight: 800;
  color: var(--blue-deep);
  line-height: 1;
}
.plan-price-sub {
  font-size: .82rem;
  color: var(--text-3);
  margin-top: 4px;
}
.plan-price-usd {
  font-size: .78rem;
  color: var(--text-3);
  margin-top: 2px;
  margin-bottom: 0;
}

/* ── Sidebar open on mobile ── */
@media(max-width:768px) {
  .sidebar { display: none; }
  .sidebar.sidebar-open { display: flex; }
}

/* ── SVG in buttons fix ── */
.btn svg { flex-shrink: 0; }
.btn-primary svg, .btn-dark svg { color: #fff; }

/* ── Alert flex ── */
.alert { display: flex; align-items: flex-start; gap: 10px; }
.alert svg { flex-shrink: 0; margin-top: 2px; }
