:root{
  --navy:#001935; --blue:#0068b5; --teal:#66cae0; --deep:#304c7b;
  --bg:#ffffff; --text:#1d2228; --muted:#667385;
  --green:#14a06f; --rose:#e24f5e; --gold:#f3b734;

  --radius:16px; --shadow-sm:0 6px 18px rgba(0,0,0,.08);
  --shadow-md:0 12px 30px rgba(0,0,0,.14); --shadow-lg:0 22px 70px rgba(0,0,0,.18);

  --grad-hero: radial-gradient(1200px 600px at 85% -10%, rgba(102,202,224,.35), transparent 60%),
               radial-gradient(900px 500px at -10% 110%, rgba(0,104,181,.35), transparent 60%),
               linear-gradient(135deg,#001935 0%,#00477f 60%,#0068b5 100%);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.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}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
section[id]{scroll-margin-top:96px}


.header{position:sticky;top:0;z-index:40;background:rgba(0,25,53,.9);backdrop-filter:saturate(140%) blur(8px);box-shadow:var(--shadow-sm)}
.header__inner{display:flex;align-items:center;justify-content:space-between;min-height:78px}
.logo{display:inline-flex;align-items:center;max-width:240px}
.logo img{height:52px;width:auto;object-fit:contain;background-color:transparent}
.nav{display:flex;align-items:center;gap:18px}
.nav .m-item{color:#f4f8ff;font-weight:700;font-size:15px;letter-spacing:.01em;position:relative;padding:6px 0}
.nav .m-item::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;border-radius:999px;background:rgba(255,255,255,.75);opacity:0;transform:scaleX(.4);transition:opacity .25s ease,transform .25s ease}
.nav .m-item:hover::after,.nav .m-item:focus-visible::after{opacity:1;transform:scaleX(1)}
.btn{display:inline-flex;align-items:center;gap:10px;border:0;cursor:pointer;font-weight:800}
.btn--contact{background:var(--teal);color:#001123;padding:10px 20px;border-radius:999px;box-shadow:var(--shadow-sm);transition:transform .2s ease, box-shadow .25s ease}
.btn--contact:hover{transform:translateY(-1px);box-shadow:0 14px 36px rgba(102,202,224,.25)}
.hamburger{display:none;background:transparent;color:#fff;font-size:22px;border:0}
.mobileMenu{display:none;flex-direction:column;background:rgba(0,19,53,.96);padding:12px 16px;backdrop-filter:blur(10px)}
.mobileMenu.open{display:flex}
.mobileMenu .m-item{color:#fff;padding:12px;border-radius:10px;font-weight:700}
.mobileMenu .m-item--cta{background:var(--teal);color:#001123;font-weight:800}


.hero{background:var(--grad-hero);color:#fff;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:0;background:none;pointer-events:none}
.hero__inner{position:relative;display:grid;gap:clamp(32px,4vw,48px);align-items:start;grid-template-columns:1.15fr 1fr;padding:clamp(72px,12vh,128px) 0 clamp(56px,10vh,120px)}
.hero__copy{max-width:560px;display:flex;flex-direction:column;gap:18px;text-align:left}
.hero__title{display:flex;align-items:center;gap:12px;flex-wrap:nowrap;font-size:clamp(32px,calc(2.1rem + 1.8vw),56px);line-height:1.08;font-weight:800;letter-spacing:-.02em;text-shadow:0 0 24px rgba(102,202,224,.35)}
.hero__titleIcon{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:78px;height:78px;line-height:1;filter:drop-shadow(0 4px 10px rgba(0,0,0,.28))}
.heroIcon{width:100%;height:100%}
.heroIcon__hat{transform-origin:60px 40px;animation:heroHatSwing 3.8s ease-in-out infinite}
.heroIcon__hatTop{fill:#e24f5e}
.heroIcon__hatBrim{fill:#ffffff}
.heroIcon__pom{fill:#ffffff;transform-origin:18px 38px;animation:heroPomBounce 3.8s ease-in-out infinite}
.heroIcon__face{fill:none}
.heroIcon__beard{fill:#ffffff}
.heroIcon__head{fill:#fbe7d2}
.heroIcon__eye{fill:#1d2228}
.heroIcon__moustache{fill:#ffffff;opacity:.98}
.heroIcon__nose{fill:#f29b88}
.heroIcon__smile{fill:none;stroke:#c44b5b;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.heroIcon__cheek{fill:#f8b5a5;opacity:.85;animation:heroCheekGlow 4.8s ease-in-out infinite}
.heroIcon__cheek--right{animation-delay:1.8s}
.heroIcon__sparkle{fill:#f3b734;opacity:0;animation:heroSparkle 5s linear infinite}
.heroIcon__sparkle--two{animation-delay:2.1s}
.heroIcon__sparkle--three{animation-delay:3.7s}
.hero__titleText{display:block;min-width:0;flex:1 1 auto}
.hero__badge{position:relative;display:inline-flex;align-items:center;gap:10px;align-self:flex-start;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.35);border-radius:999px;padding:10px 18px;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.14em;overflow:visible}
.hero__badge::after{content:"";position:absolute;inset:-6px;border-radius:999px;border:1px solid rgba(255,255,255,.4);opacity:0;animation:badgePulse 3s ease-in-out infinite;pointer-events:none}
.hero__badgeDot{position:relative;width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(243,183,52,.25);animation:badgeDot 2.2s ease-in-out infinite}
.hero__badgeDot::after{content:"";position:absolute;inset:-5px;border-radius:50%;background:rgba(243,183,52,.25);opacity:.55;animation:badgeDotGlow 2.2s ease-in-out infinite;pointer-events:none}
.hero__subtitle{margin:0;font-size:20px;color:#eaf6ff}
.hl{background:linear-gradient(90deg, rgba(116,187,209,.28), rgba(102,202,224,.35)); color:#ffffff; padding:0 .25em; border-radius:8px}
.hero__bullets{list-style:none;display:grid;gap:12px;margin:12px 0 26px;text-align:left}
.bullet{display:flex;gap:12px;align-items:flex-start;font-size:18px;position:relative}
.bullet__ico{display:inline-flex;min-width:34px;min-height:34px;border-radius:10px;align-items:center;justify-content:center;color:#0b2a4a;background:#eaf6ff;box-shadow:0 0 24px rgba(116,187,209,.45)}
.bullet__ico svg{width:18px;height:18px}
.bullet--lines .bullet__ico{background:rgba(243,183,52,.18);color:#f1a90b;box-shadow:0 0 28px rgba(243,183,52,.35)}
.bullet--discount .bullet__ico{background:rgba(226,79,94,.16);color:#e24f5e;box-shadow:0 0 28px rgba(226,79,94,.35)}
.bullet--ship .bullet__ico{background:rgba(20,160,111,.16);color:#14a06f;box-shadow:0 0 28px rgba(20,160,111,.35)}

.hero__ctaRow{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));max-width:520px}
.hero__ctaRow .btn{justify-content:center;width:100%}
.btn--light{background:#fff;color:#0b2a4a;padding:12px 18px;border-radius:12px}
.btn--ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.7);padding:12px 18px;border-radius:12px}
.btn--primary{background:var(--teal);color:#001123;padding:12px 18px;border-radius:12px;box-shadow:var(--shadow-sm)}
.btn--full{width:100%}


.btn--whatsapp{
  background:#25D366;color:#001123;font-weight:800;
  padding:12px 18px;border-radius:12px;display:inline-flex;align-items:center;gap:8px;
  box-shadow:0 0 0 0 rgba(37,211,102,.55), 0 12px 30px rgba(0,0,0,.14);
  transition:box-shadow .25s ease, transform .2s ease;
}
.btn--whatsapp:hover{transform:translateY(-2px);box-shadow:0 0 24px 8px rgba(37,211,102,.35), 0 18px 44px rgba(0,0,0,.18)}
.btn--whatsapp svg{width:18px;height:18px;color:#001123}

.floatingWhatsapp{position:fixed;right:clamp(16px,3vw,28px);bottom:clamp(18px,4vw,34px);width:64px;height:64px;border-radius:50%;
  background:#25D366;color:#001123;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 24px 48px rgba(0,0,0,.28);
  transform:translateY(32px);opacity:0;visibility:hidden;transition:opacity .32s ease,transform .32s cubic-bezier(.22,.61,.36,1),
  box-shadow .3s ease;z-index:70;
}
.floatingWhatsapp svg{width:28px;height:28px;color:#001123}
.floatingWhatsapp.is-visible{opacity:1;visibility:visible;transform:translateY(0)}
.floatingWhatsapp.is-visible:hover{transform:translateY(-4px)}
.floatingWhatsapp:focus-visible{outline:3px solid rgba(255,255,255,.75);outline-offset:4px}

.hero__formCard{position:relative;background:#0a2645;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:22px;box-shadow:var(--shadow-md)}
.hero__formCard h3{font-size:22px;margin-bottom:10px}
label{font-weight:800;font-size:13px;color:#e9f6ff}
.f-requiredMark{color:var(--gold);margin-left:6px;font-size:16px;vertical-align:middle;filter:drop-shadow(0 0 10px rgba(243,183,52,.35))}
.f-group{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.f-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
input,select,textarea{background:#06223d;color:#e9f6ff;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:12px}
input::placeholder,textarea::placeholder{color:#b8d7ea}
input:focus,select:focus,textarea:focus{box-shadow:0 0 0 3px rgba(102,202,224,.25);outline:none}
.formFeedback{margin-top:8px;font-weight:700}
.hero__glow{position:absolute;inset:auto -30% -40% -30%;height:60%;background:radial-gradient(60% 60% at 50% 40%, rgba(102,202,224,.25), transparent 60%);filter:blur(70px);pointer-events:none}

@media (min-width:1025px) and (max-height:860px){
  .hero__inner{padding:clamp(56px,10vh,96px) 0 clamp(44px,9vh,88px)}
  .hero__copy{gap:16px}
  .hero__subtitle{font-size:19px}
  .hero__bullets{margin:10px 0 22px}
}

@media (min-width:1025px) and (max-height:740px){
  .hero__inner{padding:48px 0 52px}
  .hero__title{font-size:clamp(32px,2.4vw,48px)}
  .hero__titleIcon{width:72px;height:72px}
  .hero__badge{font-size:13px;padding:8px 16px}
  .hero__subtitle{font-size:18px}
  .hero__bullets{gap:10px}
  .bullet{font-size:17px}
  .bullet__ico{min-width:32px;min-height:32px}
}

@keyframes badgePulse{0%{opacity:0;transform:scale(.85)}45%{opacity:.7;transform:scale(1.05)}100%{opacity:0;transform:scale(1.35)}}
@keyframes badgeDot{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}
@keyframes badgeDotGlow{0%{transform:scale(.4);opacity:.55}60%{transform:scale(1.35);opacity:0}100%{transform:scale(1.35);opacity:0}}
@keyframes heroHatSwing{0%,100%{transform:rotate(-6deg)}45%{transform:rotate(5deg) translateY(-1px)}70%{transform:rotate(7deg) translateY(-2px)}}
@keyframes heroPomBounce{0%,100%{transform:translate(0,0)}50%{transform:translate(-2px,2px)}}
@keyframes heroCheekGlow{0%,100%{opacity:.78;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}
@keyframes heroSparkle{0%{opacity:0;transform:scale(.4)}10%{opacity:1;transform:scale(1)}20%{opacity:0;transform:scale(.2)}100%{opacity:0;transform:scale(.2)}}


.section{padding:84px 0}
.section--alt{background:linear-gradient(180deg,#f7fbff 0%, #ffffff 100%)}
.section__head{text-align:center;margin-bottom:28px}
.section__head h2{font-size:34px;color:var(--navy);letter-spacing:-.01em;font-weight:800}
.section__head p{color:var(--muted)}


.process{position:relative;overflow:hidden;background:linear-gradient(180deg,#f7fbff 0%,#ffffff 62%)}
.process__head{position:relative;z-index:1}
.process__head p{max-width:640px;margin:12px auto 0;color:var(--muted)}
.process__grid{position:relative;z-index:1;display:grid;gap:clamp(28px,4.2vw,48px);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-items:stretch}
.process__stage{position:relative;display:flex;align-items:stretch;min-width:0;height:100%}
.process__item{position:relative;z-index:1;background:rgba(255,255,255,.94);border:1px solid rgba(0,104,181,.16);border-radius:24px;padding:32px 26px 42px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;box-shadow:0 24px 54px rgba(0,25,53,.12);transition:transform .4s cubic-bezier(.22,.61,.36,1),box-shadow .35s ease,border-color .35s ease;overflow:hidden;backdrop-filter:blur(4px);flex:1 1 auto;min-width:0;height:100%}
.process__item::before{content:"";position:absolute;inset:-45% -45% auto -45%;height:70%;background:radial-gradient(circle at top,rgba(0,104,181,.38),rgba(0,104,181,0) 68%);opacity:0;transition:opacity .45s ease;pointer-events:none}
.process__item::after{content:"";position:absolute;inset:12px;border-radius:18px;border:1px solid rgba(102,202,224,.18);opacity:0;transition:opacity .35s ease}
.process__step{font-size:13px;letter-spacing:.4em;text-transform:uppercase;color:rgba(0,104,181,.7);font-weight:800}
.process__icon{position:relative;width:78px;height:78px;border-radius:26px;background:linear-gradient(135deg,rgba(0,104,181,.92),rgba(0,25,53,.92));color:#f4f8ff;display:grid;place-items:center;box-shadow:0 22px 40px rgba(0,104,181,.24);transition:transform .35s ease,box-shadow .35s ease;margin-inline:auto}
.process__icon::after{content:"";position:absolute;inset:-12px;border-radius:32px;border:1px solid rgba(255,255,255,.3);opacity:.35;transition:opacity .35s ease,transform .35s ease}
.process__icon svg{width:38px;height:38px}
.process__tap{background:none;border:0;padding:0;margin:0;color:inherit;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;width:100%;cursor:pointer}
.process__hint{display:none;align-items:center;gap:8px;padding:6px 16px;border-radius:999px;border:1px solid rgba(0,104,181,.22);background:rgba(0,104,181,.12);color:#0068b5;font-size:13px;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:background .25s ease,color .25s ease,border-color .25s ease;box-shadow:0 6px 16px rgba(0,104,181,.08);font-family:inherit}
.process__hint:hover{background:rgba(0,104,181,.18);border-color:rgba(0,104,181,.32)}
.process__hint:focus-visible{outline:3px solid rgba(102,202,224,.45);outline-offset:3px}
.process__hint::after{content:"›";display:inline-block;transform:rotate(90deg);font-size:12px;opacity:.72}
.process__tap:focus-visible{outline:3px solid rgba(102,202,224,.55);outline-offset:6px}
.process__copy{display:flex;flex-direction:column;gap:12px;text-align:center;align-items:center}
.process__item h3{font-size:20px;color:var(--navy)}
.process__item p{color:var(--muted);line-height:1.7;font-size:16px}
.process__ornament{position:absolute;width:520px;height:520px;border-radius:50%;filter:blur(120px);opacity:.35;pointer-events:none}
.process__ornament--one{top:-220px;left:-160px;background:radial-gradient(circle at center,rgba(0,104,181,.45),transparent 70%);animation:processGlow 16s ease-in-out infinite}
.process__ornament--two{bottom:-240px;right:-160px;background:radial-gradient(circle at center,rgba(102,202,224,.4),transparent 72%);animation:processGlow 18s ease-in-out infinite reverse}
@keyframes processGlow{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}
@media (hover:hover){
  .process__item:hover,.process__item:focus-within{transform:translateY(-14px);box-shadow:0 28px 64px rgba(0,25,53,.18);border-color:rgba(102,202,224,.45)}
  .process__item:hover::before,.process__item:focus-within::before{opacity:1}
  .process__item:hover::after,.process__item:focus-within::after{opacity:1}
  .process__item:hover .process__icon,.process__item:focus-within .process__icon{box-shadow:0 26px 52px rgba(0,104,181,.28)}
  .process__item:hover .process__icon::after,.process__item:focus-within .process__icon::after{opacity:.6;transform:scale(1.08)}
}
@media (max-width:1024px){
  .process__grid{gap:clamp(24px,5vw,40px)}
}
@media (max-width:720px){
  .process__grid{grid-template-columns:1fr;gap:clamp(20px,6vw,28px)}
  .process__stage{justify-content:center}
  .process--accordion .process__item{padding:24px 22px 30px}
  .process--accordion .process__tap{gap:12px}
  .process--accordion .process__hint{display:inline-flex}
  .process--accordion .process__copy{width:100%;max-height:0;opacity:0;overflow:hidden;pointer-events:none;transform:translateY(-6px);transition:max-height .35s ease,opacity .3s ease,transform .3s ease}
  .process--accordion .process__item.is-open .process__copy{margin-top:12px;max-height:320px;opacity:1;pointer-events:auto;transform:translateY(0)}
}
@media (max-width:520px){
  .process__item{padding:24px 20px 30px;gap:12px 16px}
  .process__icon{width:68px;height:68px}
  .process__icon svg{width:32px;height:32px}
  .process__step{font-size:12px;letter-spacing:.32em}
  .logo img{height:42px}
}
@media (prefers-reduced-motion: reduce){
  .process__ornament{animation:none!important}
  .process__item{transition-duration:.01ms!important}
  .heroIcon__hat{animation:none!important;transform:rotate(-4deg)}
  .heroIcon__pom{animation:none!important;transform:translate(-1px,1px)}
  .heroIcon__cheek{animation:none!important}
  .heroIcon__sparkle{animation:none!important;opacity:.35}
  .floatingWhatsapp{transition-duration:.01ms!important}
}


.carousel{position:relative}
.c-viewport{overflow:hidden;position:relative;-ms-touch-action:pan-y;touch-action:pan-y}
.c-track{
  display:flex; align-items:stretch; gap:18px;
  transition:transform .55s cubic-bezier(.22,.61,.36,1); will-change:transform;
  padding-inline:0;
}
.c-card{
  width:clamp(240px,84vw,340px) !important; flex:0 0 clamp(240px,84vw,340px) !important;  
  margin:0 0; background:#fff; border:1px solid #e9eef4; border-radius:var(--radius);
  box-shadow:var(--shadow-sm); overflow:hidden; display:flex; flex-direction:column;
  transform:scale(.92); opacity:.65; filter:blur(1.2px) saturate(.92);
  transition:transform .5s cubic-bezier(.22,.61,.36,1),opacity .45s ease,filter .45s ease,box-shadow .45s ease;
  transform-origin:center center; z-index:1;
}
.c-card.is-prev,.c-card.is-next{transform:scale(.96);opacity:.88;filter:blur(.6px) saturate(.96);z-index:2}
.c-card.is-active{transform:scale(1.06);opacity:1;filter:none;z-index:3;box-shadow:var(--shadow-lg)}
.c-media{position:relative;aspect-ratio:1/1;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:clamp(10px,1.8vw,18px);background:transparent}
.c-media img{width:100%;height:100%;object-fit:contain;transform:none;background-color:transparent}
.c-hint{position:absolute;left:50%;bottom:12px;transform:translate(-50%,0);padding:10px 16px;border-radius:999px;background:rgba(255,255,255,.95);color:#0b2a4a;font-size:13px;font-weight:700;letter-spacing:.01em;box-shadow:0 18px 34px rgba(0,25,53,.18);border:1px solid rgba(0,104,181,.22);display:none;align-items:center;gap:6px;white-space:nowrap;pointer-events:none;z-index:4}
.c-hint::after{content:"";position:absolute;bottom:-6px;left:50%;width:10px;height:10px;border-radius:3px;transform:translateX(-50%) rotate(45deg);background:rgba(255,255,255,.95);border:1px solid rgba(0,104,181,.22);border-top-color:transparent;border-left-color:transparent;box-shadow:6px 6px 12px rgba(0,25,53,.1)}
@keyframes cHintFloat{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,-6px)}}
.c-pill{position:absolute;top:10px;left:10px;background:#0b2a4a;color:#fff;padding:6px 10px;font-weight:800;border-radius:999px;font-size:12px}
.c-pill--eco{background:#62caa7}.c-pill--classic{background:#66cae0}.c-pill--signature{background:#666fb2}.c-pill--premium{background:#0068b5}.c-pill--deluxe{background:#304c7b}
.c-title{font-size:20px;color:var(--navy);padding:16px 16px 8px;font-weight:800;text-align:center}


.c-prices{display:flex;justify-content:center;gap:12px;list-style:none;padding:0 16px 10px;margin:0}
.c-prices li{display:flex;flex-direction:column;align-items:center;gap:4px;background:#f3f8fc;border:1px solid #e3eef6;color:#003354;padding:12px 14px;border-radius:12px;min-width:130px}
.c-prices span{font-size:12px;opacity:.7}
.c-prices strong{font-size:18px}


.c-toggle{margin:8px auto 14px;background:#f4f9ff;color:var(--blue);border:1px solid #d9eefd;padding:10px 14px;border-radius:12px;font-weight:800;cursor:pointer;z-index:3;position:relative}
.c-details{overflow:hidden;height:0;transition:height .35s ease;border-top:1px dashed #e6edf5}
.c-details .inner{padding:14px 16px 16px}
.c-details ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;margin:0;padding:0}
.c-details li{display:flex;gap:8px;align-items:flex-start}
.c-details li::before{content:"";width:8px;height:8px;border-radius:2px;background:#14a06f;margin-top:8px}

.boxModal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:32px;background:rgba(3,20,40,.55);backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .28s ease;z-index:90}
.boxModal.is-open{opacity:1;pointer-events:auto}
.boxModal__overlay{position:absolute;inset:0;background:rgba(3,20,40,.55)}
.boxModal__dialog{position:relative;z-index:1;background:#f7fbff;border-radius:28px;box-shadow:0 40px 90px rgba(3,20,40,.32);padding:40px clamp(26px,5vw,54px);width:min(960px,100%);max-height:min(92vh,760px);overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:26px;color:var(--navy);padding-bottom:48px}
.boxModal__dialog{padding-bottom:calc(48px + env(safe-area-inset-bottom))}
@supports (height: 100dvh){
  .boxModal__dialog{max-height:min(92dvh,760px)}
}
.boxModal__close{position:absolute;top:20px;right:22px;width:42px;height:42px;border-radius:50%;border:1px solid rgba(3,20,40,.16);background:#fff;color:var(--navy);font-size:22px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 16px 32px rgba(3,20,40,.16);transition:background .2s ease,transform .2s ease,box-shadow .2s ease;z-index:8}
.boxModal__close:hover{background:#e6f2fb;transform:translateY(-1px);box-shadow:0 20px 40px rgba(3,20,40,.2)}
.boxModal__close:focus-visible{outline:3px solid rgba(0,104,181,.45);outline-offset:2px}
.boxModal__layout{display:grid;grid-template-columns:1.15fr 1fr;gap:28px;align-items:flex-start}
.boxModal__media{position:relative;border-radius:22px;overflow:hidden;box-shadow:0 28px 60px rgba(0,25,53,.25);display:flex;align-items:center;justify-content:center;background:transparent}
.boxModal__media img{width:100%;height:100%;object-fit:contain;background-color:transparent}
.boxModal__pill{position:absolute;top:16px;left:16px;padding:8px 14px;font-weight:800;border-radius:999px;font-size:13px;color:#fff;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 12px 26px rgba(0,25,53,.22);display:none}
.boxModal__info{display:flex;flex-direction:column;gap:16px}
.boxModal__info h3{font-size:28px;letter-spacing:-.01em}
.boxModal__prices{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.boxModal__price{background:#edf4fb;border:1px solid #dbe7f5;border-radius:16px;padding:14px 18px;display:flex;flex-direction:column;gap:6px}
.boxModal__price span{font-size:12px;letter-spacing:.04em;text-transform:none;color:var(--muted)}
.boxModal__price strong{font-size:20px;color:var(--navy)}
.boxModal__info h4{font-size:16px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.boxModal__list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 18px;color:var(--deep)}
.boxModal__list li{position:relative;padding-left:16px;line-height:1.55}
.boxModal__list li::before{content:"";position:absolute;left:0;top:.6em;width:8px;height:8px;border-radius:2px;background:var(--teal)}
.boxModal__cta{margin-top:8px;align-self:flex-start}
.boxModal__pill[data-variant="eco"]{background:#62caa7}
.boxModal__pill[data-variant="classic"]{background:#66cae0}
.boxModal__pill[data-variant="signature"]{background:#666fb2}
.boxModal__pill[data-variant="premium"]{background:#0068b5}
.boxModal__pill[data-variant="deluxe"]{background:#304c7b}

body.modal-open{overflow:hidden}


.c-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;border:0;cursor:pointer;color:#fff;background:linear-gradient(180deg,#0068b5,#304c7b);box-shadow:var(--shadow-sm);z-index:5}
.c-prev{left:-6px}.c-next{right:-6px}
.c-dots{display:flex;justify-content:center;gap:8px;margin-top:12px}
.c-dots .dot{width:8px;height:8px;border-radius:50%;border:0;background:#cfe3f7}
.c-dots .dot.is-active{background:#0068b5}

@media (min-width:1024px){
  .carousel{padding-bottom:12px}
  .carousel .c-viewport{overflow:visible}
  .carousel .c-track{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:1fr;gap:28px;padding:0!important;transform:none!important;transition:none!important}
  .c-card{width:100%!important;flex:auto!important;transform:none!important;opacity:1!important;filter:none!important;box-shadow:var(--shadow-md);cursor:pointer;position:relative;transition:transform .35s ease,box-shadow .35s ease}
  .c-card::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:0 0 0 0 rgba(102,202,224,.35);opacity:0;transition:opacity .3s ease,box-shadow .3s ease;pointer-events:none}
  .c-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
  .c-card:hover::after{opacity:1;box-shadow:0 0 24px 6px rgba(102,202,224,.35)}
  .c-card:focus-visible{outline:3px solid rgba(102,202,224,.65);outline-offset:4px}
  .c-card .c-toggle{display:none}
  .c-card .c-details{display:none!important}
  .c-card:last-child:nth-child(odd){grid-column:1/-1;max-width:520px;justify-self:center}
  .c-prices{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
  .c-prices li{width:100%}
  .c-arrow,.c-dots{display:none!important}
  .c-hint{display:inline-flex;animation:cHintFloat 3.8s ease-in-out infinite}
  .c-card:hover .c-hint,.c-card:focus-visible .c-hint{animation:none;transform:translate(-50%,-4px) scale(1.02);box-shadow:0 24px 44px rgba(0,25,53,.24)}
}

@media (prefers-reduced-motion: reduce){
  .c-hint{animation:none!important}
}


.faq__list{max-width:880px;margin:0 auto;display:grid;gap:18px}
.faq__list details{background:linear-gradient(135deg,rgba(247,251,255,.85),#ffffff);border:1px solid rgba(3,20,40,.08);border-radius:16px;padding:20px 24px;box-shadow:0 12px 34px rgba(3,20,40,.08);transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.faq__list details.is-open{border-color:rgba(0,104,181,.35);box-shadow:0 18px 46px rgba(0,25,53,.12);transform:translateY(-2px)}
.faq__list summary{font-weight:800;color:var(--navy);cursor:pointer;font-size:20px;display:flex;align-items:center;gap:14px;list-style:none;user-select:none}
.faq__list summary::-webkit-details-marker{display:none}
.faq__list summary::after{content:"+";margin-left:auto;width:28px;height:28px;border-radius:50%;border:1px solid rgba(0,25,53,.12);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;background:#f0f6fc;color:var(--blue);transition:transform .28s ease, background .28s ease,color .28s ease}
.faq__list details.is-open summary::after{background:var(--blue);color:#fff;transform:rotate(45deg)}
.faq__content{margin-top:12px;height:0;overflow:hidden;opacity:0;transition:height .3s ease, opacity .3s ease}
.faq__list details.is-open .faq__content{opacity:1}
.faq__content p{margin:0;color:var(--muted);line-height:1.7}


.bigt{position:relative}
.t-viewport{overflow:hidden}
.t-track{display:flex;will-change:transform;transition:transform .55s cubic-bezier(.22,.61,.36,1)}
.t-track{gap:22px;padding-inline:0}
.t-card{
  min-width:clamp(280px,74vw,380px); background:#fff; border:1px solid #e1e9f2; border-radius:22px;
  box-shadow:0 20px 44px rgba(0,25,53,.12); padding:32px clamp(24px,6vw,72px); margin:0;
  display:flex; flex-direction:column; gap:16px;
}
.t-card__head{display:flex;gap:14px;align-items:center}
.t-card__head img{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid #cfe3f7}
.t-card__text{font-size:18px;line-height:1.65;color:#2d3642;font-weight:500}
.t-arrow{display:none!important}
.t-dots{display:flex;gap:8px;justify-content:center;margin-top:12px}
.t-dots .dot{width:8px;height:8px;border-radius:50%;background:#cfe3f7}
.t-dots .dot.is-active{background:#0068b5}

@media (max-width:768px){
  .carousel .c-track{gap:14px}
  .c-card{width:min(92vw,340px)!important;flex-basis:min(92vw,340px)!important;transform:none!important;opacity:1!important;filter:none!important;box-shadow:var(--shadow-md)}
  .c-card.is-active,.c-card.is-prev,.c-card.is-next{transform:none!important;opacity:1!important;filter:none!important}
  .c-title{font-size:22px}
  .c-prices{flex-direction:column;align-items:stretch;gap:10px}
  .c-prices li{width:100%;min-width:unset}
  .c-prices strong{font-size:20px}
  .c-toggle{width:calc(100% - 32px)}
  .c-details .inner{padding-inline:18px}
  .t-card{align-items:center;text-align:center;padding:26px 20px;margin:0 auto;max-width:480px}
  .t-card__head{flex-direction:column;text-align:center}
  .t-card__head div{text-align:center}
  .t-card__text{font-size:17px}
  .t-track{gap:16px}
  .t-card{min-width:82vw}
}

@media (max-width:720px){
  .boxModal{padding:24px;align-items:flex-start}
  .boxModal__dialog{padding:32px 24px;max-height:calc(100vh - 40px);padding-bottom:32px}
  .boxModal__dialog{padding-bottom:calc(32px + env(safe-area-inset-bottom))}
  @supports (height: 100dvh){
    .boxModal__dialog{max-height:calc(100dvh - 40px)}
  }
  .boxModal__layout{grid-template-columns:1fr;gap:20px}
  .boxModal__prices{grid-template-columns:1fr}
  .boxModal__list{grid-template-columns:1fr}
  .boxModal__cta{width:100%;justify-content:center}
  .boxModal__close{top:16px;right:18px;width:40px;height:40px}
  .logo img{height:46px}
}

@media (min-width:1024px){
  .bigt{padding:0 18px}
  .t-viewport{overflow:visible}
  .t-track{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:auto auto;gap:32px 36px;padding-inline:0!important;transform:none!important;will-change:auto}
  .t-card{min-width:0;width:100%;max-width:520px;padding:36px clamp(28px,4vw,40px);animation:cardFloat 12s ease-in-out infinite;transition:transform .4s cubic-bezier(.22,.61,.36,1),box-shadow .35s ease}
  .t-card:nth-child(1){grid-column:1/-1;justify-self:center;max-width:640px}
  .t-card:nth-child(2){grid-column:1;grid-row:2;justify-self:end;animation-delay:1.2s}
  .t-card:nth-child(3){grid-column:2;grid-row:2;justify-self:start;animation-delay:2.4s}
  .t-card__text{font-size:20px;line-height:1.85;display:block;-webkit-line-clamp:unset;-webkit-box-orient:unset;overflow:visible}
  .t-dots{display:none}
}
@media (min-width:1280px){
  .t-track{gap:36px 48px}
  .t-card{max-width:560px}
  .t-card:nth-child(1){max-width:680px}
}
@keyframes cardFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media (min-width:1024px) and (hover:hover){
  .t-card:hover,.t-card:focus-within{animation-play-state:paused;transform:translateY(-14px);box-shadow:0 28px 64px rgba(0,25,53,.18)}
}
@media (prefers-reduced-motion: reduce){
  .t-card{animation:none!important}
}


.callout{padding:96px 0;background:radial-gradient(720px 280px at 50% 10%, rgba(102,202,224,.25), transparent 60%), linear-gradient(180deg,#f7fbff 0%, #ffffff 100%)}
.callout__card{display:flex;flex-direction:column;align-items:center;text-align:center;background:#0a2645;color:#eaf6ff;border:1px solid rgba(255,255,255,.18);border-radius:24px;padding:48px 30px 72px;max-width:760px;margin:0 auto;gap:18px;box-shadow:0 36px 90px rgba(0,25,53,.28)}
.callout__card h2{font-size:36px;letter-spacing:-.01em}
.callout__card p{font-size:18px;color:#d9ecff;max-width:520px}
.callout__card .btn--light{padding:16px 32px;font-size:16px;margin-top:0;align-self:center;margin-inline:auto}
.footer{background:#031428;color:#cfe3f7;padding:48px 0 28px}
.footer__inner{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:32px 48px;align-items:flex-start}
.footer__col h4{font-size:16px;letter-spacing:.08em;text-transform:uppercase;color:#8fb0d0;margin-bottom:14px}
.f-brand p{margin-top:12px;max-width:280px;color:#d9e6f4;line-height:1.6}
.f-links{display:flex;flex-direction:column;align-items:flex-start}
.footer__col a{display:inline-flex;align-items:center;color:#eaf6ff;margin-bottom:10px;font-weight:600;transition:color .2s ease, transform .2s ease}
.footer__col a:hover{color:#66cae0;transform:translateX(2px)}
.f-contact__item{display:flex;align-items:center;gap:12px;font-size:15px;width:100%;color:#eaf6ff}
.f-contact__icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;color:inherit;opacity:.82}
.f-contact__icon svg{width:22px;height:22px}
.f-social{margin-top:12px;display:flex;flex-direction:column;gap:10px}
.f-social span{font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:#8fb0d0}
.f-social__list{display:flex;gap:12px}
.f-social__list a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;color:#fefefe;transition:background .2s ease, transform .2s ease;margin-bottom:0}
.f-social__list a:hover{background:rgba(102,202,224,.35);transform:translateY(-2px)}
.footer__bottom{margin-top:40px;padding-top:20px;border-top:1px solid rgba(255,255,255,.14);text-align:center}
.footer__bottom small{color:#8fb0d0}


@media (max-width:1100px){
  .c-card{width:320px !important;flex-basis:320px !important}
}
@media (max-width:1024px){
  .container{padding:0 22px}
  .hero__inner{grid-template-columns:1fr;gap:36px;padding:112px 0 96px}
  .hero__copy{order:1;text-align:center;align-items:center;max-width:unset;gap:16px}
  .hero__badge{align-self:center}
  .hero__title{font-size:46px;justify-content:center;text-align:center}
  .hero__titleText{text-align:center}
  .hero__subtitle{font-size:18px;line-height:1.6}
  .hero__bullets{justify-items:center;margin:10px 0 22px}
  .hero__formCard{order:2;margin:0 auto;max-width:520px;width:100%}
  .hero__ctaRow{margin:0 auto;gap:12px}
  .f-grid{grid-template-columns:1fr}
  .hamburger{display:inline-flex}
  .nav{display:none}
  .c-prev{left:4px}.c-next{right:4px}
}
@media (max-width:768px){
  .hero__inner{gap:24px;padding:84px 0 78px}
  .hero__copy{padding-inline:clamp(12px,6vw,28px);gap:12px}
  .hero__bullets{justify-items:stretch;text-align:left;margin:6px 0 16px;gap:10px}
  .hero__ctaRow{grid-template-columns:1fr;justify-items:center;width:100%;max-width:min(100%,420px);gap:10px}
  .hero__ctaRow .btn{width:100%;padding:12px 16px}
  .hero__formCard{margin:clamp(28px,10vh,96px) auto 0;width:calc(100% - 16px);padding:26px clamp(18px,5vw,24px)}
  .hero__badge{font-size:12px;padding:9px 16px}
  .hero__subtitle{font-size:17px;line-height:1.6}
  .bullet{font-size:16px}
  .bullet__ico{min-width:30px;min-height:30px}
  .bullet__ico svg{width:16px;height:16px}
}
@media (max-width:560px){
  .hero__title{font-size:36px;line-height:1.05;padding:0 6px}
  .hero__badge{font-size:11px;letter-spacing:.1em;padding:8px 14px}
  .hero__subtitle{font-size:16px}
  .hero__titleIcon{width:64px;height:64px}
  .hero__bullets{gap:9px;margin:8px 0 16px}
  .hero__ctaRow .btn{padding:11px 16px}
  .c-prices li{min-width:128px;padding:10px}
  .c-details ul{grid-template-columns:1fr}
  .t-card__text{font-size:17px}
  .callout__card{padding:40px 22px 64px;gap:16px}
  .callout__card h2{font-size:30px}
  .callout__card p{font-size:17px}
  .callout__card .btn--light{margin-top:0;padding:16px 28px;width:auto;max-width:100%}
  .section{padding:68px 0}
  .section__head h2{font-size:28px}
  .section__head p{font-size:16px}
  .faq__list summary{font-size:18px}
  .faq__content p{font-size:16px}
}

@media (max-width:480px){
  .container{padding:0 18px}
  .hero__inner{padding:76px 0 72px}
  .hero__copy{gap:12px}
  .hero__subtitle{font-size:16px}
  .hero__bullets{gap:7px;font-size:15px;margin:6px 0 14px}
  .bullet{font-size:15px}
  .bullet__ico{min-width:28px;min-height:28px}
  .hero__formCard{padding:20px 18px}
  .hero__ctaRow{width:100%;max-width:min(100%,360px);gap:10px}
  .c-prices{flex-direction:column;align-items:stretch}
  .c-prices li{min-width:unset;width:100%}
  input,select,textarea{font-size:16px}
  .boxModal{padding:20px}
  .boxModal__dialog{padding:28px 20px;max-height:calc(100vh - 24px);padding-bottom:28px}
  .boxModal__dialog{padding-bottom:calc(28px + env(safe-area-inset-bottom))}
  @supports (height: 100dvh){
    .boxModal__dialog{max-height:calc(100dvh - 24px)}
  }
  .boxModal__close{top:12px;right:14px;width:36px;height:36px}
  .floatingWhatsapp{width:56px;height:56px;right:clamp(14px,4vw,22px);bottom:clamp(14px,6vw,28px)}
  .floatingWhatsapp svg{width:24px;height:24px}
}

@media (max-width:420px){
  .hero__title{font-size:32px}
  .hero__subtitle{font-size:16px}
  .hero__formCard{padding:18px 16px}
  .btn{font-size:15px}
}

@media (max-width:360px){
  .container{padding:0 14px}
  .hero__title{font-size:30px}
  .hero__subtitle{font-size:15px}
  .hero__titleIcon{width:58px;height:58px}
  .hero__bullets{font-size:14px}
  .bullet{font-size:14px}
  .bullet__ico{min-width:26px;min-height:26px}
}
