:root{
  --amarillo:#FFD100;
  --rojo:#E31837;
  --azul-corp:#0E2A5E;
  --azul:#0E2A5E;
  --azul-dark:#071A3D;
  --azul2:#F4F7FB;
  --azul3:#FFFFFF;
  --bg:#FFFFFF;
  --bg-soft:#F4F7FB;
  --texto:#0a1530;
  --texto-soft:#3a4a6b;
  --gris:#6b7a92;
  --borde:#E1E7F0;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Poppins',sans-serif;background:var(--bg);color:var(--texto);overflow-x:hidden;transition:background .35s ease,color .35s ease}

/* DARK MODE */
[data-theme="dark"]{
  --bg:#0A1428;
  --bg-soft:#0F1B36;
  --texto:#E8EDF5;
  --texto-soft:#A8B4CC;
  --gris:#7B8AAA;
  --borde:#1F2D4D;
  --azul-corp:#3B6FD9;
  --azul-dark:#0A1428;
}
[data-theme="dark"] h1,[data-theme="dark"] h2,[data-theme="dark"] h3,[data-theme="dark"] h4,[data-theme="dark"] h5{color:#E8EDF5}
[data-theme="dark"] .hero-title,[data-theme="dark"] .hero-title span,[data-theme="dark"] .sec-title,[data-theme="dark"] .sec-title span{color:#fff}
[data-theme="dark"] .serv-card h5,[data-theme="dark"] .ben-card h5,[data-theme="dark"] .step-title,[data-theme="dark"] .testi-name{color:#E8EDF5}
[data-theme="dark"] .navbar-brand{color:#fff!important}
[data-theme="dark"] #navbar{background:rgba(15,27,54,.85)!important;border-bottom-color:#1F2D4D}
[data-theme="dark"] #navbar.scrolled{background:rgba(15,27,54,.98)!important;box-shadow:0 2px 20px rgba(0,0,0,.4)}
[data-theme="dark"] .nav-link{color:#A8B4CC!important}
[data-theme="dark"] .nav-link:hover,[data-theme="dark"] .nav-link.active-link{color:var(--amarillo)!important;background:rgba(255,209,0,.08)}
[data-theme="dark"] .navbar-toggler{background:rgba(255,209,0,.1)!important;border-color:rgba(255,209,0,.3)!important}
[data-theme="dark"] .navbar-toggler i{color:var(--amarillo)!important}
[data-theme="dark"] .btn-outline-amarillo{border-color:var(--amarillo);color:var(--amarillo)}
[data-theme="dark"] .btn-outline-amarillo:hover{background:var(--amarillo);color:#0A1428}
[data-theme="dark"] .btn-amarillo{color:#0A1428}
[data-theme="dark"] #hero{background:linear-gradient(180deg,#0A1428 0%,#0F1B36 100%)}
[data-theme="dark"] .hero-bg{background:radial-gradient(ellipse at 80% 20%,rgba(255,209,0,.12) 0%,transparent 55%),radial-gradient(ellipse at 10% 90%,rgba(59,111,217,.18) 0%,transparent 55%)}
[data-theme="dark"] .dots-pattern{background-image:radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px)}
[data-theme="dark"] .badge-pill{background:rgba(255,209,0,.1);border-color:rgba(255,209,0,.3);color:var(--amarillo)}
[data-theme="dark"] .btn-hero-main{background:var(--amarillo);color:#0A1428;box-shadow:0 6px 20px rgba(255,209,0,.3)}
[data-theme="dark"] .btn-hero-main:hover{background:#ffdb33}
[data-theme="dark"] .btn-hero-sec{border-color:#fff;color:#fff}
[data-theme="dark"] .btn-hero-sec:hover{background:#fff;color:#0A1428}
[data-theme="dark"] .serv-card,[data-theme="dark"] .ben-card,[data-theme="dark"] .testi-card{background:#152448;border-color:#1F2D4D;box-shadow:0 4px 14px rgba(0,0,0,.25)}
[data-theme="dark"] .serv-card:hover,[data-theme="dark"] .ben-card:hover,[data-theme="dark"] .testi-card:hover{border-color:rgba(255,209,0,.3);box-shadow:0 16px 40px rgba(0,0,0,.45)}
[data-theme="dark"] .step-num{background:#152448;border-color:var(--amarillo);color:var(--amarillo)}
[data-theme="dark"] .step-item.active .step-num,[data-theme="dark"] .step-item:hover .step-num{background:var(--amarillo);color:#0A1428}
[data-theme="dark"] .step-item:not(:last-child)::after{background:rgba(255,209,0,.2)}
[data-theme="dark"] .step-icon{color:var(--amarillo)}
[data-theme="dark"] .ben-icon,[data-theme="dark"] .serv-icon{color:var(--amarillo)}
[data-theme="dark"] .serv-icon{background:rgba(255,209,0,.12)}
[data-theme="dark"] .sec-label{color:var(--amarillo)}
[data-theme="dark"] .tech-badge{background:#152448;border-color:#1F2D4D;color:#E8EDF5}
[data-theme="dark"] .tech-badge:hover{background:var(--amarillo);color:#0A1428;border-color:var(--amarillo)}
[data-theme="dark"] .accordion-item{background:#152448!important;border-color:#1F2D4D!important}
[data-theme="dark"] .accordion-button{background:#152448!important;color:#E8EDF5!important}
[data-theme="dark"] .accordion-button:not(.collapsed){background:rgba(255,209,0,.06)!important;color:var(--amarillo)!important}
[data-theme="dark"] .accordion-button::after{filter:invert(1)}
[data-theme="dark"] .req-table th{color:var(--amarillo)}
[data-theme="dark"] .req-table td:first-child{color:#E8EDF5}
[data-theme="dark"] .form-side,[data-theme="dark"] .pos-screen{background:#152448}
[data-theme="dark"] .pos-product-card,[data-theme="dark"] .pos-cart{background:#0F1B36;border-color:#1F2D4D}
[data-theme="dark"] .pos-product-name,[data-theme="dark"] .pos-cart-item{color:#E8EDF5}
[data-theme="dark"] #cta{background:#0A1428}
[data-theme="dark"] #btnTop{background:var(--amarillo);color:#0A1428}
[data-theme="dark"] .promo-modal{background:#152448}
[data-theme="dark"] .promo-discount{color:var(--amarillo)}
[data-theme="dark"] .promo-desc,[data-theme="dark"] .promo-feat{color:#A8B4CC}
[data-theme="dark"] .promo-countdown-item{background:#0F1B36;border-color:#1F2D4D}
[data-theme="dark"] .promo-countdown-num{color:var(--amarillo)}
[data-theme="dark"] #preloader{background:#0A1428}
[data-theme="dark"] .preloader-text{color:var(--amarillo)}
[data-theme="dark"] .preloader-ring::before{border-top-color:var(--amarillo);border-right-color:var(--amarillo)}
[data-theme="dark"] .preloader-ring::after{border-top-color:#fff;border-left-color:#fff}

/* THEME TOGGLE */
.theme-toggle{width:42px;height:42px;border-radius:50%;border:1.5px solid var(--borde);background:transparent;color:var(--azul-corp);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;transition:.3s;position:relative;overflow:hidden}
.theme-toggle:hover{border-color:var(--azul-corp);background:rgba(14,42,94,.06);transform:rotate(15deg)}
[data-theme="dark"] .theme-toggle{border-color:rgba(255,209,0,.4);color:var(--amarillo)}
[data-theme="dark"] .theme-toggle:hover{background:rgba(255,209,0,.1);border-color:var(--amarillo)}
.theme-toggle .bi-sun-fill{display:none}
[data-theme="dark"] .theme-toggle .bi-moon-stars-fill{display:none}
[data-theme="dark"] .theme-toggle .bi-sun-fill{display:inline-block}

/* TRICOLOR BAR */
.tricolor{height:4px;background:linear-gradient(to right,var(--amarillo) 0%,var(--amarillo) 33.33%,var(--azul-corp) 33.33%,var(--azul-corp) 66.66%,var(--rojo) 66.66%,var(--rojo) 100%)}

/* NAVBAR */
#navbar{transition:all .3s;padding:12px 0;background:rgba(255,255,255,.85)!important;backdrop-filter:blur(12px);border-bottom:1px solid var(--borde)}
#navbar.scrolled{background:rgba(255,255,255,.98)!important;box-shadow:0 2px 20px rgba(0,51,160,.08)}
.navbar-brand{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.4rem;color:var(--azul-corp)!important;letter-spacing:-0.5px}
.nav-link{color:var(--texto)!important;font-weight:600;font-size:.92rem;transition:.2s;padding:8px 16px!important;border-radius:8px}
.nav-link:hover{color:var(--azul-corp)!important;background:rgba(0,51,160,.06)}
.nav-link.active-link{color:var(--azul-corp)!important;background:rgba(0,51,160,.1)}
.btn-outline-amarillo{border:2px solid var(--azul-corp);color:var(--azul-corp);border-radius:50px;padding:7px 20px;font-weight:700;font-size:.85rem;background:transparent;transition:.3s}
.btn-outline-amarillo:hover{background:var(--azul-corp);color:#fff}
.btn-amarillo{background:var(--amarillo);color:var(--azul-corp);border-radius:50px;padding:8px 22px;font-weight:700;font-size:.85rem;border:none;transition:.3s;box-shadow:0 4px 14px rgba(255,209,0,.4)}
.btn-amarillo:hover{background:#ffdb33;transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,209,0,.5)}

/* HERO */
#hero{display:flex;align-items:center;position:relative;overflow:hidden;padding:90px 0 50px;background:linear-gradient(180deg,#FFFFFF 0%,#F4F7FB 100%)}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(255,209,0,.15) 0%,transparent 55%),radial-gradient(ellipse at 10% 90%,rgba(0,51,160,.1) 0%,transparent 55%),radial-gradient(ellipse at 90% 90%,rgba(227,24,55,.06) 0%,transparent 50%)}
.dots-pattern{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(0,51,160,.07) 1px,transparent 1px);background-size:28px 28px}
.badge-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(0,51,160,.08);border:1px solid rgba(0,51,160,.2);border-radius:50px;padding:8px 18px;font-size:.85rem;font-weight:700;color:var(--azul-corp);margin-bottom:20px;animation:fadeUp .6s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.hero-title{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;line-height:1.1;letter-spacing:-0.03em;color:var(--azul-corp);animation:fadeUp .7s .1s ease both}
.hero-title span{color:var(--azul-corp);font-weight:300}
.hero-sub{font-size:1.1rem;color:var(--texto-soft);max-width:560px;line-height:1.7;animation:fadeUp .7s .2s ease both}
.hero-btns{animation:fadeUp .7s .3s ease both;display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.btn-hero-main{background:var(--azul-corp);color:#fff;border-radius:50px;padding:14px 32px;font-weight:700;font-size:1rem;border:none;transition:.3s;display:inline-flex;align-items:center;gap:8px;box-shadow:0 6px 20px rgba(0,51,160,.25)}
.btn-hero-main:hover{background:var(--azul-dark);transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,51,160,.35)}
.btn-hero-sec{border:2px solid var(--azul-corp);color:var(--azul-corp);border-radius:50px;padding:13px 28px;font-weight:700;font-size:1rem;background:transparent;transition:.3s}
.btn-hero-sec:hover{background:var(--azul-corp);color:#fff}
.rating-row{display:flex;align-items:center;gap:10px;margin-top:28px;animation:fadeUp .7s .4s ease both}
.stars{color:var(--amarillo);font-size:1rem;letter-spacing:2px}
.rating-text{font-size:.85rem;color:var(--gris)}
.hero-code-preview{background:#0a1530;border:1px solid rgba(0,51,160,.2);border-radius:16px;padding:20px;font-family:monospace;font-size:.8rem;max-width:460px;animation:fadeUp .7s .2s ease both;box-shadow:0 20px 60px rgba(0,51,160,.15);color:#F0F0F0}
.code-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px}
.code-line{margin:3px 0;white-space:pre}
.json-key{color:#79b8ff}
.json-str{color:#9eff82}
.json-num{color:#ffab70}
.json-brace{color:#e2c08d}

/* TECH STACK */
#stack{padding:40px 0;background:var(--bg-soft);border-top:1px solid var(--borde);border-bottom:1px solid var(--borde)}
.tech-badge{display:inline-flex;align-items:center;gap:8px;border:1.5px solid var(--borde);background:#fff;color:var(--azul-corp);border-radius:50px;padding:7px 18px;font-size:.82rem;font-weight:700;margin:5px;transition:.3s;cursor:default}
.tech-badge i{font-size:1.1rem;line-height:1}
.tech-badge:hover{background:var(--azul-corp);color:#fff;border-color:var(--azul-corp);transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,51,160,.15)}

/* SECTION TITLES */
.sec-label{font-size:.78rem;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--azul-corp);margin-bottom:10px}
.sec-title{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:800;line-height:1.2;letter-spacing:-0.02em;color:var(--azul-corp)}
.sec-title span{color:var(--azul-corp);font-weight:300}
.sec-sub{color:var(--texto-soft);font-size:1rem;margin-top:12px;max-width:560px}

/* CARDS SERVICIOS */
#servicios{padding:70px 0;background:var(--bg)}
.serv-card{background:#fff;border:1px solid var(--borde);border-radius:18px;padding:30px;transition:.35s;height:100%;position:relative;overflow:hidden;box-shadow:0 2px 10px rgba(0,51,160,.04)}
.serv-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--amarillo);transform:scaleX(0);transition:.35s}
.serv-card:hover{border-color:rgba(0,51,160,.3);transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,51,160,.12)}
.serv-card:hover::before{transform:scaleX(1)}
.serv-icon{width:50px;height:50px;background:rgba(255,209,0,.18);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--azul-corp);margin-bottom:16px}
.serv-card h5{font-size:1.05rem;font-weight:700;margin-bottom:8px;color:var(--azul-corp)}
.serv-card p{color:var(--texto-soft);font-size:.88rem;line-height:1.6}
.badge-nuevo{background:var(--rojo);color:#fff;font-size:.65rem;font-weight:800;padding:3px 8px;border-radius:6px;margin-left:8px;vertical-align:middle}

/* BENEFICIOS */
#beneficios{padding:70px 0;background:var(--bg-soft)}
.ben-card{display:flex;gap:20px;align-items:flex-start;padding:28px;background:#fff;border:1px solid var(--borde);border-radius:16px;transition:.3s;box-shadow:0 2px 10px rgba(0,51,160,.04)}
.ben-card:hover{border-color:rgba(0,51,160,.25);box-shadow:0 12px 30px rgba(0,51,160,.1)}
.ben-icon{font-size:1.8rem;color:var(--azul-corp);flex-shrink:0;margin-top:4px}
.ben-card h5{font-size:1rem;font-weight:700;margin-bottom:6px;color:var(--azul-corp)}
.ben-card p{color:var(--texto-soft);font-size:.87rem;line-height:1.6;margin:0}

/* COMO FUNCIONA */
#como{padding:70px 0;background:var(--bg)}
.steps-wrap{display:flex;gap:0;position:relative}
.step-item{flex:1;text-align:center;position:relative;padding:0 10px}
.step-item:not(:last-child)::after{content:'';position:absolute;top:36px;left:calc(50% + 36px);right:calc(-50% + 36px);height:2px;background:rgba(0,51,160,.2);z-index:0}
.step-num{width:72px;height:72px;border-radius:50%;background:#fff;border:2px solid var(--azul-corp);display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-size:1.5rem;font-weight:800;color:var(--azul-corp);margin:0 auto 16px;position:relative;z-index:1;transition:.3s;box-shadow:0 4px 14px rgba(0,51,160,.15)}
.step-item.active .step-num,.step-item:hover .step-num{background:var(--azul-corp);color:#fff;box-shadow:0 0 30px rgba(0,51,160,.4)}
.step-icon{font-size:1.4rem;margin-bottom:10px;color:var(--azul-corp)}
.step-title{font-size:1rem;font-weight:700;margin-bottom:8px;color:var(--azul-corp)}
.step-desc{color:var(--texto-soft);font-size:.83rem;line-height:1.6}

/* CÓDIGO */
#codigo{padding:70px 0;background:var(--bg-soft)}
.tab-code{display:flex;gap:4px;margin-bottom:0;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:0}
.tab-btn{background:transparent;border:none;color:#8fa0b5;padding:10px 18px;font-size:.85rem;font-weight:700;cursor:pointer;border-bottom:2px solid transparent;transition:.2s;font-family:'Poppins',sans-serif}
.tab-btn.active{color:var(--amarillo);border-bottom-color:var(--amarillo)}
.code-block{background:#0a1530;border:1px solid rgba(0,51,160,.15);border-top:none;border-radius:0 0 16px 16px;padding:24px;font-family:'Courier New',monospace;font-size:.8rem;line-height:1.7;max-height:420px;overflow:auto;position:relative;color:#F0F0F0;white-space:pre;tab-size:2}
.code-block::-webkit-scrollbar{width:8px;height:8px}
.code-block::-webkit-scrollbar-thumb{background:rgba(255,209,0,.3);border-radius:4px}
.code-block::-webkit-scrollbar-track{background:transparent}
.code-box-wrap{border:1px solid rgba(0,51,160,.15);border-radius:16px;overflow:hidden;margin-top:24px;box-shadow:0 12px 40px rgba(0,51,160,.1)}
.code-header{background:#0a1530;border-bottom:1px solid rgba(255,255,255,.08);padding:12px 18px;display:flex;align-items:center;justify-content:space-between}
.code-dots span{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:5px}
.copy-btn{background:rgba(255,209,0,.15);border:1px solid rgba(255,209,0,.4);color:var(--amarillo);border-radius:8px;padding:5px 14px;font-size:.78rem;font-weight:700;cursor:pointer;transition:.3s;font-family:'Poppins',sans-serif}
.copy-btn:hover{background:var(--amarillo);color:var(--azul-corp)}
.req-table th{color:var(--azul-corp);font-size:.8rem;font-weight:700;border-color:var(--borde)!important;background:transparent}
.req-table td{font-size:.82rem;color:var(--texto-soft);border-color:var(--borde)!important;background:transparent}
.req-table td:first-child{color:var(--texto);font-weight:600}

/* STATS */
#stats{padding:70px 0;background:linear-gradient(135deg,var(--azul-corp) 0%,var(--azul-dark) 100%);color:#fff}
.stat-card{text-align:center;padding:20px}
.stat-num{font-family:'Poppins',sans-serif;font-size:2.8rem;font-weight:800;color:var(--amarillo);line-height:1}
.stat-label{color:rgba(255,255,255,.85);font-size:.88rem;margin-top:6px;font-weight:500}

/* TESTIMONIOS */
#testimonios{padding:70px 0;background:var(--bg)}
.testi-card{background:#fff;border:1px solid var(--borde);border-radius:16px;padding:28px;height:100%;transition:.3s;box-shadow:0 2px 10px rgba(0,51,160,.04)}
.testi-card:hover{border-color:rgba(0,51,160,.25);box-shadow:0 12px 30px rgba(0,51,160,.1)}
.testi-stars{color:var(--amarillo);font-size:.95rem;margin-bottom:12px}
.testi-text{color:var(--texto-soft);font-size:.88rem;line-height:1.7;font-style:italic;margin-bottom:18px}
.testi-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;color:#fff;flex-shrink:0}
.testi-name{font-size:.85rem;font-weight:700;color:var(--azul-corp)}

/* FAQ */
#faq{padding:70px 0;background:var(--bg-soft)}
.accordion-item{background:#fff!important;border:1px solid var(--borde)!important;border-radius:12px!important;margin-bottom:10px;overflow:hidden;box-shadow:0 2px 10px rgba(0,51,160,.04)}
.accordion-button{background:#fff!important;color:var(--azul-corp)!important;font-weight:700;font-size:.95rem;border-radius:12px!important;box-shadow:none!important;padding:18px 20px}
.accordion-button:not(.collapsed){color:var(--azul-corp)!important;background:rgba(0,51,160,.05)!important}
.accordion-button::after{filter:none}
.accordion-body{color:var(--texto-soft);font-size:.9rem;line-height:1.8;padding:0 20px 18px}

/* CTA */
#cta{padding:70px 0;background:var(--bg);position:relative;overflow:hidden}
.cta-bg{position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(255,209,0,.12) 0%,transparent 65%)}
.cta-wrap{background:linear-gradient(135deg,var(--azul-corp) 0%,var(--azul-dark) 100%);border:1px solid rgba(255,209,0,.2);border-radius:24px;padding:70px 40px;text-align:center;position:relative;box-shadow:0 20px 60px rgba(0,51,160,.25);color:#fff}
.cta-wrap::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(to right,var(--amarillo) 0%,var(--amarillo) 33.33%,#fff 33.33%,#fff 66.66%,var(--rojo) 66.66%,var(--rojo) 100%);border-radius:24px 24px 0 0}
.cta-title{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;margin-bottom:16px;color:#fff!important}
.btn-wa{background:var(--amarillo);color:var(--azul-corp);border-radius:50px;padding:16px 36px;font-weight:800;font-size:1.05rem;border:none;display:inline-flex;align-items:center;gap:10px;transition:.3s}
.btn-wa:hover{background:#ffdb33;transform:translateY(-3px);box-shadow:0 12px 30px rgba(255,209,0,.5)}
.btn-doc{border:2px solid #fff;color:#fff;border-radius:50px;padding:14px 28px;font-weight:700;font-size:1rem;background:transparent;transition:.3s}
.btn-doc:hover{background:#fff;color:var(--azul-corp)}

/* FOOTER */
footer{background:var(--azul-dark);padding:70px 0 30px;color:#fff}
.footer-brand{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.4rem;color:var(--amarillo)}
.footer-desc{color:rgba(255,255,255,.7);font-size:.87rem;line-height:1.7;max-width:260px;margin-top:10px}
.footer-title{font-size:.78rem;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;color:var(--amarillo);margin-bottom:16px}
.footer-link{display:block;color:rgba(255,255,255,.7);font-size:.87rem;text-decoration:none;margin-bottom:9px;transition:.2s}
.footer-link:hover{color:var(--amarillo)}
.social-btn{width:38px;height:38px;border:1px solid rgba(255,255,255,.2);border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:rgba(255,255,255,.8);text-decoration:none;margin-right:8px;transition:.3s;font-size:1rem}
.social-btn:hover{border-color:var(--amarillo);color:var(--amarillo);background:rgba(255,209,0,.1)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;margin-top:50px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{color:rgba(255,255,255,.6);font-size:.82rem}
.footer-links-bottom a{color:rgba(255,255,255,.6);font-size:.82rem;text-decoration:none;margin-left:20px;transition:.2s}
.footer-links-bottom a:hover{color:var(--amarillo)}

/* SCROLL BTN */
#btnTop{position:fixed;bottom:28px;right:28px;width:46px;height:46px;background:var(--azul-corp);color:#fff;border:none;border-radius:50%;font-size:1.1rem;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:9999;box-shadow:0 4px 20px rgba(0,51,160,.4);transition:.3s}
#btnTop:hover{background:var(--azul-dark);transform:translateY(-3px)}

/* ANIMATE */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* TYPEWRITER EFFECT */
.typewriter{overflow:hidden;white-space:nowrap;display:inline-block}
.typewriter::after{content:'|';color:var(--azul-corp);font-weight:700;animation:blink-caret .75s step-end infinite;margin-left:2px}
@keyframes blink-caret{from,to{opacity:0}50%{opacity:1}}
.hero-subtitle{font-size:1.5rem;font-weight:700;color:var(--azul-corp);margin:1rem 0}

/* CAROUSEL CONTROLS */
.carousel-control-prev-icon,.carousel-control-next-icon{filter:invert(1) drop-shadow(0 0 4px rgba(0,51,160,.3))}

/* POS SHOWCASE */
.pos-showcase{animation:fadeUp .7s .2s ease both}
.pos-screen{background:#fff;border:1px solid var(--borde);border-radius:16px;padding:20px;max-width:500px;box-shadow:0 20px 60px rgba(0,51,160,.15)}
.pos-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--borde)}
.pos-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:16px;margin-bottom:16px}
.pos-category{color:var(--azul-corp);font-size:.75rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}
.pos-products{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.pos-product-card{background:var(--bg-soft);border:1px solid var(--borde);border-radius:8px;padding:12px;text-align:center;transition:.3s;cursor:pointer}
.pos-product-card:hover{background:rgba(0,51,160,.08);border-color:var(--azul-corp)}
.pos-product-icon{font-size:1.5rem;color:var(--azul-corp);margin-bottom:6px}
.pos-product-name{font-size:.75rem;font-weight:600;color:var(--texto)}
.pos-cart{background:var(--bg-soft);border:1px solid var(--borde);border-radius:12px;padding:16px}
.pos-cart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--borde);color:var(--azul-corp)}
.pos-cart-items{margin-bottom:12px}
.pos-cart-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--borde);font-size:.85rem;color:var(--texto)}
.pos-cart-item:last-child{border-bottom:none}
.pos-cart-total{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-top:2px solid var(--amarillo);margin-bottom:12px;color:var(--azul-corp)}
.pos-cart-btn{background:var(--azul-corp);color:#fff;border:none;border-radius:8px;padding:12px;font-weight:700;width:100%;transition:.3s;display:flex;align-items:center;justify-content:center;gap:8px}
.pos-cart-btn:hover{background:var(--azul-dark);transform:translateY(-2px)}

@media(max-width:768px){
  .steps-wrap{flex-direction:column;align-items:center}
  .step-item{width:100%;max-width:280px}
  .step-item:not(:last-child)::after{display:none}
  #hero{padding:100px 0 60px}
}

/* PRELOADER */
#preloader{position:fixed;inset:0;background:#fff;z-index:99999;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .5s ease,visibility .5s ease}
#preloader.hidden{opacity:0;visibility:hidden}
.preloader-logo{width:90px;height:90px;animation:pulseLogo 1.6s ease-in-out infinite}
.preloader-ring{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.preloader-ring::before,.preloader-ring::after{content:'';position:absolute;inset:0;border-radius:50%;border:3px solid transparent}
.preloader-ring::before{border-top-color:var(--azul-corp);border-right-color:var(--azul-corp);animation:spin 1.1s linear infinite}
.preloader-ring::after{inset:8px;border-top-color:var(--amarillo);border-left-color:var(--amarillo);animation:spin 1.5s linear reverse infinite}
.preloader-text{font-family:'Poppins',sans-serif;font-weight:700;color:var(--azul-corp);font-size:.9rem;letter-spacing:3px;text-transform:uppercase;margin-top:6px}
.preloader-text span{display:inline-block;animation:dotBlink 1.4s infinite}
.preloader-text span:nth-child(2){animation-delay:.2s}
.preloader-text span:nth-child(3){animation-delay:.4s}
@keyframes pulseLogo{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.92);opacity:.85}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes dotBlink{0%,80%,100%{opacity:.3}40%{opacity:1}}
body.loading{overflow:hidden}

/* PROMO POPUP */
#promoOverlay{position:fixed;inset:0;background:rgba(7,26,61,.65);backdrop-filter:blur(6px);z-index:9998;display:none;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .3s ease}
#promoOverlay.show{display:flex;opacity:1}
.promo-modal{background:#fff;border-radius:20px;max-width:480px;width:100%;overflow:hidden;position:relative;box-shadow:0 30px 80px rgba(7,26,61,.3);transform:scale(.85) translateY(20px);transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
#promoOverlay.show .promo-modal{transform:scale(1) translateY(0)}
.promo-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.95);border:none;color:var(--azul-corp);font-size:1.1rem;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;transition:.25s;box-shadow:0 4px 12px rgba(0,0,0,.15)}
.promo-close:hover{background:var(--rojo);color:#fff;transform:rotate(90deg)}
.promo-banner{background:linear-gradient(135deg,var(--azul-corp) 0%,var(--azul-dark) 100%);padding:36px 30px 50px;text-align:center;position:relative;overflow:hidden;color:#fff}
.promo-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(255,209,0,.18) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(227,24,55,.15) 0%,transparent 50%)}
.promo-banner::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:30px;background:#fff;clip-path:polygon(0 100%,100% 100%,100% 0,0 60%)}
.promo-icon-wrap{position:relative;width:78px;height:78px;margin:0 auto 14px;background:var(--amarillo);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--azul-corp);box-shadow:0 8px 24px rgba(255,209,0,.4);animation:bounceIn .6s ease both .15s}
.promo-icon-wrap::before{content:'';position:absolute;inset:-8px;border-radius:50%;border:2px dashed rgba(255,209,0,.5);animation:spin 8s linear infinite}
@keyframes bounceIn{0%{transform:scale(0)}60%{transform:scale(1.15)}100%{transform:scale(1)}}
.promo-tag{display:inline-block;background:var(--rojo);color:#fff;font-size:.7rem;font-weight:800;padding:4px 12px;border-radius:50px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px;position:relative;z-index:1}
.promo-headline{font-size:1.5rem;font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1.2;position:relative;z-index:1;margin-bottom:6px}
.promo-headline span{color:var(--amarillo)}
.promo-sub{font-size:.88rem;color:rgba(255,255,255,.85);position:relative;z-index:1;max-width:340px;margin:0 auto}
.promo-body{padding:20px 30px 26px;text-align:center}
.promo-discount{font-family:'Poppins',sans-serif;font-weight:800;color:var(--azul-corp);font-size:2.6rem;line-height:1;letter-spacing:-.03em;margin-bottom:6px}
.promo-discount small{font-size:1.1rem;font-weight:700;color:var(--rojo);margin-left:4px}
.promo-desc{color:var(--texto-soft);font-size:.92rem;line-height:1.55;margin-bottom:18px}
.promo-features{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin-bottom:18px}
.promo-feat{display:flex;align-items:center;gap:6px;font-size:.78rem;font-weight:600;color:var(--texto-soft)}
.promo-feat i{color:var(--verde,#16a34a);font-size:1rem}
.promo-cta{display:inline-flex;align-items:center;gap:8px;background:var(--amarillo);color:var(--azul-corp);border:none;border-radius:50px;padding:13px 30px;font-weight:800;font-size:.95rem;cursor:pointer;text-decoration:none;transition:.3s;box-shadow:0 6px 20px rgba(255,209,0,.4);font-family:'Poppins',sans-serif}
.promo-cta:hover{background:#ffdb33;transform:translateY(-2px);box-shadow:0 10px 28px rgba(255,209,0,.55);color:var(--azul-corp)}
.promo-noshow{margin-top:14px;display:flex;align-items:center;justify-content:center;gap:6px;font-size:.78rem;color:var(--gris)}
.promo-noshow input{accent-color:var(--azul-corp);cursor:pointer}
.promo-noshow label{cursor:pointer}
.promo-countdown{display:flex;justify-content:center;gap:8px;margin-bottom:16px}
.promo-countdown-item{background:var(--bg-soft);border:1px solid var(--borde);border-radius:8px;padding:6px 10px;min-width:48px;text-align:center}
.promo-countdown-num{font-weight:800;color:var(--azul-corp);font-size:1.1rem;line-height:1}
.promo-countdown-lbl{font-size:.62rem;color:var(--gris);text-transform:uppercase;letter-spacing:1px;margin-top:2px}

/* FLOATING BANNER (mensaje persistente) */
#promoBanner{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(120%);z-index:9990;background:linear-gradient(135deg,var(--azul-corp) 0%,var(--azul-dark) 100%);color:#fff;border-radius:14px;padding:14px 22px 14px 18px;display:flex;align-items:center;gap:14px;box-shadow:0 14px 40px rgba(7,26,61,.3);max-width:520px;width:calc(100% - 40px);transition:transform .5s cubic-bezier(.34,1.56,.64,1)}
#promoBanner.show{transform:translateX(-50%) translateY(0)}
.promo-banner-icon{width:42px;height:42px;background:var(--amarillo);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--azul-corp);font-size:1.2rem;flex-shrink:0}
.promo-banner-text{flex:1;font-size:.88rem;line-height:1.35}
.promo-banner-text strong{display:block;color:var(--amarillo);font-size:.95rem;margin-bottom:2px}
.promo-banner-btn{background:var(--amarillo);color:var(--azul-corp);border:none;border-radius:50px;padding:8px 16px;font-weight:700;font-size:.82rem;cursor:pointer;white-space:nowrap;transition:.25s;font-family:'Poppins',sans-serif}
.promo-banner-btn:hover{background:#ffdb33;transform:translateY(-2px)}
.promo-banner-close{background:transparent;border:none;color:rgba(255,255,255,.7);font-size:1.1rem;cursor:pointer;padding:4px;transition:.2s}
.promo-banner-close:hover{color:#fff}
@media(max-width:576px){
  .promo-headline{font-size:1.25rem}
  .promo-discount{font-size:2rem}
  .promo-banner{padding:30px 20px 44px}
  .promo-body{padding:16px 20px 22px}
  #promoBanner{flex-wrap:wrap;padding:12px 16px}
  .promo-banner-text{flex-basis:100%;order:1}
  .promo-banner-icon{order:0}
}