:root{
  --celeste:#5aa9c1;
  --violeta:#5d3288;
  --violeta2:#8b5cc8;
  --bg:#f7f9fc;
  --bg2:#ffffff;
  --bg3:#eef4f8;
  --text:#111827;
  --muted:#5c6976;
  --line:rgba(17,24,39,.08);
  --shadow:0 18px 50px rgba(17,24,39,.08);
  --radius:22px;
  --radius-sm:14px;
  --font:'Montserrat',sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  background:
    radial-gradient(circle at top, rgba(90,169,193,.16), transparent 28%),
    linear-gradient(180deg,#fff 0%,#f7f9fc 45%,#f4f7fb 100%);
  color:var(--text);
  overflow-x:hidden;
}
body.menu-open{overflow:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,textarea{font-family:inherit}

.container{width:min(1180px, calc(100% - 28px)); margin:0 auto}
.section{padding:84px 0}
.eyebrow{display:inline-block;font-size:.72rem;letter-spacing:3px;text-transform:uppercase;color:var(--violeta);font-weight:900;margin-bottom:12px}
.eyebrow.center{display:block;text-align:center}
.section-title{font-size:clamp(1.8rem,4vw,3rem);font-weight:900;line-height:1.08;letter-spacing:-.05em}
.section-title.center{text-align:center}
.section-subtitle{max-width:700px;margin:12px auto 0;text-align:center;color:var(--muted);font-size:1rem;line-height:1.7}

.btn-primary,.btn-secondary,.btn-whatsapp{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 26px;border-radius:999px;font-weight:800;font-size:.9rem;
  transition:.25s ease;box-shadow:var(--shadow)
}
.btn-primary{background:linear-gradient(135deg,var(--celeste),var(--violeta2));color:#fff}
.btn-secondary{background:#fff;border:1px solid var(--line);color:var(--text)}
.btn-whatsapp{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff}
.btn-primary:hover,.btn-secondary:hover,.btn-whatsapp:hover{transform:translateY(-2px)}

/* NAV */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;padding:14px 0;transition:.25s ease;
}
.navbar.scrolled{
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  width:min(1180px, calc(100% - 28px));
  margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:14px
}
.nav-logo{
  font-size:1.32rem;font-weight:900;font-style:italic;letter-spacing:-.04em;
  background:linear-gradient(135deg,var(--celeste),var(--violeta));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent
}
.nav-links{display:flex;gap:24px;align-items:center}
.nav-links a{font-size:.84rem;font-weight:800;color:var(--muted);position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--celeste);transition:.25s ease}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:10px}
.icon-btn,.burger,.close-btn{
  border:1px solid var(--line);background:#fff;border-radius:14px
}
.icon-btn{
  width:42px;height:42px;display:grid;place-items:center;position:relative
}
.icon-btn b{
  position:absolute;top:-5px;right:-5px;width:18px;height:18px;border-radius:50%;
  display:grid;place-items:center;background:var(--violeta);color:#fff;font-size:.64rem;font-weight:900;
  transform:scale(0)
}
.icon-btn b.show{transform:scale(1)}
.burger{display:none;width:42px;height:42px;padding:10px}
.burger span{display:block;height:2px;background:var(--text);border-radius:999px;margin:4px 0;transition:.25s ease}
.burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* HERO */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:92px 0 56px;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 18%, rgba(124,199,218,.28), transparent 18%),
    radial-gradient(circle at 78% 16%, rgba(139,92,200,.18), transparent 18%),
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.95), transparent 42%);
  pointer-events:none;
}
.hero-glow{
  position:absolute;left:50%;bottom:-10%;
  width:min(760px, 92vw);height:min(760px, 92vw);
  transform:translateX(-50%);
  background:radial-gradient(circle, rgba(90,169,193,.18), transparent 68%);
  filter:blur(10px);
  pointer-events:none;
}
.hero-inner{
  position:relative;z-index:1;
  width:min(860px, calc(100% - 24px));
  text-align:center
}
.hero-topline{
  display:flex;
  justify-content:center;
  margin-bottom:16px
}
.top-pill{
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.82);
  border:1px solid var(--line);
  font-size:.72rem;
  font-weight:900;
  color:var(--violeta);
  letter-spacing:1px
}
.hero-spotlight{
  width:min(100%, 620px);
  margin:0 auto;
  padding:26px 18px 20px;
  border-radius:28px;
  background:rgba(255,255,255,.58);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 18px 40px rgba(17,24,39,.06);
}
.moon-row{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.moon-row span{font-size:1.05rem;opacity:.42}
.moon-full{font-size:1.45rem !important;opacity:1 !important}
.hero-title{
  font-size:clamp(2.8rem, 12vw, 6.5rem);
  font-weight:900;font-style:italic;line-height:.95;letter-spacing:-.08em;margin-bottom:10px;
  background:linear-gradient(135deg,var(--celeste),var(--violeta));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent
}
.hero-tagline{
  font-size:.62rem;font-weight:900;letter-spacing:4px;color:var(--violeta);margin-bottom:10px
}
.hero-copy{
  max-width:520px;margin:0 auto 18px;color:var(--muted);font-size:.95rem;line-height:1.7
}
.hero-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.hero-mini-note{
  margin-top:14px;
  font-size:.74rem;
  color:var(--muted);
  font-weight:700;
}
.scroll-indicator{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  width:2px;height:42px;background:linear-gradient(180deg,var(--celeste),transparent);
  animation:scroll 2s infinite ease-in-out
}
@keyframes scroll{0%,100%{opacity:.55;transform:translateX(-50%) translateY(0)}50%{opacity:1;transform:translateX(-50%) translateY(8px)}}

/* SPLIT */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center}
.split-text h2{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:900;letter-spacing:-.04em;margin-bottom:14px}
.split-text p{color:var(--muted);line-height:1.8;margin-bottom:14px;font-size:.98rem}
.values{display:grid;gap:12px;margin-top:24px}
.value-card{
  display:flex;gap:14px;padding:16px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:0 10px 30px rgba(17,24,39,.04)
}
.value-card span{font-size:1.2rem}
.value-card strong{display:block;margin-bottom:4px;font-size:.92rem}
.value-card p{margin:0;font-size:.82rem;line-height:1.55;color:var(--muted)}
.split-visual{display:flex;justify-content:center}
.moon-orb{position:relative;width:min(340px,78vw);aspect-ratio:1;display:grid;place-items:center}
.orb{position:absolute;border-radius:50%}
.orb-1{inset:0;background:radial-gradient(circle, rgba(90,169,193,.18), transparent 70%);filter:blur(2px)}
.orb-2{inset:14%;border:1px solid rgba(90,169,193,.22);animation:spin 24s linear infinite}
.orb-core{inset:22%;background:linear-gradient(135deg,var(--violeta),var(--violeta2),var(--celeste));box-shadow:inset -18px -10px 36px rgba(0,0,0,.18), 0 0 50px rgba(139,92,200,.28)}
@keyframes spin{to{transform:rotate(360deg)}}

/* MARQUEE */
.marquee-section{padding:0 0 20px}
.marquee{overflow:hidden;background:linear-gradient(90deg, rgba(90,169,193,.12), rgba(93,50,136,.08));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marquee-track{display:flex;gap:34px;width:max-content;white-space:nowrap;padding:14px 0;animation:marquee 20s linear infinite}
.marquee-track span,.info-track span{font-size:.78rem;font-weight:900;letter-spacing:4px;text-transform:uppercase;color:var(--violeta)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* PRODUCTS */
.filters{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin:34px 0 28px}
.filter-btn{
  padding:9px 16px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--muted);font-size:.78rem;font-weight:900
}
.filter-btn.active{background:linear-gradient(135deg,var(--celeste),var(--violeta2));color:#fff;border-color:transparent}
.products-grid{
  width:min(100%, 1020px);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:18px;
  justify-items:stretch;
}
.pcard{
  background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:0 14px 38px rgba(17,24,39,.05);transition:.25s ease
}
.pcard:hover{transform:translateY(-4px)}
.pcard-img{
  position:relative;aspect-ratio:1/1;overflow:hidden;background:linear-gradient(180deg,#f8fbfd,#edf4f8)
}
.pcard-img img{width:100%;height:100%;object-fit:contain;padding:12px}
.pbadge{
  position:absolute;top:12px;left:12px;padding:4px 9px;border-radius:999px;font-size:.64rem;font-weight:900;text-transform:uppercase;letter-spacing:.7px
}
.bp{background:rgba(90,169,193,.16);color:var(--celeste)}
.bi{background:rgba(93,50,136,.14);color:var(--violeta)}
.ba{background:rgba(93,50,136,.18);color:var(--violeta)}
.bn{background:rgba(90,169,193,.95);color:#fff}
.pcard-body{padding:16px}
.pcard-name{font-weight:900;font-size:.98rem;letter-spacing:-.02em;margin-bottom:6px}
.pcard-desc{color:var(--muted);font-size:.81rem;line-height:1.55;margin-bottom:14px}
.pcard-foot{display:flex;align-items:center;justify-content:space-between;gap:12px}
.pcard-price{font-size:1rem;font-weight:900;color:var(--violeta)}
.pcard-price small{display:block;font-size:.66rem;font-weight:700;color:var(--muted)}
.btn-plus{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--celeste),var(--violeta2));color:#fff;font-size:1.2rem;font-weight:900
}

/* PHASES */
.phases-line{
  margin-top:34px;
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:12px;
}
.phase-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px 12px;text-align:center;box-shadow:0 12px 28px rgba(17,24,39,.04)
}
.phase-card.highlight{background:linear-gradient(180deg, rgba(90,169,193,.1), rgba(93,50,136,.08));border-color:rgba(90,169,193,.18)}
.phase-card span{font-size:1.8rem;display:block;margin-bottom:8px}
.phase-card strong{display:block;font-size:.76rem;margin-bottom:6px}
.phase-card p{font-size:.7rem;color:var(--muted);line-height:1.45}

/* INFO STRIP */
.info-strip{
  overflow:hidden;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(90,169,193,.14), rgba(93,50,136,.1));
  border:1px solid var(--line)
}
.info-track{display:flex;gap:28px;width:max-content;padding:14px 0;animation:marquee 18s linear infinite}

/* CONTACT */
.contact-form{
  display:grid;gap:14px;background:#fff;border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:var(--shadow)
}
.contact-form input,.contact-form textarea{
  width:100%;border:1px solid var(--line);border-radius:16px;padding:14px 16px;font-size:.92rem;outline:none;background:#fff
}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--celeste);box-shadow:0 0 0 4px rgba(90,169,193,.12)}

/* FLOATING CART */
.floating-cart{
  position:fixed;right:16px;bottom:16px;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,var(--violeta),var(--violeta2));color:#fff;z-index:1200;
  box-shadow:0 16px 40px rgba(93,50,136,.28);display:grid;place-items:center
}
.floating-cart b{
  position:absolute;top:-4px;right:-2px;width:20px;height:20px;border-radius:50%;
  background:var(--celeste);color:#fff;font-size:.66rem;display:grid;place-items:center;transform:scale(0)
}
.floating-cart b.show{transform:scale(1)}

/* CART */
.side-overlay{
  position:fixed;inset:0;background:rgba(17,24,39,.42);opacity:0;pointer-events:none;transition:.25s ease;z-index:1300
}
.side-overlay.show{opacity:1;pointer-events:auto}
.cart-panel{
  position:fixed;top:0;right:0;bottom:0;width:min(420px,100vw);background:#fff;transform:translateX(100%);
  transition:.28s ease;z-index:1400;display:flex;flex-direction:column;box-shadow:-20px 0 60px rgba(17,24,39,.1)
}
.cart-panel.show{transform:translateX(0)}
.cart-panel-head{
  display:flex;justify-content:space-between;align-items:center;padding:18px;border-bottom:1px solid var(--line)
}
.cart-panel-head strong{font-size:1rem;font-weight:900}
.close-btn{
  width:38px;height:38px;border-radius:50%;font-size:1.3rem
}
.cart-panel-body{
  flex:1;overflow:auto;padding:16px 18px;display:grid;gap:12px
}
.cart-empty{text-align:center;color:var(--muted);padding:40px 10px}
.cart-item{
  display:flex;gap:12px;align-items:center;padding:12px;border:1px solid var(--line);border-radius:18px;background:#fff
}
.cart-item img{width:56px;height:56px;border-radius:14px;object-fit:contain;background:linear-gradient(180deg,#f8fbfd,#edf4f8)}
.ci-info{flex:1;min-width:0}
.ci-name{font-size:.85rem;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ci-price{font-size:.78rem;color:var(--violeta);font-weight:800;margin-top:3px}
.ci-controls{display:flex;align-items:center;gap:6px}
.ci-btn{width:28px;height:28px;border-radius:50%;background:#f4f7fa;border:1px solid var(--line)}
.ci-qty{min-width:18px;text-align:center;font-size:.84rem;font-weight:800}
.ci-del{padding:6px 8px;color:#c04949;font-weight:900}
.cart-panel-footer{padding:16px 18px 18px;border-top:1px solid var(--line)}
.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:.96rem}
.cart-total strong{font-size:1.12rem;color:var(--violeta)}

/* MODAL */
.modal-overlay{
  position:fixed;inset:0;background:rgba(17,24,39,.7);opacity:0;pointer-events:none;transition:.25s ease;z-index:1500;
  display:grid;place-items:center;padding:18px
}
.modal-overlay.show{opacity:1;pointer-events:auto}
.modal-box{
  width:min(620px,100%);background:#fff;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);position:relative
}
.modal-close{position:absolute;top:12px;right:12px;z-index:2}
.modal-content img{width:100%;height:280px;object-fit:contain;background:linear-gradient(180deg,#f8fbfd,#edf4f8)}
.modal-body{padding:20px}
.modal-body h3{font-size:1.4rem;font-weight:900;margin:8px 0}
.modal-body p{color:var(--muted);line-height:1.7;font-size:.92rem}
.modal-price{font-size:1.6rem;font-weight:900;color:var(--violeta);margin:12px 0}
.modal-price small{font-size:.7rem;color:var(--muted);font-weight:400;margin-left:4px}
.modal-actions{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}

/* TOAST */
.toast{
  position:fixed;left:50%;bottom:92px;transform:translateX(-50%) translateY(20px);
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:999px;padding:12px 18px;
  font-size:.82rem;font-weight:700;color:var(--text);opacity:0;z-index:1800;transition:.25s ease;white-space:nowrap;max-width:calc(100vw - 20px);overflow:hidden;text-overflow:ellipsis
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* RESPONSIVE */
@media (max-width: 1100px){
  .products-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .phases-line{grid-template-columns:repeat(4, minmax(0,1fr))}
}
@media (max-width: 768px){
  .section{padding:68px 0}
  .burger{display:block}
  .nav-links{
    position:fixed;inset:68px 0 auto 0;background:rgba(255,255,255,.96);backdrop-filter:blur(18px);
    border-bottom:1px solid var(--line);flex-direction:column;padding:22px;transform:translateY(-120%);
    transition:.28s ease;z-index:950
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{font-size:1.05rem;padding:8px 0}
  .split{grid-template-columns:1fr}
  .split-visual{display:none}
  .products-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
  .phases-line{grid-template-columns:repeat(2,minmax(0,1fr))}
  .phase-card:nth-child(n+5){display:none}
  .hero{padding:78px 0 50px;min-height:100svh}
  .hero-inner{width:min(100%,calc(100% - 18px))}
  .hero-topline{margin-bottom:12px}
  .top-pill{font-size:.66rem;padding:7px 10px}
  .hero-spotlight{
    width:min(100%, 520px);
    padding:22px 14px 18px;
    border-radius:24px;
  }
  .moon-row{gap:7px;margin-bottom:10px}
  .moon-row span{font-size:1rem}
  .moon-full{font-size:1.35rem !important}
  .hero-title{font-size:clamp(2.45rem, 13vw, 4.1rem);margin-bottom:8px}
  .hero-tagline{font-size:.6rem;letter-spacing:3px;margin-bottom:8px}
  .hero-copy{font-size:.92rem;line-height:1.65;margin-bottom:18px}
  .hero-actions{flex-direction:column}
  .hero-actions a{width:100%}
  .hero-mini-note{font-size:.7rem}
  .cart-panel{width:100vw}
}
@media (max-width: 520px){
  .container{width:min(100% - 20px, 100%)}
  .nav-inner{width:min(100% - 20px, 100%)}
  .products-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .pcard-body{padding:12px}
  .pcard-name{font-size:.84rem}
  .pcard-desc{font-size:.72rem}
  .pcard-price{font-size:.92rem}
  .pcard-img img{padding:10px}
  .filter-btn{padding:8px 14px;font-size:.74rem}
  .floating-cart{width:54px;height:54px;right:14px;bottom:14px}
  .toast{bottom:78px;width:calc(100% - 20px);text-align:center}
  .modal-content img{height:220px}
  .modal-body{padding:16px}
  .modal-actions .btn-primary,.modal-actions .btn-secondary{width:100%}
}
@media (max-width: 390px){
  .products-grid{grid-template-columns:1fr 1fr}
  .phase-card p{display:none}
  .phase-card{padding:14px 10px}
  .hero-title{font-size:clamp(2.35rem,14vw,3.6rem)}
}