:root{--bg:#0b0f19;--panel:#121829;--brand:#3FA0D7;--brand-2:#1F7390;--text:#e6e9f2;--muted:#9aa3b2;--radius:16px;--shadow:0 10px 30px rgba(0,0,0,.35)}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;font-family:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica,Arial;color:var(--text);background:radial-gradient(1200px 800px at 80% -10%, rgba(63,160,215,.25), transparent 60%), radial-gradient(1000px 600px at -10% 0%, rgba(31,115,144,.18), transparent 50%), var(--bg)}
a{color:inherit;text-decoration:none}.container{width:min(1200px,92%);margin-inline:auto}

.bh-header{position:sticky;top:0;z-index:50;backdrop-filter:saturate(180%) blur(10px);background:rgba(11,15,25,.6);border-bottom:1px solid rgba(255,255,255,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:.2px}
.logo-img{height:56px;width:auto;display:block} /* bigger desktop logo */
nav ul{display:flex;gap:8px;list-style:none;margin:0;padding:0}
nav a{padding:10px 14px;border-radius:10px;color:var(--muted);font-weight:600}
nav a:hover, nav a.active{color:var(--text);background:rgba(255,255,255,.06)}
.cta{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:white;font-weight:700;box-shadow:0 10px 30px rgba(63,160,215,.35)}
.menu-btn{display:none}
.mobile{display:none}

/* Seasonal bar */
.season-bar{background:linear-gradient(90deg, rgba(0,200,83,.25), rgba(229,57,53,.25)); border-bottom:1px solid rgba(255,255,255,.12);}
.sbar-content{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;color:#eaf7ea;font-weight:700}
.sbar-close{background:transparent;border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:8px;padding:2px 10px;cursor:pointer}

.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center;padding:64px 0 32px}
.hero h1{font-size:clamp(32px,5vw,56px);line-height:1.05;margin:0 0 10px}
.gradient{background:linear-gradient(90deg,var(--brand),var(--brand-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{color:var(--muted);font-size:clamp(16px,2.2vw,19px);margin:0 0 24px}
.hero-card{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.badge{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;background:rgba(63,160,215,.12);color:#dfe6ff;font-weight:700;letter-spacing:.2px;margin-bottom:12px}
.hero-art-img{height:320px;width:100%;object-fit:cover;border-radius:22px;border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow);background:#0f1527}

section{padding:56px 0} h2{font-size:clamp(24px,3.2vw,36px);margin:0 0 12px} .sub{color:var(--muted);margin:0 0 24px}

.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{grid-column:span 6;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:20px;transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;position:relative;overflow:hidden}
.card:hover{transform:translateY(-4px);box-shadow:0 15px 40px rgba(0,0,0,.4);border-color:rgba(255,255,255,.18)}
.card h3{margin:6px 0 8px}.card p{color:var(--muted)}
.icon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(63,160,215,.25),rgba(31,115,144,.18));border:1px solid rgba(255,255,255,.2)}

.about{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.list{display:grid;gap:10px;margin:0;padding-left:18px}
.pill{display:inline-flex;gap:8px;align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:8px 12px;border-radius:999px;font-weight:600}

/* Plans 3 columnas */
.plans{display:grid;grid-template-columns:repeat(3, 1fr);gap:16px}
.plan{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.plan h4{margin:10px 0 8px}
.plan ul{list-style:none;margin:0;padding:0;display:grid;gap:6px;color:var(--muted)}
.plan-btn{display:inline-block;margin-top:10px;padding:10px 14px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:white;font-weight:800;text-align:center}
.badge-top{display:inline-block;font-size:.8rem;padding:6px 10px;border-radius:999px;background:rgba(63,160,215,.18);border:1px solid rgba(255,255,255,.12)}
.badge-top.accent{background:rgba(255,165,0,.18);border-color:rgba(255,255,255,.2)}
.plan.highlight{outline:1px solid rgba(255,255,255,.2)}
.plans-note{color:var(--muted);margin-top:8px}

/* Modal Gracias */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.6);z-index:1000;padding:16px}
.modal.show{display:flex}
.modal-card{max-width:520px;width:100%;background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:22px;text-align:center;box-shadow:var(--shadow)}

form{display:grid;gap:14px}
input,textarea,select{background:#0e1322;color:var(--text);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:12px 14px;font:inherit}
textarea{min-height:120px;resize:vertical}
.btn{cursor:pointer;border:0;border-radius:12px;padding:12px 16px;font-weight:800;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:white;box-shadow:0 10px 30px rgba(63,160,215,.35)}
.wa-btn{background:linear-gradient(135deg,#25D366,#128C7E)!important; box-shadow:0 12px 30px rgba(37,211,102,.25)!important; display:inline-flex; align-items:center; gap:8px; margin-top:10px}

/* Floating WhatsApp FAB */
.wa-fab{
  position:fixed; right:22px; bottom:22px; z-index:1200;
  width:60px; height:60px; border-radius:999px; display:grid; place-items:center;
  background:#25D366; color:white; box-shadow:0 18px 35px rgba(37,211,102,.35), 0 6px 18px rgba(0,0,0,.25);
  transition:transform .15s ease, box-shadow .15s ease;
}
.wa-fab:hover{ transform:translateY(-2px); box-shadow:0 22px 45px rgba(37,211,102,.4), 0 8px 20px rgba(0,0,0,.3) }
.wa-fab:active{ transform:translateY(0) }

.contact-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:22px}
.contact-card{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:20px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-status{margin-top:12px;font-weight:700}
.form-status.ok{color:#53d17a}.form-status.fail{color:#ff7b7b}.form-status.invalid{color:#f8b84e}

.bh-footer{padding:38px 0;color:var(--muted);border-top:1px solid rgba(255,255,255,.06)}
.fwrap{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.links{display:flex;gap:10px;align-items:center}.links span{opacity:.4}

@media (max-width:920px){
  .hero{grid-template-columns:1fr;padding-top:32px}
  .contact-wrap,.about{grid-template-columns:1fr}
  .card{grid-column:span 12}
  .logo-img{height:40px} /* smaller logo on mobile for balance */
  nav ul{display:none}
  .menu-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:transparent;color:var(--text)}
  .mobile{position:absolute;top:64px;right:4%;background:rgba(11,15,25,.95);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:10px;box-shadow:var(--shadow);display:none}
  .mobile a{display:block;padding:10px 12px;color:var(--muted)}
  .mobile a:hover{background:rgba(255,255,255,.06);color:var(--text)}
}

.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}
.floaty{position:relative;animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.divider{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.14),transparent);margin:22px 0}