:root{
  --navy:#141b2e;
  --navy-2:#1e2740;
  --navy-3:#2a3552;
  --accent:#f6a609;
  --accent-2:#ffc24d;
  --accent-d:#c98500;
  --accent-soft:#fff4df;
  --ink:#1b2233;
  --muted:#626c80;
  --line:#e8eaf1;
  --bg:#ffffff;
  --bg-alt:#f6f8fc;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 18px 50px rgba(20,27,46,.10);
  --shadow-sm:0 6px 18px rgba(20,27,46,.07);
  --container:1180px;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html,body{overflow-x:hidden;max-width:100%}
body{font-family:"Plus Jakarta Sans",system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:"Oswald",sans-serif;font-weight:600;line-height:1.12;letter-spacing:.4px}
.container{width:min(var(--container),92%);margin-inline:auto}
.accent{color:var(--accent)}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;color:var(--accent-d);font-weight:700;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:.7rem}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--accent);display:inline-block}

/* Icon sizing */
.ic{width:1.2em;height:1.2em;vertical-align:middle;flex:none}

/* Icon chips */
.chip{display:inline-grid;place-items:center;width:58px;height:58px;border-radius:16px;
  background:linear-gradient(145deg,var(--accent-soft),#fff);color:var(--accent-d);
  box-shadow:inset 0 0 0 1px rgba(246,166,9,.18);transition:.3s var(--ease)}
.chip .ic{width:26px;height:26px}
.chip--sm{width:46px;height:46px;border-radius:12px}
.chip--sm .ic{width:20px;height:20px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.82rem 1.5rem;border-radius:999px;font-weight:700;font-size:.95rem;transition:.25s var(--ease);cursor:pointer;border:2px solid transparent;white-space:nowrap}
.btn .ic{width:18px;height:18px}
.btn--lg{padding:1rem 1.8rem;font-size:1rem}
.btn--accent{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#241a00;box-shadow:0 10px 24px rgba(246,166,9,.35)}
.btn--accent:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(246,166,9,.45)}
.btn--ghost{border-color:rgba(255,255,255,.45);color:#fff;backdrop-filter:blur(4px)}
.btn--ghost:hover{background:rgba(255,255,255,.14);border-color:#fff}
.btn--dark{background:var(--navy);color:#fff}
.btn--dark:hover{background:var(--navy-2);transform:translateY(-3px)}

/* Topbar */
.topbar{background:var(--navy);color:#aeb6cc;font-size:.82rem}
.topbar__inner{display:flex;gap:1.6rem;flex-wrap:wrap;justify-content:center;align-items:center;padding:.55rem 0}
.topbar__item{display:inline-flex;align-items:center;gap:.4rem}
.topbar__item .ic{width:15px;height:15px;color:var(--accent)}
.topbar__link:hover{color:#fff}

/* Header */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:.3s}
.header.scrolled{box-shadow:var(--shadow-sm)}
.header__inner{display:flex;align-items:center;gap:1.5rem;padding:.85rem 0}
.logo{display:flex;align-items:center;gap:.65rem}
.logo__mark{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--navy);box-shadow:0 6px 16px rgba(246,166,9,.35)}
.logo__mark .ic{width:26px;height:26px;color:var(--navy);stroke-width:2.2}
.logo__text{font-family:"Oswald";font-size:1.25rem;color:var(--navy)}
.logo__text strong{color:var(--accent-d)}
.logo--light .logo__text{color:#fff}
.logo--light .logo__text strong{color:var(--accent)}
.nav{display:flex;gap:1.7rem;margin-left:auto}
.nav a{font-weight:600;color:var(--navy);font-size:.96rem;position:relative;padding:.2rem 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--accent);transition:.28s var(--ease)}
.nav a:hover::after{width:100%}
.header__cta{padding:.62rem 1.2rem}
.nav-toggle{display:none;background:none;border:none;color:var(--navy);cursor:pointer}
.nav-toggle .ic{width:28px;height:28px}

/* Hero */
.hero{position:relative;color:#fff;overflow:hidden;background:
  linear-gradient(100deg,rgba(17,24,42,.55) 0%,rgba(17,24,42,.15) 60%,rgba(30,39,64,0) 100%),
  url("assets/hero-bg.svg") center/cover no-repeat,
  radial-gradient(700px 400px at 85% 8%,rgba(246,166,9,.20),transparent 60%),
  linear-gradient(135deg,#11182a 0%,#141b2e 55%,#2a3552 100%)}
.hero__overlay{position:absolute;inset:0;background:radial-gradient(900px 500px at 85% 10%,rgba(246,166,9,.18),transparent 60%);pointer-events:none}
.hero__inner{position:relative;padding:6rem 0 7rem}
.hero__content{max-width:660px}
.hero__badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(246,166,9,.14);border:1px solid rgba(246,166,9,.4);color:var(--accent-2);padding:.45rem 1rem;border-radius:999px;font-size:.82rem;font-weight:600;margin-bottom:1.4rem}
.hero__badge .ic{width:16px;height:16px}
.hero h1{font-size:clamp(2.5rem,5.5vw,4.2rem);letter-spacing:.5px}
.hero p{font-size:1.13rem;color:#d3d9ea;margin:1.3rem 0 2.2rem;max-width:560px}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero__stats{list-style:none;display:flex;gap:0;margin-top:3rem;flex-wrap:wrap}
.hero__stats li{padding-right:2rem;margin-right:2rem;border-right:1px solid rgba(255,255,255,.15)}
.hero__stats li:last-child{border:0}
.hero__stats strong{display:block;font-family:"Oswald";font-size:1.7rem;color:var(--accent-2)}
.hero__stats span{font-size:.85rem;color:#aeb6cc}
.hero__wave{position:absolute;left:0;right:0;bottom:-1px;height:60px;background:var(--bg);
  clip-path:polygon(0 100%,100% 100%,100% 40%,0 75%)}

/* Benefits */
.benefits{margin-top:-3rem;position:relative;z-index:5}
.benefits__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem}
.benefit{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow);transition:.3s var(--ease)}
.benefit:hover{transform:translateY(-6px)}
.benefit:hover .chip{transform:rotate(-6deg) scale(1.05)}
.benefit h3{font-size:1.15rem;margin:1rem 0 .4rem;color:var(--navy)}
.benefit p{font-size:.9rem;color:var(--muted)}

/* Sections */
.section{padding:5.5rem 0}
.section--alt{background:var(--bg-alt)}
.section__head{text-align:center;max-width:640px;margin:0 auto 3.2rem}
.section__head .eyebrow{justify-content:center}
.section__head h2{font-size:clamp(2rem,4vw,2.8rem);color:var(--navy)}
.section__head p{color:var(--muted);margin-top:.7rem}

/* Two column */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.two-col__media{position:relative}
.two-col__text h2{font-size:clamp(1.9rem,3.6vw,2.5rem);color:var(--navy);margin-bottom:1.1rem}
.two-col__text p{color:var(--muted);margin-bottom:1rem}
.media-card{aspect-ratio:4/3;border-radius:var(--radius);background:
  radial-gradient(500px 300px at 30% 20%,rgba(246,166,9,.22),transparent 60%),
  linear-gradient(135deg,var(--navy),var(--navy-3));
  display:grid;place-content:center;text-align:center;color:#fff;box-shadow:var(--shadow)}
.media-card__big{font-family:"Oswald";font-size:4.5rem;color:var(--accent)}
.media-card__sub{color:#c3c9dd;font-size:.95rem}
.media-badge{position:absolute;right:-14px;bottom:-22px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:.9rem 1.2rem;box-shadow:var(--shadow);text-align:center}
.media-badge strong{display:block;font-family:"Oswald";font-size:1.8rem;color:var(--accent-d);line-height:1}
.media-badge span{font-size:.74rem;color:var(--muted)}
.checklist{list-style:none;margin-top:1.4rem;display:grid;gap:.7rem}
.checklist li{position:relative;padding-left:2rem;color:var(--ink);font-weight:500}
.checklist li::before{content:"✓";position:absolute;left:0;top:-1px;width:22px;height:22px;display:grid;place-items:center;border-radius:50%;background:var(--accent-soft);color:var(--accent-d);font-size:.78rem;font-weight:800}

/* Cards / catalog */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem 1.8rem;transition:.3s var(--ease);overflow:hidden}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transform:scaleX(0);transform-origin:left;transition:.35s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card:hover .chip{transform:rotate(-6deg) scale(1.05)}
.card h3{font-size:1.18rem;margin:1rem 0 .4rem;color:var(--navy)}
.card p{font-size:.92rem;color:var(--muted)}

.catalog{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem}
.cat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem 1.5rem;text-align:center;transition:.3s var(--ease)}
.cat .chip{margin-bottom:.4rem}
.cat:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.cat:hover .chip{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 10px 22px rgba(246,166,9,.4)}
.cat h3{font-size:1.05rem;margin:.7rem 0 .3rem;color:var(--navy)}
.cat p{font-size:.84rem;color:var(--muted)}
.catalog__cta{text-align:center;margin-top:3rem;display:grid;gap:1rem;place-items:center}
.catalog__cta p{color:var(--muted)}

/* CTA band */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#2a1f00;text-align:center;padding:4rem 0}
.cta-band::after{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 80% -20%,rgba(255,255,255,.35),transparent 60%);pointer-events:none}
.cta-band__inner{position:relative}
.cta-band h2{font-size:clamp(1.8rem,3.4vw,2.6rem)}
.cta-band p{margin:.6rem 0 1.8rem;font-weight:600}
.cta-band__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* Contact */
.contact-list{list-style:none;display:grid;gap:1.2rem;margin:1.6rem 0}
.contact-list li{display:flex;gap:1rem;align-items:center}
.contact-list a:hover{color:var(--accent-d)}
.map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);height:100%;min-height:380px;border:1px solid var(--line)}
.map iframe{width:100%;height:100%;min-height:380px;border:0;filter:saturate(.95)}
.map-card{display:grid;justify-items:center;align-content:center;gap:.5rem;text-align:center;min-height:380px;
  border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--line);overflow:hidden;position:relative;
  background:
    radial-gradient(220px 220px at 70% 30%,rgba(246,166,9,.12),transparent 60%),
    repeating-linear-gradient(0deg,#eef1f8 0 1px,transparent 1px 38px),
    repeating-linear-gradient(90deg,#eef1f8 0 1px,transparent 1px 38px),
    linear-gradient(135deg,#fbfcff,#eef2fa);
  transition:.3s var(--ease)}
.map-card:hover{transform:translateY(-4px);box-shadow:0 24px 60px rgba(20,27,46,.16)}
.map-card__pin{display:grid;place-items:center;width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;
  box-shadow:0 12px 26px rgba(246,166,9,.5);margin-bottom:.3rem}
.map-card__pin .ic{width:30px;height:30px}
.map-card__title{font-family:"Oswald";font-size:1.4rem;color:var(--navy)}
.map-card__addr{color:var(--muted);font-size:.95rem}
.map-card__btn{display:inline-flex;align-items:center;gap:.45rem;margin-top:.8rem;padding:.6rem 1.2rem;
  border-radius:999px;background:var(--navy);color:#fff;font-weight:700;font-size:.9rem;transition:.25s var(--ease)}
.map-card__btn .ic{width:17px;height:17px}
.map-card:hover .map-card__btn{background:var(--accent-d)}

/* Botones extra contacto */
.btn--outline{border:1px solid var(--line);background:#fff;color:var(--navy)}
.btn--outline:hover{border-color:var(--accent-d);color:var(--accent-d)}
.contact-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.4rem}

/* Formulario de contacto */
.contact-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:2rem}
.contact-form__title{font-family:"Oswald";font-size:1.4rem;color:var(--navy);margin-bottom:.25rem}
.contact-form__hint{color:var(--muted);font-size:.92rem;margin-bottom:1.4rem}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field label{font-size:.85rem;font-weight:600;color:var(--navy)}
.field input,.field textarea{font:inherit;color:var(--navy);background:var(--bg-alt);
  border:1px solid var(--line);border-radius:12px;padding:.75rem .9rem;transition:.2s var(--ease);width:100%}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--accent);
  background:#fff;box-shadow:0 0 0 3px rgba(246,166,9,.18)}
.field textarea{resize:vertical;min-height:110px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.contact-form__submit{width:100%;justify-content:center;margin-top:.4rem}
.contact-form__submit[disabled]{opacity:.6;cursor:not-allowed}
.contact-form__status{margin-top:1rem;font-size:.92rem;font-weight:600;min-height:1.2em}
.contact-form__status.is-ok{color:#1a7f4b}
.contact-form__status.is-err{color:#c0392b}

/* Footer */
.footer{background:var(--navy);color:#aeb6cc;padding-top:3.5rem}
.footer__inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem;padding-bottom:2.8rem}
.footer__brand p{margin-top:1rem;font-size:.92rem;max-width:320px;line-height:1.7}
.footer__col h4{color:#fff;font-family:"Oswald";margin-bottom:1rem;font-size:1.1rem}
.footer__col a,.footer__col p{display:flex;align-items:center;gap:.5rem;font-size:.9rem;margin-bottom:.5rem}
.footer__col .ic{width:15px;height:15px;color:var(--accent)}
.footer__col a:hover{color:var(--accent)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.3rem 0;font-size:.82rem;text-align:center}

/* Overlay del menú móvil */
.nav-backdrop{position:fixed;inset:0;background:rgba(10,15,28,.62);opacity:0;transition:opacity .3s var(--ease);z-index:65}
.nav-backdrop.open{opacity:1}
/* Menú abierto: el header (que contiene el panel) debe quedar SOBRE el backdrop,
   si no el fondo oscuro intercepta los toques y los links no responden.
   También se quita el backdrop-filter, que desenfocaba el texto del panel en iOS. */
body.menu-open .header{z-index:80;backdrop-filter:none;-webkit-backdrop-filter:none}

/* WhatsApp float */
.wa-float{position:fixed;right:22px;bottom:22px;width:60px;height:60px;border-radius:50%;background:#25d366;color:#fff;display:grid;place-items:center;box-shadow:0 10px 28px rgba(37,211,102,.5);z-index:60;transition:.3s var(--ease)}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #25d366;animation:pulse 2.2s ease-out 6}
.wa-float:hover{transform:scale(1.1)}
.wa-float:hover::after{animation-play-state:paused}
/* Ocultar el botón flotante cuando el menú móvil está abierto */
body.menu-open .wa-float{opacity:0;visibility:hidden;pointer-events:none}
@keyframes pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.7);opacity:0}}

/* Scroll reveal (solo se oculta si hay JS activo) */
.js .reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
.benefits__grid .benefit:nth-child(2){transition-delay:.08s}
.benefits__grid .benefit:nth-child(3){transition-delay:.16s}
.benefits__grid .benefit:nth-child(4){transition-delay:.24s}
.cards .card:nth-child(2),.catalog .cat:nth-child(2){transition-delay:.06s}
.cards .card:nth-child(3),.catalog .cat:nth-child(3){transition-delay:.12s}
.cards .card:nth-child(4),.catalog .cat:nth-child(4){transition-delay:.18s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* Responsive */
@media(max-width:980px){
  .benefits__grid,.cards,.catalog{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1fr;gap:2.5rem}
  .footer__inner{grid-template-columns:1fr 1fr}
  .media-badge{right:16px}
  .field-row{grid-template-columns:1fr}
  .contact-form{padding:1.6rem}
}
@media(max-width:680px){
  .nav{position:fixed;top:0;right:0;bottom:0;height:100dvh;width:80%;max-width:330px;
    background:var(--navy);flex-direction:column;align-items:flex-start;justify-content:center;
    padding:2rem 2.2rem;gap:.4rem;margin:0;transform:translateX(105%);
    transition:transform .35s var(--ease);box-shadow:-16px 0 50px rgba(0,0,0,.35);z-index:70;overflow-y:auto}
  .nav.open{transform:translateX(0)}
  .nav a{color:#fff;font-size:1.25rem;font-family:"Oswald";width:100%;padding:.85rem 0;border-bottom:1px solid rgba(255,255,255,.08)}
  .nav a::after{display:none}
  .nav a:active{color:var(--accent)}
  .nav-toggle{display:grid;place-items:center;margin-left:auto;z-index:80;color:var(--navy)}
  .header__cta{display:none}
  .benefits__grid,.cards,.catalog{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr}
  .section{padding:3.8rem 0}
  .hero__inner{padding:3.5rem 0 4.5rem}
  .hero p{font-size:1.05rem}
  .hero__stats{margin-top:2rem;gap:0}
  .hero__stats li{padding-right:1.1rem;margin-right:1.1rem}
  .benefits{margin-top:-2rem}
  .topbar__inner{gap:.3rem .9rem;padding:.5rem 0}
  .topbar{font-size:.74rem}
  .media-badge{right:14px;bottom:-18px;padding:.7rem 1rem}
}
@media(max-width:430px){
  .topbar__item--hours{display:none}
  .hero__stats li{border:0;padding:0;margin:0 1.4rem .4rem 0}
  .cta-band__actions{flex-direction:column;align-items:stretch}
  .cta-band__actions .btn{justify-content:center}
  .btn{padding:.8rem 1.2rem}
  .container{width:90%}
}
