:root{
  --bg:#f3f6fb;
  --soft:#eef4ff;
  --card:#ffffff;
  --text:#1b2330;
  --muted:#5f6b7a;

  --primary:#19376D;
  --primary2:#1B396A;
  --accent:#d32f2f;

  --gold:#FFD700;
  --green:#25D366;

  --shadow:0 16px 34px rgba(16,24,40,0.12);
  --shadow2:0 10px 22px rgba(16,24,40,0.10);
  --radius:16px;
  --radius2:22px;

  --max:1100px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(var(--max),calc(100% - 32px));margin:0 auto}

/* ===== Header ===== */
.header{
  position:sticky; top:0; z-index:50;
  background:linear-gradient(90deg,var(--primary),#214a92);
  box-shadow:0 10px 26px rgba(0,0,0,0.18);
}
.header__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:14px; padding:14px 0; position:relative;
}
.brand{display:flex;align-items:center;gap:12px;min-width:220px}
.brand__logo{
  width:56px;height:56px;object-fit:contain;
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.20);
  border-radius:14px; padding:8px;
}
.brand__title{font-weight:900;color:#fff;line-height:1.1;font-size:16px}
.brand__subtitle{color:rgba(255,255,255,0.82);font-size:12px;margin-top:4px}

/* Nav */
.nav{display:flex;align-items:center;gap:10px}
.nav__link{
  color:#fff;font-weight:800;font-size:14px;
  padding:10px 12px;border-radius:12px;
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.15);
  display:flex;align-items:center;gap:8px;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease;
}
.nav__link:hover{background:rgba(255,255,255,0.20);transform:translateY(-1px);box-shadow:0 10px 18px rgba(0,0,0,0.14)}

.navToggle{
  display:none;width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(255,255,255,0.20);
  background:rgba(255,255,255,0.10);
  cursor:pointer;padding:10px;
}
.navToggle span{
  display:block;height:2px;background:#fff;margin:6px 0;border-radius:2px;
  transition:transform .2s ease, opacity .2s ease;
}
.navToggle.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.navToggle.is-open span:nth-child(2){opacity:0}
.navToggle.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ===== Main / Sections ===== */
.main{padding-bottom:40px}
.section{padding:56px 0}
.section--soft{
  background:
    radial-gradient(1200px 400px at 50% 0%, rgba(25,55,109,0.12), transparent 60%),
    linear-gradient(180deg, var(--soft), rgba(255,255,255,0));
}
.sectionHead{text-align:center;margin-bottom:22px}
.sectionHead h2{margin:0;font-size:clamp(22px,2.6vw,32px)}
.sectionHead p{margin:8px auto 0;max-width:720px;color:var(--muted)}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;gap:10px;align-items:center;justify-content:center;
  padding:12px 16px;border-radius:14px;font-weight:900;
  border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, filter .2s ease;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow2);filter:saturate(1.05)}
.btn--primary{background:linear-gradient(180deg,var(--accent),#b71c1c);color:#fff}
.btn--ghost{background:rgba(25,55,109,0.08);border-color:rgba(25,55,109,0.18);color:var(--primary2)}
.btn--light{background:rgba(255,255,255,0.95);border-color:rgba(255,255,255,0.55);color:var(--primary2)}
.btn--small{padding:10px 12px;border-radius:12px;font-size:13px}
.w100{width:100%}

/* ===== Hero ===== */
.hero{
  padding:42px 0 10px;
  background:
    radial-gradient(900px 320px at 15% 10%, rgba(255,215,0,0.10), transparent 55%),
    radial-gradient(900px 320px at 85% 0%, rgba(211,47,47,0.10), transparent 55%),
    linear-gradient(180deg, rgba(25,55,109,0.06), transparent 80%);
}
.hero__grid{
  display:grid;
  grid-template-columns: 0.95fr 1.05fr; /* slider más grande */
  gap:28px; align-items:center;
}
.pill{
  display:inline-flex;gap:8px;align-items:center;
  padding:8px 12px;border-radius:999px;
  background:rgba(25,55,109,0.10);
  border:1px solid rgba(25,55,109,0.16);
  color:var(--primary2);font-weight:900;font-size:12px;
}
.hero__title{margin:12px 0 10px;font-size:clamp(28px,3.2vw,44px);line-height:1.05}
.hero__text{margin:0 0 18px;color:var(--muted);font-size:15.5px;line-height:1.6}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.hero__features{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}

.feature{
  background:rgba(255,255,255,0.75);
  border:1px solid rgba(16,24,40,0.08);
  border-radius:16px;
  padding:12px;
  box-shadow:0 12px 20px rgba(16,24,40,0.06);
  display:flex;gap:10px;align-items:flex-start;
  transition:transform .15s ease, box-shadow .2s ease;
}
.feature:hover{transform:translateY(-2px);box-shadow:var(--shadow2)}
.feature i{color:var(--primary2);font-size:18px;margin-top:2px}
.feature strong{display:block;font-size:13px}
.feature span{display:block;font-size:12px;color:var(--muted);margin-top:3px}

/* ===== Slider (IMÁGENES SIEMPRE RELLENAN) ===== */
.slider{
  position:relative;
  border-radius:var(--radius2);
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(16,24,40,0.10);
  background:#0b1220;

  /* más alto y estable */
  aspect-ratio: 16 / 9;
  min-height: 320px;
}
.slide{
  position:absolute;inset:0;
  opacity:0;
  transform:scale(1.02);
  transition:opacity .55s ease, transform .7s ease;
}
.slide.is-active{opacity:1;transform:scale(1)}
.slide img{
  width:100%;
  height:100%;
  object-fit:cover;     /* ✅ rellena SIEMPRE */
  object-position:center;
  filter:saturate(1.06) contrast(1.05);
  transform:scale(1);
  transition:transform .9s ease;
}
.slider:hover .slide.is-active img{transform:scale(1.07)}

/* Overlay más elegante (y card animada al hover) */
.slide__overlay{
  position:absolute;inset:0;
  display:flex;align-items:flex-end;
  padding:18px;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.00) 40%, rgba(0,0,0,0.62) 100%),
    radial-gradient(600px 220px at 20% 80%, rgba(255,215,0,0.22), transparent 55%),
    radial-gradient(600px 220px at 80% 80%, rgba(211,47,47,0.18), transparent 55%);
}
.overlayCard{
  width:min(380px,100%);
  background:rgba(255,255,255,0.14);
  border:1px solid rgba(255,255,255,0.22);
  backdrop-filter:blur(12px);
  border-radius:18px;
  padding:14px 14px 12px;
  color:#fff;
  box-shadow:0 16px 32px rgba(0,0,0,0.35);
  transform: translateY(10px);
  opacity: .92;
  transition: transform .25s ease, opacity .25s ease;
}
.slider:hover .overlayCard{transform: translateY(0); opacity: 1;}
.overlayCard__top{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 10px;border-radius:999px;
  font-weight:900;font-size:12px;
  border:1px solid rgba(255,255,255,0.22);
  background:rgba(0,0,0,0.20);
}
.badge--gold{background:rgba(255,215,0,0.18);border-color:rgba(255,215,0,0.35)}
.overlayCard h3{margin:0 0 6px;font-size:18px}
.overlayCard p{margin:0 0 10px;font-size:13px;color:rgba(255,255,255,0.88);line-height:1.5}

.sliderBtn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:999px;
  border:1px solid rgba(255,255,255,0.22);
  background:rgba(0,0,0,0.30);
  color:#fff;display:grid;place-items:center;
  cursor:pointer;
  transition:background .2s ease, transform .15s ease;
}
.sliderBtn:hover{background:rgba(0,0,0,0.45);transform:translateY(-50%) scale(1.04)}
.sliderBtn--prev{left:12px}
.sliderBtn--next{right:12px}

.dots{
  position:absolute;bottom:12px;left:50%;
  transform:translateX(-50%);
  display:flex;gap:8px;
}
.dot{
  width:10px;height:10px;border-radius:999px;
  border:1px solid rgba(255,255,255,0.55);
  background:rgba(255,255,255,0.30);
  cursor:pointer;
  transition:transform .2s ease, background .2s ease;
}
.dot.is-active{background:rgba(255,255,255,0.95);transform:scale(1.2)}

/* ===== Cards (HOVER PRO) ===== */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
.card{
  background:var(--card);
  border:1px solid rgba(16,24,40,0.08);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:0 14px 24px rgba(16,24,40,0.06);
  transition:transform .18s ease, box-shadow .25s ease, border-color .25s ease;
  position:relative;
  overflow:hidden;
}
.card::after{
  content:"";
  position:absolute; inset:-40%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.35), transparent);
  transform:rotate(20deg) translateX(-60%);
  transition:transform .6s ease;
  pointer-events:none;
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
  border-color: rgba(211,47,47,0.18);
}
.card:hover::after{ transform:rotate(20deg) translateX(60%); }

.card__img{
  height: 160px;            /* ✅ más alto para que no se vea “chiquito” */
  border-radius: 14px;
  overflow:hidden;
  border:1px solid rgba(16,24,40,0.06);
  margin-bottom:12px;
  background: linear-gradient(180deg, rgba(25,55,109,0.06), rgba(211,47,47,0.04));
  position:relative;
}
.card__img img{
  width:100%;
  height:100%;
  object-fit: cover;        /* ✅ rellena bien */
  object-position: center;
  transform: scale(1);
  transition: transform .45s ease;
}
.card:hover .card__img img{ transform: scale(1.08); }

.card h3{margin:0 0 6px}
.card p{margin:0;color:var(--muted);line-height:1.55}

/* Cards de aspectos */
.card--accent .card__icon{
  width:46px;height:46px;border-radius:14px;
  display:grid;place-items:center;
  background:rgba(25,55,109,0.10);
  border:1px solid rgba(25,55,109,0.18);
  color:var(--primary2);
  margin-bottom:10px;
  font-size:18px;
  transition: transform .2s ease;
}
.card--accent:hover .card__icon{ transform: scale(1.06); }

.miniList{margin:10px 0 0;padding-left:18px;color:var(--muted)}
.miniList li{margin:7px 0}

/* ===== TwoCol / Conócenos ===== */
.twoCol{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
.twoCol__text p{color:var(--muted);line-height:1.65}
.checkList{margin:0 0 14px;padding:0;list-style:none;display:grid;gap:10px}
.checkList li{display:flex;gap:10px;align-items:flex-start;color:var(--muted)}
.checkList i{color:var(--green);margin-top:2px}
.inlineBtns{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px}

.mosaic{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.mosaic__box{
  height:140px;border-radius:18px;
  border:1px solid rgba(16,24,40,0.08);
  background:
    radial-gradient(260px 140px at 30% 30%, rgba(255,215,0,0.22), transparent 60%),
    radial-gradient(260px 140px at 70% 70%, rgba(211,47,47,0.18), transparent 60%),
    linear-gradient(180deg, rgba(25,55,109,0.18), rgba(255,255,255,0));
  box-shadow:0 16px 26px rgba(16,24,40,0.08);
}
.mosaic__box--big{grid-column:1/-1;height:190px}
.noteCard{
  margin-top:12px;
  display:flex;gap:10px;align-items:flex-start;
  background:var(--card);
  border:1px solid rgba(16,24,40,0.08);
  border-radius:18px;
  padding:14px;
  box-shadow:0 14px 20px rgba(16,24,40,0.06);
  transition: transform .15s ease, box-shadow .2s ease;
}
.noteCard:hover{transform:translateY(-2px);box-shadow:var(--shadow2)}
.noteCard i{color:var(--accent);font-size:18px;margin-top:3px}
.noteCard p{margin:4px 0 0;color:var(--muted)}

/* ===== Productos placeholder ===== */
.productPlaceholder{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
.productPlaceholder__left,.productPlaceholder__right{
  background:var(--card);
  border:1px solid rgba(16,24,40,0.08);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:0 14px 24px rgba(16,24,40,0.06);
}
.chips{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0}
.chip{
  display:inline-flex;gap:8px;align-items:center;
  padding:8px 10px;border-radius:999px;
  background:rgba(25,55,109,0.08);
  border:1px solid rgba(25,55,109,0.16);
  color:var(--primary2);font-weight:900;font-size:12px;
}
.hint{
  display:flex;gap:10px;align-items:center;color:var(--muted);
  background:rgba(255,215,0,0.10);
  border:1px solid rgba(255,215,0,0.22);
  padding:10px 12px;border-radius:14px;
}
.emptyState{
  border-radius:18px;
  border:1px dashed rgba(25,55,109,0.30);
  background:linear-gradient(180deg, rgba(25,55,109,0.04), rgba(255,255,255,0));
  padding:22px;text-align:center;
}
.emptyState i{font-size:26px;color:var(--primary2);margin-bottom:8px}
.emptyState.small{padding:16px}
.muted{color:var(--muted)}

/* ===== Reseñas ===== */
.reviewsGrid{display:grid;grid-template-columns:0.95fr 1.05fr;gap:16px;margin-top:18px}
.reviewForm,.reviewList{
  background:var(--card);
  border:1px solid rgba(16,24,40,0.08);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:0 14px 24px rgba(16,24,40,0.06);
}
.label{display:block;font-weight:900;margin:12px 0 6px}
.input,.textarea{
  width:100%;
  border-radius:14px;border:1px solid rgba(16,24,40,0.12);
  padding:12px;
  outline:none;background:#fff;
  transition:border .2s ease, box-shadow .2s ease;
}
.input:focus,.textarea:focus{
  border-color:rgba(25,55,109,0.45);
  box-shadow:0 0 0 4px rgba(25,55,109,0.12);
}
.textarea{resize:vertical;min-height:110px}
.formNote{margin:10px 0 0;color:var(--muted);font-size:12px;display:flex;gap:8px;align-items:center}

/* Stars */
.stars{display:flex;gap:6px;flex-direction:row-reverse;justify-content:flex-start}
.stars input{display:none}
.stars label{
  font-size:28px;cursor:pointer;
  color:rgba(255,215,0,0.35);
  transition:transform .12s ease, color .2s ease;
}
.stars label:hover{transform:scale(1.08)}
.stars input:checked ~ label,
.stars label:hover,
.stars label:hover ~ label{color:var(--gold)}

.reviewList__top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.reviewList__hint{color:var(--muted);font-size:12px;display:flex;gap:8px;align-items:center}
.reviewScroller{
  display:flex;gap:12px;overflow-x:auto;
  padding-bottom:8px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
.reviewCard{
  flex:0 0 auto;
  width:min(340px,86%);
  scroll-snap-align:start;
  border-radius:18px;
  border:1px solid rgba(16,24,40,0.08);
  background:
    radial-gradient(280px 180px at 30% 30%, rgba(255,215,0,0.14), transparent 60%),
    linear-gradient(180deg, rgba(25,55,109,0.06), rgba(255,255,255,0));
  padding:14px;
  transition: transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.reviewCard:hover{transform:translateY(-3px);box-shadow:var(--shadow2);border-color: rgba(25,55,109,0.20)}
.reviewCard__stars{color:var(--gold);font-size:18px;margin-bottom:6px}
.reviewCard__name{font-weight:1000;margin-bottom:6px}
.reviewCard__text{color:var(--muted);line-height:1.55;font-size:14px;min-height:44px}
.reviewCard__date{margin-top:8px;font-size:12px;color:rgba(95,107,122,0.9)}

/* ===== Ubicación ===== */
.twoCol--map{grid-template-columns:0.9fr 1.1fr}
.infoBox{
  background:var(--card);
  border:1px solid rgba(16,24,40,0.08);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:0 14px 24px rgba(16,24,40,0.06);
}
.infoList{list-style:none;padding:0;margin:14px 0;display:grid;gap:12px}
.infoList li{display:flex;gap:12px;align-items:flex-start;color:var(--muted)}
.infoList i{width:22px;margin-top:2px;color:var(--primary2)}
.link{
  color:var(--primary2);
  font-weight:900;
  text-decoration:underline;
  text-decoration-thickness:2px;
  text-underline-offset:3px;
}
.mapWrap{
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid rgba(16,24,40,0.08);
  box-shadow:var(--shadow);
  background:#fff;
  min-height:360px;
}
.mapWrap iframe{width:100%;height:100%;min-height:360px;border:0;display:block}

/* WhatsApp */
.whatsapp{
  position:fixed;right:18px;bottom:18px;
  width:58px;height:58px;border-radius:999px;
  background:var(--green);
  color:#fff;display:grid;place-items:center;
  box-shadow:0 18px 34px rgba(37,211,102,0.35);
  border:1px solid rgba(255,255,255,0.25);
  z-index:60;
  transition:transform .15s ease;
}
.whatsapp i{font-size:28px}
.whatsapp:hover{transform:translateY(-2px) scale(1.03)}

/* Footer */
.footer{
  background:linear-gradient(90deg,var(--primary),#214a92);
  color:#fff;padding:34px 0 24px;margin-top:30px;
}
.footer__grid{
  display:grid;
  grid-template-columns:180px 1fr 180px;
  gap:18px;align-items:center;
}
.footer__logo img{max-height:140px;object-fit:contain;margin:0 auto}
.footer__logo.right img{margin-left:auto}
.footer__info{text-align:center}
.footer__info h3{margin:0 0 10px;font-size:18px}
.footerLine{margin:6px 0;color:rgba(255,255,255,0.9)}
.ico{display:inline-block;width:22px}
.gold{color:var(--gold)}
.green{color:var(--green)}
.footer__bottom{text-align:center;margin-top:16px}
.divider{height:1px;background:rgba(255,255,255,0.20);margin:14px 0 10px}
.footer__bottom .muted{color:rgba(255,255,255,0.82)}

/* Responsive */
@media (max-width:980px){
  .hero__grid{grid-template-columns:1fr}
  .hero__features{grid-template-columns:1fr}
  .twoCol{grid-template-columns:1fr}
  .twoCol--map{grid-template-columns:1fr}
  .productPlaceholder{grid-template-columns:1fr}
  .reviewsGrid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr;text-align:center}
  .footer__logo.right img{margin:0 auto}
}
@media (max-width:820px){
  .navToggle{display:block}
  .nav{
    position:absolute;top:74px;right:16px;left:16px;
    background:rgba(25,55,109,0.97);
    border:1px solid rgba(255,255,255,0.18);
    border-radius:18px;padding:12px;
    box-shadow:var(--shadow);
    display:none;flex-direction:column;gap:10px;
  }
  .nav.is-open{display:flex}
  .nav__link{width:100%;justify-content:space-between}
  .cards3{grid-template-columns:1fr}
  .sliderBtn{display:none} /* móvil usa swipe */
  .slider{min-height:260px}
}
@media (max-width:420px){
  .brand__title{font-size:14px}
  .brand__subtitle{font-size:11px}
  .brand__logo{width:52px;height:52px}
}

/* ===== Mosaic con IMÁGENES reales (rellena bien y con hover) ===== */
.twoCol__media { align-self: center; }

.mosaic{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.mosaic__item{
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid rgba(16,24,40,0.10);
  background: #0b1220;
  box-shadow: 0 16px 30px rgba(16,24,40,0.12);
  aspect-ratio: 16/11;
  margin: 0;
}

.mosaic__item--big{
  grid-column: 1 / -1;
  aspect-ratio: 16/9;
  min-height: 220px;
}

.mosaic__item img{
  width:100%;
  height:100%;
  object-fit: cover;     /* ✅ rellena sí o sí */
  object-position: center;
  transform: scale(1);
  transition: transform .7s ease;
  filter: saturate(1.05) contrast(1.05);
}

.mosaic__item::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0.00) 45%, rgba(0,0,0,0.55) 100%);
  opacity: 0.85;
  transition: opacity .25s ease;
}

.mosaic__item:hover img{ transform: scale(1.08); }
.mosaic__item:hover::after{ opacity: 1; }

.mosaic__item figcaption{
  position:absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  z-index: 2;
  color:#fff;
  padding: 12px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.20);
  backdrop-filter: blur(10px);
  transform: translateY(10px);
  opacity: 0.92;
  transition: transform .25s ease, opacity .25s ease;
}

.mosaic__item:hover figcaption{
  transform: translateY(0);
  opacity: 1;
}

.cap__tag{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  font-weight: 900;
  font-size: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,215,0,0.18);
  border: 1px solid rgba(255,215,0,0.35);
  margin-bottom: 8px;
}

.mosaic__item figcaption strong{
  display:block;
  font-size: 16px;
  letter-spacing: .2px;
}

.mosaic__item figcaption small{
  display:block;
  margin-top: 4px;
  color: rgba(255,255,255,0.88);
  font-size: 12.5px;
}

.cap--mini{
  padding: 10px 12px;
}

/* Responsive */
@media (max-width: 980px){
  .mosaic{ grid-template-columns: 1fr; }
  .mosaic__item--big{ grid-column: auto; }
}
/* ====== NAV RESPONSIVE - SOLUCIÓN SIMPLE Y CONFIABLE ====== */

/* Botón hamburguesa - oculto en desktop */
.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  width: 32px;
  height: 24px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 1002;
}

.nav-toggle span {
  display: block;
  height: 3px;
  background: #8B1A3A; /* Vino rojo */
  border-radius: 2px;
  transition: transform 0.3s, opacity 0.3s;
}

/* Animación hamburguesa → X */
.nav-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(6px, 6px); }
.nav-toggle.active span:nth-child(2) { opacity: 0; }
.nav-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(6px, -6px); }

/* ====== MÓVIL (< 768px) ====== */
@media (max-width: 768px) {
  .header__inner {
    flex-wrap: wrap;
    position: relative;
  }

  .nav-toggle {
    display: flex; /* Mostrar en móvil */
  }

  .nav {
    /* Posicionamiento fijo para que cubra toda la pantalla */
    position: fixed;
    top: 70px;
    left: 0;
    right: 0;
    bottom: 0;
    
    /* Estado inicial: oculto */
    display: flex;
    flex-direction: column;
    background: #fff;
    padding: 20px;
    gap: 10px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
    z-index: 1001;
    
    /* Animación de entrada */
    transform: translateX(-100%);
    transition: transform 0.3s ease;
  }

  /* Estado activo: visible */
  .nav.active {
    transform: translateX(0);
  }

  .nav__link {
    padding: 15px 20px;
    font-size: 1.1rem;
    border-radius: 8px;
    color: #333;
    text-decoration: none;
    border-left: 4px solid transparent;
    transition: all 0.2s;
  }

  .nav__link:hover,
  .nav__link:focus {
    background: #f0f8ff; /* Azul claro de fondo */
    border-left-color: #8B1A3A;
    color: #8B1A3A;
  }

  /* Evitar scroll del body cuando el menú está abierto */
  body.menu-open {
    overflow: hidden;
  }
}