:root{
    --primary:#1C2E4A;
    --secondary:#F4A300;
    --tertiary:#2F343A;
    --muted:#6B7280;
    --soft:#F8F5EF;
    --white:#ffffff;
    --success:#16a34a;
    --danger:#dc2626;
    --shadow-soft:0 10px 30px rgba(15,23,42,.07);
    --shadow-medium:0 18px 45px rgba(15,23,42,.10);
    --shadow-strong:0 26px 60px rgba(15,23,42,.14);
}

html{ scroll-behavior:smooth; }

*,
*::before,
*::after{
    box-sizing:border-box;
}

html,
body{
    max-width:100%;
    overflow-x:hidden;
}

img,
svg,
video,
canvas{
    max-width:100%;
    height:auto;
}

body{
    font-family:'Inter',sans-serif;
    color:var(--tertiary);
    overflow-x:hidden;
    background:#fff;
    padding-top:96px;
}

body.loading{ overflow:hidden; }

a{ text-decoration:none; }

.text-primary-custom{ color:var(--primary)!important; }
.text-secondary-custom{ color:var(--secondary)!important; }
.text-muted-custom{ color:var(--muted)!important; }
.bg-soft{ background:var(--soft)!important; }
.bg-primary-soft{ background:rgba(28,46,74,.05)!important; }
.bg-warning-soft{ background:rgba(244,163,0,.10)!important; }

.section-label{
    letter-spacing:.12em;
    text-transform:uppercase;
    font-size:.78rem;
    font-weight:800;
    color:var(--muted);
}

.section-title{
    color:var(--primary);
    font-weight:900;
    letter-spacing:-.04em;
}

.section-text{
    color:var(--muted);
    font-size:1.02rem;
    line-height:1.8;
}

.btn-warning-custom{
    background:var(--secondary);
    border-color:var(--secondary);
    color:#fff;
    box-shadow:0 14px 30px rgba(244,163,0,.22);
    transition:
        transform .32s cubic-bezier(.16,1,.3,1),
        box-shadow .32s cubic-bezier(.16,1,.3,1),
        background .25s ease,
        border-color .25s ease;
    position:relative;
    overflow:hidden;
}

.btn-warning-custom:hover{
    background:#db9400;
    border-color:#db9400;
    color:#fff;
    transform:translateY(-5px) scale(1.02);
    box-shadow:0 18px 38px rgba(244,163,0,.28);
}

.btn-outline-primary-custom{
    border-color:rgba(28,46,74,.16);
    color:var(--primary);
    background:#fff;
    transition:
        transform .32s cubic-bezier(.16,1,.3,1),
        box-shadow .32s cubic-bezier(.16,1,.3,1),
        background .25s ease,
        border-color .25s ease,
        color .25s ease;
    position:relative;
    overflow:hidden;
}

.btn-outline-primary-custom:hover{
    background:var(--primary);
    border-color:var(--primary);
    color:#fff;
    transform:translateY(-5px) scale(1.02);
}

.btn-warning-custom::after,
.btn-outline-primary-custom::after{
    content:"";
    position:absolute;
    top:0;
    left:-120%;
    width:65%;
    height:100%;
    background:linear-gradient(120deg, transparent, rgba(255,255,255,.35), transparent);
    transform:skewX(-18deg);
}

.btn-warning-custom:hover::after,
.btn-outline-primary-custom:hover::after{
    animation:buttonSweep .85s ease;
}

.soft-card,
.card-premium{
    border:1px solid rgba(28,46,74,.07);
    box-shadow:var(--shadow-soft);
    border-radius:1.5rem;
    background:#fff;
    overflow:hidden;
    transition:
        transform .38s cubic-bezier(.16,1,.3,1),
        box-shadow .38s cubic-bezier(.16,1,.3,1),
        border-color .3s ease,
        background .3s ease;
    transform-origin:center;
    will-change:transform, box-shadow;
}

.soft-card:hover,
.card-premium:hover{
    transform:translateY(-12px) scale(1.02);
    box-shadow:0 1.5rem 3rem rgba(15,23,42,.14);
    border-color:rgba(244,163,0,.25);
}

.card-highlight{
    position:relative;
    border:1px solid rgba(244,163,0,.28);
    box-shadow:0 20px 45px rgba(244,163,0,.16);
}

.card-highlight::before{
    content:"";
    position:absolute;
    inset:0 0 auto 0;
    height:4px;
    background:linear-gradient(90deg, var(--secondary), #ffd26b);
}

.icon-soft{
    width:56px;
    height:56px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:1rem;
    background:#fff;
    border:1px solid #eef2f7;
    color:var(--primary);
    font-size:1.25rem;
    flex-shrink:0;
    box-shadow:0 6px 18px rgba(15,23,42,.04);
}

/* PRELOADER */
#preloader{
    position:fixed;
    inset:0;
    z-index:99999;
    display:flex;
    align-items:center;
    justify-content:center;
    background:
        radial-gradient(circle at top right, rgba(244,163,0,.18), transparent 28%),
        radial-gradient(circle at bottom left, rgba(28,46,74,.09), transparent 22%),
        linear-gradient(180deg, #ffffff 0%, #f8f5ef 100%);
    transition:opacity .45s ease, visibility .45s ease;
}

#preloader.hide{
    opacity:0;
    visibility:hidden;
}

.preloader-box{ text-align:center; }

.preloader-dots{
    display:flex;
    justify-content:center;
    gap:.4rem;
    margin-top:1.25rem;
}

.preloader-dots span{
    width:10px;
    height:10px;
    border-radius:50%;
    background:var(--secondary);
    opacity:.35;
    animation:dotPulse 1.2s infinite ease-in-out;
}

.preloader-dots span:nth-child(2){ animation-delay:.15s; }
.preloader-dots span:nth-child(3){ animation-delay:.30s; }

.preloader-text{
    color:var(--primary);
    font-weight:800;
    letter-spacing:.08em;
    font-size:.95rem;
    margin-top:1rem;
}

.preloader-subtext{
    color:var(--muted);
    font-size:.92rem;
    margin-top:.35rem;
}

/* MATRAZ */
.flask-container{
    display:flex;
    justify-content:center;
    align-items:center;
    margin-bottom:1.5rem;
}

.flask{
    width:70px;
    height:100px;
    border:3px solid var(--primary);
    border-top:none;
    border-radius:0 0 30px 30px;
    position:relative;
    overflow:hidden;
}

.flask::before{
    content:"";
    position:absolute;
    top:-30px;
    left:50%;
    transform:translateX(-50%);
    width:20px;
    height:40px;
    border:3px solid var(--primary);
    border-bottom:none;
    border-radius:10px 10px 0 0;
    background:#fff;
}

.liquid{
    position:absolute;
    bottom:0;
    width:100%;
    height:0%;
    background:linear-gradient(180deg,var(--secondary),#ffd26b);
    animation:fillFlask 2.5s ease-in-out forwards;
}

.typewriter{
    font-weight:900;
    letter-spacing:.08em;
    font-size:1.1rem;
    color:var(--primary);
}

/* NAVBAR */
.navbar-glass{
    background:rgba(255,255,255,.82);
    backdrop-filter:blur(12px);
    border-bottom:1px solid rgba(28,46,74,.06);
    transition:all .3s ease;
}

.navbar-glass.scrolled{
    background:rgba(255,255,255,.96);
    box-shadow:0 14px 35px rgba(15,23,42,.08);
}

.logo-img{ max-height:78px; width:auto; }
.footer-logo{ max-height:76px; width:auto; }

.navbar-toggler{
    border:0!important;
    box-shadow:none!important;
}

.nav-link{
    color:var(--tertiary)!important;
    font-weight:600;
    padding:.72rem 1rem!important;
    border-radius:999px;
    position:relative;
    transition:all .25s ease;
}

.nav-link:hover,
.nav-link.active-link{
    color:var(--primary)!important;
    background:rgba(28,46,74,.05);
}

.nav-link::after{
    content:"";
    position:absolute;
    left:18px;
    right:18px;
    bottom:8px;
    height:2px;
    border-radius:999px;
    background:linear-gradient(90deg,var(--secondary),#ffd26b);
    transform:scaleX(0);
    transition:transform .28s ease;
}

.nav-link:hover::after,
.nav-link.active-link::after{
    transform:scaleX(1);
}

.navbar-search{
    position:relative;
    min-width:300px;
}

.navbar-search .form-control{
    border-radius:999px;
    border:1px solid rgba(28,46,74,.10);
    padding-left:2.7rem;
    min-height:46px;
    box-shadow:none;
}

.navbar-search .form-control:focus{
    border-color:rgba(244,163,0,.7);
    box-shadow:0 0 0 .25rem rgba(244,163,0,.12);
}

.navbar-search .search-icon{
    position:absolute;
    left:1rem;
    top:50%;
    transform:translateY(-50%);
    color:var(--muted);
    z-index:3;
}

.search-results{
    position:absolute;
    top:calc(100% + .55rem);
    left:0;
    right:0;
    background:#fff;
    border:1px solid rgba(28,46,74,.08);
    border-radius:1rem;
    box-shadow:var(--shadow-medium);
    padding:.45rem;
    display:none;
    z-index:1050;
}

.search-results.show{ display:block; }

.search-result-item{
    display:flex;
    align-items:flex-start;
    gap:.85rem;
    width:100%;
    border:0;
    background:#fff;
    border-radius:.9rem;
    padding:.85rem .9rem;
    text-align:left;
    transition:
        background .22s ease,
        transform .22s ease;
}

.search-result-item:hover{
    background:rgba(28,46,74,.04);
    transform:translateX(4px);
}

.search-result-item i{
    color:var(--secondary);
    font-size:1.1rem;
    margin-top:.1rem;
}

.search-result-item .title{
    font-weight:700;
    color:var(--primary);
    font-size:.95rem;
}

.search-result-item .desc{
    color:var(--muted);
    font-size:.84rem;
    line-height:1.45;
}

/* HERO */
.hero-section{
    position:relative;
    overflow:hidden;
    background:
        radial-gradient(circle at top right, rgba(244,163,0,.16), transparent 30%),
        radial-gradient(circle at 12% 85%, rgba(28,46,74,.08), transparent 22%),
        linear-gradient(180deg, #fcfaf7 0%, #f8f5ef 100%);
}

.hero-grid{
    position:absolute;
    inset:0;
    background-image:
        linear-gradient(rgba(28,46,74,.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(28,46,74,.03) 1px, transparent 1px);
    background-size:26px 26px;
    mask-image:linear-gradient(180deg,rgba(0,0,0,.35),transparent 75%);
    pointer-events:none;
    animation:gridFloat 12s linear infinite;
}

.hero-orb{
    position:absolute;
    border-radius:50%;
    filter:blur(14px);
    pointer-events:none;
    transition:transform .2s ease-out;
}

.hero-orb.one{
    width:260px;
    height:260px;
    right:-70px;
    top:80px;
    background:rgba(244,163,0,.14);
    animation:orbDriftOne 9s ease-in-out infinite;
}

.hero-orb.two{
    width:190px;
    height:190px;
    left:-70px;
    bottom:90px;
    background:rgba(28,46,74,.09);
    animation:orbDriftTwo 11s ease-in-out infinite;
}

.hero-kicker{
    background:rgba(255,255,255,.82);
    backdrop-filter:blur(10px);
    border:1px solid rgba(28,46,74,.08)!important;
    box-shadow:var(--shadow-soft);
}

.hero-title{
    color:var(--primary);
    font-size:clamp(2.35rem,4.3vw,4.65rem);
    line-height:1.01;
    font-weight:900;
    letter-spacing:-.06em;
    animation:heroTitleEntrance 1.15s cubic-bezier(.16,1,.3,1), heroTitleFloat 6s ease-in-out 1.2s infinite;
}

.hero-text{
    color:var(--muted);
    font-size:1.04rem;
    line-height:1.8;
    max-width:560px;
    animation:heroTextEntrance 1.35s cubic-bezier(.16,1,.3,1), heroTextGlow 7s ease-in-out 1.4s infinite;
}

.hero-chip{
    border:1px solid rgba(28,46,74,.08);
    background:#fff;
    border-radius:999px;
    padding:.78rem 1rem;
    font-weight:600;
    color:var(--primary);
    box-shadow:0 .125rem .25rem rgba(0,0,0,.03);
    display:inline-flex;
    align-items:center;
    gap:.5rem;
    transition:
        transform .35s cubic-bezier(.16,1,.3,1),
        box-shadow .35s cubic-bezier(.16,1,.3,1),
        border-color .35s ease;
}

.hero-chip:hover{
    transform:translateY(-8px) scale(1.03);
    box-shadow:0 18px 34px rgba(15,23,42,.12);
    border-color:rgba(244,163,0,.35);
}

.hero-stat-card{
    background:rgba(255,255,255,.85);
    backdrop-filter:blur(8px);
    border:1px solid rgba(28,46,74,.07);
    box-shadow:var(--shadow-soft);
    transition:
        transform .38s cubic-bezier(.16,1,.3,1),
        box-shadow .38s cubic-bezier(.16,1,.3,1),
        border-color .3s ease;
    will-change:transform, box-shadow;
}

.hero-stat-card:hover{
    transform:translateY(-12px) scale(1.02);
    box-shadow:var(--shadow-medium);
    border-color:rgba(244,163,0,.24);
}

.hero-visual-wrap{
    position:relative;
    perspective:1200px;
}

.hero-float-badge{
    position:absolute;
    top:-12px;
    left:24px;
    z-index:4;
    background:rgba(255,255,255,.88);
    backdrop-filter:blur(10px);
    border:1px solid rgba(28,46,74,.08);
    box-shadow:var(--shadow-soft);
    animation:badgeWave 4s ease-in-out infinite;
}

.laptop-shell{
    position:relative;
    max-width:760px;
    margin-inline:auto;
    border-radius:24px;
    padding:14px 14px 18px;
    background:linear-gradient(180deg,#212938 0%, #161c27 100%);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 28px 70px rgba(15,23,42,.22);
    transform-style:preserve-3d;
    animation:screenBreath 5.5s ease-in-out infinite;
}

.laptop-screen{
    border-radius:16px;
    overflow:hidden;
    aspect-ratio:16/10;
    background:#0f172a;
    border:2px solid rgba(255,255,255,.04);
    position:relative;
}

.laptop-screen::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(120deg, transparent 10%, rgba(255,255,255,.12) 28%, transparent 42%);
    transform:translateX(-130%);
    animation:screenSweep 6s ease-in-out infinite;
    pointer-events:none;
    z-index:2;
}

.laptop-screen img{
    width:100%;
    height:100%;
    object-fit:contain;
    display:block;
    background:#fff;
}

.laptop-base{
    width:100%;
    height:16px;
    background:linear-gradient(180deg, #cfd4dc 0%, #aeb6c2 100%);
    margin:0 auto;
    margin-top:-2px;
    border-radius:0 0 18px 18px;
    position:relative;
}

.laptop-base::after{
    content:"";
    width:22%;
    height:4px;
    background:rgba(0,0,0,.16);
    border-radius:999px;
    position:absolute;
    left:50%;
    top:2px;
    transform:translateX(-50%);
}

.mini-floating-card{
    position:absolute;
    right:0;
    bottom:36px;
    min-width:220px;
    max-width:min(220px, 100%);
    background:#fff;
    border:1px solid rgba(28,46,74,.08);
    box-shadow:var(--shadow-medium);
    border-radius:1.1rem;
    padding:.95rem 1rem;
    animation:cardDock 5s ease-in-out infinite;
}

.mini-dot{
    width:10px;
    height:10px;
    border-radius:50%;
    background:var(--success);
    display:inline-block;
    box-shadow:0 0 0 0 rgba(22,163,74,.45);
    animation:signalPulse 2s infinite;
}

.feature-strip-card{
    border:1px solid rgba(28,46,74,.06);
    background:rgba(255,255,255,.85);
    backdrop-filter:blur(8px);
    box-shadow:var(--shadow-soft);
}

/* GALLERY */
.gallery-frame{
    border-radius:1.65rem;
    overflow:hidden;
    background:#fff;
    box-shadow:0 1rem 2.5rem rgba(15,23,42,.08);
    border:1px solid rgba(28,46,74,.08);
    transition:transform .35s ease, box-shadow .35s ease;
}

.gallery-frame:hover{
    transform:translateY(-4px);
    box-shadow:0 1.5rem 3rem rgba(15,23,42,.12);
}

.gallery-preview{
    aspect-ratio:16/10;
    background:#f8fafc;
    overflow:hidden;
}

.gallery-preview img,
.gallery-img{
    width:100%;
    height:100%;
    object-fit:contain;
    display:block;
    background:#fff;
    cursor:zoom-in;
    transition:transform .65s cubic-bezier(.16,1,.3,1), filter .45s ease;
}

.gallery-preview:hover .gallery-img{
    transform:scale(1.08);
    filter:saturate(1.08) contrast(1.02);
}

/* PLANS */
.plan-badge{
    display:inline-flex;
    align-items:center;
    gap:.45rem;
    border-radius:999px;
    padding:.55rem .9rem;
    font-size:.86rem;
    font-weight:700;
    border:1px solid rgba(28,46,74,.09);
    background:#fff;
    color:var(--primary);
}

.plan-title{
    font-size:1.55rem;
    font-weight:800;
    color:var(--primary);
    letter-spacing:-.03em;
}

.plan-subtitle{
    color:var(--muted);
    line-height:1.75;
    min-height:84px;
}

.plan-list li{
    display:flex;
    align-items:flex-start;
    gap:.7rem;
    padding:.72rem 0;
    border-bottom:1px dashed rgba(28,46,74,.10);
    color:var(--tertiary);
}

.plan-list li:last-child{
    border-bottom:0;
    padding-bottom:0;
}

.plan-list i{
    color:var(--success);
    font-size:1rem;
    margin-top:.18rem;
}

/* FAQ */
.faq-accordion .accordion-item{
    background:#fff;
    box-shadow:0 10px 30px rgba(15,23,42,.06);
    border:1px solid rgba(28,46,74,.08);
}

.faq-item{
    transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s cubic-bezier(.16,1,.3,1);
}

.faq-item:hover{
    transform:translateY(-8px);
    box-shadow:0 18px 38px rgba(15,23,42,.12);
}

.faq-button{
    background:#fff;
    color:var(--primary);
    font-weight:700;
    font-size:1rem;
    padding:1.2rem 1.25rem;
    box-shadow:none!important;
}

.faq-button:not(.collapsed){
    background:rgba(28,46,74,.03);
    color:var(--primary);
}

.faq-button::after{
    filter:grayscale(20%);
}

.faq-body{
    color:var(--muted);
    line-height:1.8;
    font-size:.98rem;
    padding:0 1.25rem 1.25rem 1.25rem;
}

/* CONTACTO */
.contact-box{
    background:
        radial-gradient(circle at top right, rgba(244,163,0,.10), transparent 28%),
        linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(248,245,239,1) 100%);
    border:1px solid rgba(28,46,74,.08);
    box-shadow:var(--shadow-medium);
    border-radius:1.7rem;
}

.contact-info-item{
    border:1px solid rgba(28,46,74,.08);
    background:#fff;
    border-radius:1rem;
    padding:1rem 1.1rem;
    transition:
        transform .38s cubic-bezier(.16,1,.3,1),
        box-shadow .38s cubic-bezier(.16,1,.3,1),
        border-color .3s ease;
}

.contact-info-item:hover{
    transform:translateY(-12px) scale(1.02);
    box-shadow:0 1.5rem 3rem rgba(15,23,42,.14);
    border-color:rgba(244,163,0,.25);
}

.logo-showcase{
    min-height:100%;
    border:1px solid rgba(28,46,74,.08);
    background:
        radial-gradient(circle at top center, rgba(244,163,0,.12), transparent 35%),
        linear-gradient(180deg, #ffffff 0%, #f8f5ef 100%);
    border-radius:1.7rem;
    box-shadow:var(--shadow-medium);
    padding:2rem;
    text-align:center;
    position:relative;
    overflow:hidden;
}

.logo-showcase::before{
    content:"";
    position:absolute;
    inset:auto -80px -80px auto;
    width:220px;
    height:220px;
    border-radius:50%;
    background:rgba(28,46,74,.05);
    filter:blur(10px);
}

.logo-showcase-img{
    max-width:280px;
    width:100%;
    height:auto;
    margin:0 auto 1.5rem;
    display:block;
    filter:drop-shadow(0 18px 30px rgba(28,46,74,.10));
    transition:transform .5s cubic-bezier(.16,1,.3,1), filter .4s ease;
}

.logo-showcase:hover .logo-showcase-img{
    transform:scale(1.05) translateY(-4px);
    filter:drop-shadow(0 24px 38px rgba(28,46,74,.14));
}

.keyword-badges{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    gap:.65rem;
}

.keyword-badge{
    border:1px solid rgba(28,46,74,.09);
    background:#fff;
    color:var(--primary);
    border-radius:999px;
    padding:.65rem 1rem;
    font-weight:600;
    font-size:.92rem;
}

/* FOOTER */
.footer-link{
    color:rgba(255,255,255,.65);
    transition:.2s ease;
    position:relative;
}

.footer-link:hover{
    color:#fff;
}

.footer-link::after{
    content:"";
    position:absolute;
    left:0;
    bottom:-2px;
    width:0;
    height:1px;
    background:rgba(255,255,255,.8);
    transition:width .25s ease;
}

.footer-link:hover::after{
    width:100%;
}

/* FLOAT */
.whatsapp-float{
    position:fixed;
    right:16px;
    bottom:16px;
    z-index:1030;
    width:56px;
    height:56px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#25D366;
    color:#fff;
    font-size:1.5rem;
    box-shadow:0 18px 35px rgba(37,211,102,.30);
    transition:.28s ease;
    text-decoration:none;
    animation:whatsappPulsePremium 2.6s infinite;
}

.whatsapp-float:hover{
    color:#fff;
    transform:translateY(-4px);
    box-shadow:0 22px 42px rgba(37,211,102,.38);
}

/* MODALS */
.cookie-modal .modal-content,
.legal-modal .modal-content{
    border:0;
    border-radius:1.5rem;
    overflow:hidden;
    box-shadow:var(--shadow-strong);
}

.cookie-topbar,
.legal-topbar{
    height:5px;
    background:linear-gradient(90deg,var(--secondary),#ffd26b,var(--primary));
}

.cookie-icon,
.legal-icon{
    width:62px;
    height:62px;
    border-radius:1rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:rgba(244,163,0,.12);
    color:var(--secondary);
    font-size:1.65rem;
}

.legal-section{
    border:1px solid rgba(28,46,74,.08);
    border-radius:1rem;
    padding:1rem 1.1rem;
    background:#fff;
}

.legal-section h6{
    color:var(--primary);
    font-weight:800;
    margin-bottom:.5rem;
}

.legal-section p,
.legal-section li{
    color:var(--muted);
    line-height:1.75;
    font-size:.96rem;
}

/* BACK TO TOP */
.back-to-top{
    position:fixed;
    right:22px;
    bottom:86px;
    width:48px;
    height:48px;
    border:none;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    z-index:1031;
    opacity:0;
    visibility:hidden;
    transform:translateY(10px);
    background:var(--secondary);
    color:var(--primary);
    box-shadow:0 12px 24px rgba(0,0,0,.18);
    transition:
        opacity .25s ease,
        visibility .25s ease,
        transform .25s ease,
        box-shadow .25s ease;
}

.back-to-top.show{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
}

.back-to-top:hover{
    transform:translateY(-4px);
    box-shadow:0 16px 30px rgba(0,0,0,.22);
}

/* REVEAL */
.reveal,
.reveal-left,
.reveal-right,
.reveal-zoom{
    opacity:0;
    will-change:transform, opacity, filter;
    backface-visibility:hidden;
    transform-style:preserve-3d;
}

.reveal{
    transform:translateY(70px);
    filter:blur(10px);
    transition:
        opacity 1s cubic-bezier(.16,1,.3,1),
        transform 1s cubic-bezier(.16,1,.3,1),
        filter 1s cubic-bezier(.16,1,.3,1);
}

.reveal-left{
    transform:translateX(-90px) scale(.96);
    filter:blur(10px);
    transition:
        opacity 1s cubic-bezier(.16,1,.3,1),
        transform 1s cubic-bezier(.16,1,.3,1),
        filter 1s cubic-bezier(.16,1,.3,1);
}

.reveal-right{
    transform:translateX(90px) scale(.96);
    filter:blur(10px);
    transition:
        opacity 1s cubic-bezier(.16,1,.3,1),
        transform 1s cubic-bezier(.16,1,.3,1),
        filter 1s cubic-bezier(.16,1,.3,1);
}

.reveal-zoom{
    transform:translateY(35px) scale(.82);
    filter:blur(12px);
    transition:
        opacity 1.05s cubic-bezier(.16,1,.3,1),
        transform 1.05s cubic-bezier(.16,1,.3,1),
        filter 1.05s cubic-bezier(.16,1,.3,1);
}

.reveal.active,
.reveal-left.active,
.reveal-right.active,
.reveal-zoom.active{
    opacity:1!important;
    transform:none!important;
    filter:blur(0)!important;
}

.delay-1{ transition-delay:.14s; }
.delay-2{ transition-delay:.28s; }
.delay-3{ transition-delay:.42s; }

/* KEYFRAMES */
@keyframes fillFlask{
    0%{ height:0%; }
    100%{ height:80%; }
}

@keyframes dotPulse{
    0%,100%{ opacity:.35; transform:translateY(0); }
    50%{ opacity:1; transform:translateY(-4px); }
}

@keyframes gridFloat{
    0%{ transform:translateY(0); }
    50%{ transform:translateY(10px); }
    100%{ transform:translateY(0); }
}

@keyframes orbDriftOne{
    0%,100%{ transform:translate3d(0,0,0) scale(1); }
    50%{ transform:translate3d(-18px,16px,0) scale(1.06); }
}

@keyframes orbDriftTwo{
    0%,100%{ transform:translate3d(0,0,0) scale(1); }
    50%{ transform:translate3d(18px,-12px,0) scale(1.04); }
}

@keyframes badgeWave{
    0%,100%{ transform:translateY(0) rotate(0); }
    50%{ transform:translateY(-6px) rotate(-1deg); }
}

@keyframes screenBreath{
    0%,100%{ transform:rotateX(0) rotateY(0) translateY(0); }
    50%{ transform:rotateX(.6deg) rotateY(-1deg) translateY(-6px); }
}

@keyframes screenSweep{
    0%{ transform:translateX(-130%); }
    30%{ transform:translateX(130%); }
    100%{ transform:translateX(130%); }
}

@keyframes cardDock{
    0%,100%{ transform:translateY(0); }
    50%{ transform:translateY(-8px); }
}

@keyframes signalPulse{
    0%{ box-shadow:0 0 0 0 rgba(22,163,74,.45); }
    70%{ box-shadow:0 0 0 10px rgba(22,163,74,0); }
    100%{ box-shadow:0 0 0 0 rgba(22,163,74,0); }
}

@keyframes heroTitleEntrance{
    0%{
        opacity:0;
        transform:translateY(40px) scale(.94);
        filter:blur(8px);
    }
    100%{
        opacity:1;
        transform:translateY(0) scale(1);
        filter:blur(0);
    }
}

@keyframes heroTextEntrance{
    0%{
        opacity:0;
        transform:translateY(35px);
        filter:blur(6px);
    }
    100%{
        opacity:1;
        transform:translateY(0);
        filter:blur(0);
    }
}

@keyframes heroTitleFloat{
    0%,100%{ transform:translateY(0); }
    50%{ transform:translateY(-2px); }
}

@keyframes heroTextGlow{
    0%,100%{ opacity:1; }
    50%{ opacity:.92; }
}

@keyframes buttonSweep{
    0%{ left:-120%; }
    100%{ left:140%; }
}

@keyframes whatsappPulsePremium{
    0%,100%{
        transform:translateY(0) scale(1);
        box-shadow:0 18px 35px rgba(37,211,102,.30);
    }
    50%{
        transform:translateY(-6px) scale(1.07);
        box-shadow:0 26px 44px rgba(37,211,102,.42);
    }
}

@keyframes modalLiftIn{
    from{
        opacity:0;
        transform:translateY(18px) scale(.98);
    }
    to{
        opacity:1;
        transform:translateY(0) scale(1);
    }
}

/* MODAL IMAGE */
#galleryModal .modal-content{
    animation:modalLiftIn .35s cubic-bezier(.22,1,.36,1);
}

/* RESPONSIVE */
@media (max-width: 1199.98px){
    .navbar-search{ min-width:250px; }
}

@media (max-width: 991.98px){
    .hero-float-badge{
        position:static;
        margin-bottom:1rem;
        display:inline-flex!important;
    }

    .mini-floating-card{
        position:static;
        margin-top:1rem;
        width:100%;
        min-width:auto;
    }

    .navbar-collapse{
        background:#fff;
        border-radius:1.2rem;
        padding:1rem;
        margin-top:1rem;
        box-shadow:var(--shadow-soft);
        border:1px solid rgba(28,46,74,.06);
    }

    .navbar-search{
        min-width:100%;
        margin:1rem 0;
    }

    .plan-subtitle{ min-height:auto; }
}

@media (max-width: 767.98px){
    .logo-img{ max-height:62px; }
    .hero-title{ letter-spacing:-.05em; }
    .hero-text{ max-width:100%; }
    .logo-showcase-img{ max-width:220px; }

    .whatsapp-float{
        right:12px;
        bottom:12px;
        width:52px;
        height:52px;
        font-size:1.35rem;
    }

    .back-to-top{
        right:12px;
        bottom:74px;
        width:44px;
        height:44px;
    }
}

@media (prefers-reduced-motion: reduce){
    *,
    *::before,
    *::after{
        animation:none!important;
        transition:none!important;
        scroll-behavior:auto!important;
    }
}