:root{
  --nude:#F5EDE3;--rosa:#F2A7BB;--rosa-d:#D4748F;--crema:#FBF5EE;
  --choco:#5C3317;--choco-l:#7A4E2E;--blanco:#FFFFFF;--wa:#25D366;
  --text:#3D2314;--muted:#5D3F33;
  --space-xs:.5rem;--space-sm:1rem;--space-md:1.5rem;--space-lg:2rem;--space-xl:3rem;
  --radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-full:999px;
  --shadow-sm:0 2px 8px rgba(92,51,23,.08);
  --shadow-md:0 4px 24px rgba(92,51,23,.12);
  --shadow-lg:0 12px 40px rgba(92,51,23,.18);
  --ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --duration-fast: 150ms;
  --duration-normal: 300ms;
  --duration-slow: 500ms;
  --duration-hero: 1s;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
*:focus-visible{outline:2px solid var(--rosa-d);outline-offset:2px;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--crema);color:var(--text);overflow-x:hidden;}

/* PRECIO BADGE */
.precio-badge {
  background: var(--rosa);
  color: white;
  padding: 0.3rem 0.8rem;
  border-radius: 99px;
  font-size: 0.75rem;
  font-weight: 500;
  display: inline-block;
  margin-top: 0.5rem;
}
.gallery-item .precio-badge, .galeria-mesas-item .precio-badge, .incluye-card .precio-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 10;
  margin-top: 0;
}
.hero-precio {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.9rem;
  color: var(--rosa-d);
  margin-top: 0.75rem;
  font-weight: 500;
}
.hero-precio strong {
  color: var(--choco);
  font-weight: 600;
}

.seo-links-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.detail-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  margin-top:2.5rem;
}
@media(max-width:900px){.detail-grid{grid-template-columns:1fr;}}
.detail-card{
  background:white;
  border-radius:var(--radius-lg);
  padding:2rem;
  box-shadow:var(--shadow-sm);
  border-left:3px solid var(--rosa);
  transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);
}
.detail-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}
.detail-card h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.45rem;
  font-weight:600;
  color:var(--choco);
  margin-bottom:.8rem;
}
.detail-card p{
  color:var(--muted);
  line-height:1.75;
  font-size:.95rem;
}
.detail-kicker{
  display:inline-block;
  margin-bottom:.75rem;
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--rosa-d);
}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;transition:background var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);background:linear-gradient(to bottom,rgba(251,245,238,.92) 0%,rgba(251,245,238,.4) 70%,transparent 100%);}
nav.scrolled{background:rgba(251,245,238,.93);backdrop-filter:blur(14px);box-shadow:0 2px 24px rgba(92,51,23,.08);}
.nav-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none;transition:transform var(--duration-fast) var(--ease-out);}
.nav-logo-img{height:42px;width:auto;display:block;}
.nav-logo span{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-style:italic;color:var(--choco);font-weight:600;letter-spacing:.03em;}
.nav-logo:hover{transform:scale(1.02);}
.nav-links{display:flex;gap:2rem;align-items:center;list-style:none;}
.nav-links a{font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:var(--choco-l);text-decoration:none;transition:color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out);}
.nav-links a:hover{color:var(--rosa-d);}
.nav-cta{background:var(--wa)!important;color:white!important;padding:.5rem 1.2rem;border-radius:99px;font-weight:500!important;letter-spacing:.1em!important;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)!important;}
.nav-cta:hover{transform:scale(1.05);box-shadow:0 4px 16px rgba(37,211,102,.3);}
/* Hamburger button */
.hamburger{
  display:none;
  flex-direction:column;
  justify-content:center;
  width:44px;
  height:44px;
  background:transparent;
  border:none;
  cursor:pointer;
  padding:10px;
  z-index:101;
}
.hamburger span{
  display:block;
  width:24px;
  height:2px;
  background:var(--choco);
  margin:3px 0;
  transition:0.3s;
  border-radius:2px;
}
.hamburger.active span:nth-child(1){transform:rotate(-45deg) translate(-5px,6px);}
.hamburger.active span:nth-child(2){opacity:0;}
.hamburger.active span:nth-child(3){transform:rotate(45deg) translate(-5px,-6px);}

/* Mobile menu */
@media(max-width:768px){
  .hamburger{display:flex;}
  .nav-links{
    position:fixed;
    top:0;
    left:0;
    right:0;
    bottom:0;
    background:var(--crema);
    flex-direction:column;
    justify-content:center;
    align-items:center;
    gap:2rem;
    transform:translateX(100%);
    transition:transform 0.3s ease;
    z-index:100;
    padding:2rem;
  }
  .nav-links.open{transform:translateX(0);}
  .nav-links a{font-size:1.2rem;}
  .nav-cta{margin-top:1rem;}
}

/* HERO TIPOGRÁFICO */
.hero{position:relative;min-height:100svh;overflow:hidden;background:linear-gradient(135deg,var(--nude) 0%,var(--crema) 50%,#f2c8d6 100%);}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:100px;background:linear-gradient(to bottom,transparent 0%,var(--choco) 100%);z-index:3;pointer-events:none;}
.hero-editorial{display:flex;min-height:100svh;align-items:center;justify-content:center;gap:0;}
.hero-img-col{display:flex;align-items:center;justify-content:center;flex:0 0 40%;max-width:40%;position:relative;z-index:2;}
.hero-product{width:100%;max-width:420px;height:auto;object-fit:cover;border-radius:var(--radius-lg);box-shadow:0 24px 64px rgba(92,51,23,.18);animation:fadeUp 1s var(--ease-out) .3s both;transform-origin:center bottom;}
.hero-text-col{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:6rem 2rem;padding-top:calc(6rem + 70px);position:relative;z-index:2;text-align:center;max-width:600px;margin:0 auto;}
.hero-logo{width:180px;height:auto;display:block;margin:0 auto 1.5rem;animation:fadeUp .8s var(--ease-out) both;filter:drop-shadow(0 6px 20px rgba(92,51,23,.2));}
.hero-label{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--rosa-d);margin-bottom:1.5rem;display:block;font-weight:500;animation:fadeUp .8s var(--ease-out) .1s both;}
.hero-text-col h1{font-family:'Cormorant Garamond',serif;font-size:clamp(3.5rem,8vw,7rem);font-weight:600;line-height:1.0;color:var(--choco);margin-bottom:1rem;animation:fadeUp .8s var(--ease-out) .15s both;}
.hero-text-col h1 em{font-style:italic;color:var(--rosa-d);font-weight:500;}
.hero-location{font-size:clamp(1rem,2.5vw,1.4rem);color:var(--choco-l);margin-bottom:2.5rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;animation:fadeUp .8s var(--ease-out) .3s both;}
.hero-cta{animation:fadeUp .8s var(--ease-out) .45s both;width:fit-content;}
@keyframes fadeUp{from{opacity:0;transform:translateY(40px);}to{opacity:1;transform:translateY(0);}}

/* Scroll hint */
.scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;color:var(--choco-l);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;z-index:2;}
.scroll-hint span{display:block;width:1px;height:40px;background:var(--choco-l);}

/* Hero responsive */
@media(max-width:768px){
  .hero-img-col{display:none;}
  .hero-text-col{padding:4rem 1.5rem;padding-top:calc(4rem + 70px);max-width:900px;}
  .hero-logo{width:130px;}
  .hero-text-col h1{font-size:clamp(2.8rem,12vw,4rem);}
  .hero-label{font-size:.65rem;letter-spacing:.2em;}
  .hero-cta{width:100%;justify-content:center;}
}
@media(max-width:480px){
  .hero-text-col{padding:3rem 1rem;padding-top:calc(3rem + 70px);}
  .hero-logo{width:110px;}
  .hero-text-col h1{font-size:2.6rem;}
}

/* BTN WA */
.btn-wa{display:inline-flex;align-items:center;gap:.6rem;background:var(--wa);color:white;font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.9rem 2rem;border-radius:var(--radius-full);text-decoration:none;box-shadow:0 8px 24px rgba(37,211,102,.35);transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);}
.btn-wa:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 12px 32px rgba(37,211,102,.45);}
.btn-wa:active{transform:scale(0.98);}
.btn-wa svg,.btn-wa-big svg{fill:currentColor;flex-shrink:0;}
.btn-wa svg{width:20px;height:20px;}
.btn-wa-sm{font-size:.8rem;padding:.7rem 1.5rem;}

/* MARQUEE */
.marquee-wrap{background:var(--choco);overflow:hidden;padding:.8rem 0;}
.marquee-inner{display:flex;width:max-content;animation:marquee 16s linear infinite;}
.marquee-inner:hover{animation-play-state:paused;}
.marquee-item{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1rem;color:var(--rosa);padding:0 2rem;white-space:nowrap;letter-spacing:.06em;}
.marquee-dot{color:var(--rosa-d);padding:0 .4rem;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* SECTIONS */
section{padding:6rem 1.5rem;}
#galeria{padding:5rem 1.5rem;}
#proceso{padding:7rem 1.5rem;}
#rellenos{padding:5rem 1.5rem;}
#zona{padding:4rem 1.5rem;}
#faq{padding:5rem 1.5rem;}
.section-label{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--rosa-d);margin-bottom:.75rem;display:block;}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:600;color:var(--choco);line-height:1.15;}
.container{max-width:1200px;margin:0 auto;}

/* GALLERY */
#galeria{background:var(--nude);}
.gallery-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;gap:2rem;flex-wrap:wrap;}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);}
@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-sm);}}
.gallery-item{overflow:hidden;border-radius:var(--radius-lg);position:relative;cursor:pointer;transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);perspective:600px;}
.gallery-item:hover{transform:translateY(-6px) rotateX(2deg);box-shadow:var(--shadow-lg);}
.gallery-item img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;transition:transform var(--duration-normal) var(--ease-out);}
.gallery-item:hover img{transform:scale(1.08);}
.gallery-item-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(92,51,23,.65) 0%,transparent 60%);opacity:0;transition:opacity var(--duration-normal) var(--ease-out);display:flex;align-items:flex-end;padding:1.25rem;}
.gallery-item:hover .gallery-item-overlay{opacity:1;}
.gallery-item-label{color:white;font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;}

/* PROCESO */
#proceso{background:var(--choco);}
#proceso .section-label{color:var(--rosa);}
#proceso .section-title{color:white;}
.pasos{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3.5rem;}
@media(max-width:768px){.pasos{grid-template-columns:1fr;}}
.paso{background:rgba(255,255,255,.06);border:1px solid rgba(242,167,187,.25);border-radius:var(--radius-lg);padding:2.5rem 2rem;transition:background var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out);}
.paso:hover{background:rgba(255,255,255,.1);transform:translateY(-4px);}
.paso-num{font-family:'Cormorant Garamond',serif;font-size:4rem;font-weight:700;color:var(--rosa);opacity:.5;line-height:1;margin-bottom:1rem;}
.paso h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:600;color:white;margin-bottom:.75rem;}
.paso p{color:rgba(255,255,255,.75);font-size:.9rem;line-height:1.7;}
.proceso-cta{text-align:center;margin-top:3.5rem;}

/* RELLENOS */
#rellenos{background:var(--nude);}
.rellenos-intro{color:var(--muted);margin-top:.75rem;font-size:.9rem;letter-spacing:.04em;}
.rellenos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem;}
@media(max-width:768px){.rellenos-grid{grid-template-columns:1fr;}}
.rellenos-card{background:white;border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm);border-top:3px solid var(--rosa);transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);cursor:default;}
.rellenos-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.rellenos-cat{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--rosa-d);margin-bottom:.75rem;display:block;}
.rellenos-card h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:600;color:var(--choco);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--nude);}
.rellenos-card h3.sub{font-size:1.1rem;margin-top:1.5rem;margin-bottom:.5rem;padding-bottom:.5rem;}
.rellenos-list{list-style:none;display:flex;flex-direction:column;gap:.45rem;}
.rellenos-list li{font-size:.9rem;color:var(--muted);padding-left:1rem;position:relative;}
.rellenos-list li::before{content:'·';position:absolute;left:0;color:var(--rosa);font-size:1.2rem;line-height:1;top:-1px;}
.rellenos-nota{text-align:center;margin-top:2.5rem;font-size:.8rem;letter-spacing:.1em;color:var(--rosa-d);text-transform:uppercase;}

/* MESAS TEMÁTICAS */
#mesas{background:var(--nude);}
.mesas-intro{color:var(--muted);margin-top:.75rem;font-size:.95rem;letter-spacing:.04em;line-height:1.7;}
.mesas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem;}
@media(max-width:768px){.mesas-grid{grid-template-columns:1fr;}}
.mesa-card{background:white;border-radius:var(--radius-lg);padding:2.5rem 2rem;text-align:center;box-shadow:var(--shadow-sm);transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);cursor:default;}
.mesa-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.mesa-icon{font-size:3rem;margin-bottom:1rem;transition:transform var(--duration-normal) var(--ease-out-expo);}
.mesa-card:hover .mesa-icon{transform:scale(1.15);}
.mesa-card h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;color:var(--choco);margin-bottom:.75rem;}
.mesa-card p{color:var(--muted);font-size:.9rem;line-height:1.6;margin-bottom:1rem;}
.mesa-note{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--rosa-d);display:block;}
.mesas-cta{text-align:center;margin-top:2.5rem;}

/* MAPA */
#zona{background:var(--crema);}
.mapa-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:center;}
@media(max-width:768px){.mapa-inner{grid-template-columns:1fr;}}
.mapa-desc{color:var(--muted);line-height:1.8;font-size:.95rem;margin:1rem 0 1.5rem;}
.mapa-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem;}
.mapa-tag{background:var(--nude);border:1px solid var(--rosa);color:var(--choco-l);font-size:.75rem;padding:.3rem .8rem;border-radius:var(--radius-full);letter-spacing:.05em;transition:transform var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out);}
.mapa-tag:hover{transform:scale(1.05);background:var(--rosa-d);color:white;border-color:var(--rosa-d);}
.mapa-frame{border-radius:20px;overflow:hidden;height:380px;box-shadow:0 16px 48px rgba(92,51,23,.12);}
.mapa-frame iframe{width:100%;height:100%;border:0;}

.btn-ig{display:inline-flex;align-items:center;gap:.5rem;border:1.5px solid var(--rosa);color:var(--rosa);font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;padding:.75rem 2rem;border-radius:var(--radius-full);text-decoration:none;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out);}
.btn-ig:hover{background:var(--rosa);color:white;}
.btn-ig svg{width:16px;height:16px;fill:var(--rosa);transition:fill var(--duration-fast) var(--ease-out);}
.btn-ig:hover svg{fill:white;}

/* CTA FINAL */
#cta-final{background:linear-gradient(135deg,var(--rosa) 0%,var(--rosa-d) 100%);text-align:center;padding:7rem 2rem;}
#cta-final h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:600;color:white;margin-bottom:.75rem;line-height:1.1;}
#cta-final p{color:rgba(255,255,255,.9);margin-bottom:2.5rem;font-size:1rem;}
.btn-wa-big{display:inline-flex;align-items:center;gap:.75rem;background:white;color:var(--wa);font-family:'DM Sans',sans-serif;font-weight:700;font-size:1rem;letter-spacing:.08em;text-transform:uppercase;padding:1.1rem 2.5rem;border-radius:var(--radius-full);text-decoration:none;box-shadow:0 12px 40px rgba(0,0,0,.15);transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);}
.btn-wa-big:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 20px 48px rgba(0,0,0,.2);}
.btn-wa-big:active{transform:scale(0.98);}
.btn-wa-big svg{width:22px;height:22px;fill:var(--wa);}

/* FOOTER */
footer{background:#2a1608;color:rgba(255,255,255,.7);padding:3rem 2rem 1.5rem;font-size:.75rem;letter-spacing:.08em;}
footer a{color:var(--rosa);text-decoration:none;transition:color var(--duration-fast) var(--ease-out);}
footer a:hover{color:var(--rosa-d);}
.hecho-by{font-size:.7rem;margin-top:.5rem;color:rgba(255,255,255,.35);letter-spacing:.05em;}
.hecho-by a{color:rgba(255,255,255,.35);}

/* FAB */
.fab-wa{position:fixed;bottom:1.5rem;right:1.5rem;z-index:200;width:60px;height:60px;background:var(--wa);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(37,211,102,.45);text-decoration:none;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);animation:pulse-wa 3s ease-in-out infinite;}
.fab-wa:hover{transform:scale(1.1);box-shadow:0 10px 32px rgba(37,211,102,.6);animation:none;}
.fab-wa:active{transform:scale(0.95);}
.fab-wa svg{width:32px;height:32px;fill:white;}
@keyframes pulse-wa{0%,100%{box-shadow:0 6px 24px rgba(37,211,102,.45);}50%{box-shadow:0 6px 40px rgba(37,211,102,.75),0 0 0 10px rgba(37,211,102,.1);}}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity var(--duration-slow) var(--ease-out),transform var(--duration-slow) var(--ease-out);}
.reveal.visible{opacity:1;transform:none;}
.reveal-delay-1{transition-delay:.1s;}.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}.reveal-delay-4{transition-delay:.4s;}

/* FAQ */
#faq{background:var(--nude);}

@media(max-width:768px){.faq-grid{grid-template-columns:1fr;}}
.faq-card{background:var(--crema);border-radius:var(--radius-lg);padding:2rem;box-shadow:none;border:1px solid rgba(242,167,187,.25);transition:transform var(--duration-normal) var(--ease-out),border-color var(--duration-normal) var(--ease-out);}
.faq-card:hover{transform:translateY(-2px);border-color:var(--rosa);}
.faq-card h3{font-family:'DM Sans',sans-serif;font-size:1.05rem;font-weight:600;color:var(--choco);margin-bottom:.75rem;line-height:1.4;}
.faq-card p{color:var(--choco-l);font-size:.9rem;line-height:1.7;}

/* REDUCED MOTION */
@media(prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
  .blob,.marquee-inner,.scroll-hint,.fab-wa,.pulse-wa{animation:none!important;}
}

/* PWA Install Prompt */
#pwa-prompt{position:fixed;bottom:0;left:0;right:0;background:var(--blanco);padding:1rem 1.5rem;box-shadow:0 -4px 20px rgba(0,0,0,0.15);z-index:999;display:none;transform:translateY(100%);transition:transform 0.3s ease;}
#pwa-prompt.visible{display:block;transform:translateY(0);}
.pwa-prompt-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:600px;margin:0 auto;}
.pwa-prompt-content{display:flex;align-items:center;gap:1rem;}
.pwa-prompt-icon{width:48px;height:48px;background:var(--rosa);border-radius:12px;display:flex;align-items:center;justify-content:center;color:white;font-size:1.5rem;flex-shrink:0;}
.pwa-prompt-text{flex:1;}
.pwa-prompt-title{font-weight:600;color:var(--choco);margin:0;font-size:0.95rem;}
.pwa-prompt-subtitle{color:var(--muted);margin:0;font-size:0.8rem;}
.pwa-prompt-actions{display:flex;gap:0.5rem;}
.pwa-prompt-btn{padding:0.6rem 1rem;border-radius:8px;font-size:0.85rem;cursor:pointer;transition:all 0.2s ease;}
.pwa-prompt-btn:hover{transform:translateY(-1px);}
#pwa-dismiss{background:transparent;border:1px solid var(--muted);color:var(--muted);}
#pwa-dismiss:hover{background:var(--nude);}
#pwa-install{background:var(--rosa);border:none;color:white;font-weight:600;}
#pwa-install:hover{background:var(--rosa-d);}

/* iOS Install Hint */
#ios-hint{display:none;background:var(--crema);padding:1rem;border-radius:var(--radius-md);margin:1rem 0;text-align:center;}
.ios-hint-text{color:var(--choco);margin:0;font-size:0.9rem;}

/* PWA Prompt - Mobile only */
@media(min-width:769px){#pwa-prompt{display:none!important;}}

/* iOS specific - show manual instructions */
@supports(-webkit-touch-callout:none){.ios-install-hint{display:block;}}

/* SEO-only links - invisible but crawlable by Google */
.seo-link {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
}

/* FAQ Section */
.faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-top: 3rem;
}


/* Mesas Dulces Page Styles */

.mesas-hero h1 em{color:var(--choco-l);}
.incluye-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem;}
@media(max-width:900px){.incluye-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.incluye-grid{grid-template-columns:1fr;}}
.incluye-card{background:white;border-radius:var(--radius-lg);padding:2rem;text-align:center;box-shadow:var(--shadow-sm);transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);}
.incluye-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.incluye-icon{font-size:3.5rem;margin-bottom:1rem;transition:transform var(--duration-normal) var(--ease-out-expo);}
.incluye-card:hover .incluye-icon{transform:scale(1.15);}
.incluye-card h3{font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-weight:600;color:var(--choco);margin-bottom:.75rem;}
.incluye-card p{color:var(--muted);font-size:.9rem;line-height:1.6;}
.galeria-mesas{background:var(--nude);}
.galeria-mesas-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem;margin-top:2.5rem;justify-items:center;}
@media(max-width:980px){.galeria-mesas-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:640px){.galeria-mesas-grid{grid-template-columns:1fr;}}
.galeria-mesas-item{overflow:hidden;border-radius:28px;position:relative;aspect-ratio:9/16;cursor:pointer;transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);width:min(100%,320px);background:#d9c3b6;}
.galeria-mesas-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.galeria-mesas-item video{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--duration-normal) var(--ease-out);background:#e9ddd1;border-radius:28px;}
.galeria-mesas-item:hover video{transform:scale(1.02);}
.galeria-mesas-item video::-webkit-media-controls{display:none!important;}
.galeria-mesas-item video::-webkit-media-controls-panel{display:none!important;}
.galeria-mesas-item .video-fallback{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;z-index:1;}
.galeria-mesas-item.video-loaded .video-fallback{opacity:0;transition:opacity .5s ease;pointer-events:none;}
.galeria-mesas-overlay{position:absolute;inset:auto 0 0 0;background:linear-gradient(to top,rgba(92,51,23,.78) 0%,rgba(92,51,23,0) 100%);transition:opacity var(--duration-normal) var(--ease-out);display:flex;align-items:flex-end;padding:1.25rem;min-height:32%;}
.galeria-mesas-label{color:white;font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-style:italic;line-height:1.2;}
.galeria-videos-note{color:var(--muted);margin-top:.85rem;font-size:.92rem;line-height:1.7;max-width:620px;}
.video-badge{position:absolute;top:1rem;left:1rem;background:rgba(255,255,255,.92);color:var(--choco);padding:.45rem .75rem;border-radius:999px;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;z-index:2;}
.precios-mesas{background:var(--crema);text-align:center;}
.precios-note{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.3rem;color:var(--choco);margin:1.5rem 0 2rem;}
.coordina-section{background:var(--choco);}
.coordina-section .section-label{color:var(--rosa);}
.coordina-section .section-title{color:white;}
.coordina-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;margin-top:2.5rem;}
@media(max-width:768px){.coordina-grid{grid-template-columns:1fr;}}
.coordina-text p{color:rgba(255,255,255,.8);font-size:.95rem;line-height:1.8;margin-bottom:1rem;}
.coordina-text ul{list-style:none;margin-top:1.5rem;}
.coordina-text li{color:rgba(255,255,255,.85);padding:.5rem 0;padding-left:1.5rem;position:relative;}
.coordina-text li::before{content:'✦';position:absolute;left:0;color:var(--rosa);}
.coordina-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.2);}
.coordina-img img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;}
.tipos-mesas{background:var(--nude);}
.tipos-grid{display:grid;grid-template:repeat(2,1fr)/repeat(2,1fr);gap:1.5rem;margin-top:2.5rem;}
@media(max-width:768px){.tipos-grid{grid-template:1fr/1fr;}}
.tipo-card{background:white;border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm);transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);}
.tipo-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.tipo-card h3{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;color:var(--choco);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem;}
.tipo-card p{color:var(--muted);font-size:.9rem;line-height:1.7;}
.breadcrumb{font-size:.8rem;color:var(--muted);margin-bottom:1.5rem;display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;}
.breadcrumb a{color:var(--choco-l);text-decoration:none;transition:color var(--duration-fast);}
.breadcrumb a:hover{color:var(--rosa-d);}
.nav-category{display:inline-flex;align-items:center;gap:.5rem;background:var(--nude);border:1px solid var(--rosa);color:var(--choco);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;padding:.6rem 1.2rem;border-radius:var(--radius-full);text-decoration:none;margin-left:.5rem;transition:background var(--duration-fast),color var(--duration-fast);}
.nav-category:hover{background:var(--rosa);color:white;}
.faq-accordion{max-width:800px;margin:0 auto}
.faq-item{background:#fff;border-radius:12px;margin-bottom:1rem;box-shadow:0 2px 8px rgba(92,51,23,.08);overflow:hidden}
.faq-question{cursor:pointer;padding:1.5rem;display:flex;justify-content:space-between;align-items:center;margin:0;font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:500;color:#5C3317;transition:color .3s}
.faq-question:hover{color:#D4748F}
.faq-question::after{content:'+';font-size:1.5rem;color:#D4748F;transition:transform .3s}
.faq-question.active::after{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease-out,padding .4s}
.faq-answer.open{max-height:300px;padding:0 1.5rem 1.5rem}
.faq-answer p{color:#8B7067;line-height:1.7;margin:0}

/* Skip Link - Keyboard Navigation */
.skip-link{position:absolute;top:-100px;left:0;background:var(--rosa);color:white;padding:.75rem 1.5rem;z-index:9999;text-decoration:none;font-weight:500;transition:top .3s}
.skip-link:focus{top:0}

/* ===== DARK MODE ===== */
[data-theme="dark"]{
  --nude:#1a1210;--rosa:#c76e8a;--rosa-d:#a04d6a;--crema:#120c08;
  --choco:#e8d5c4;--choco-l:#b89a86;--blanco:#1a1210;--wa:#25D366;
  --text:#e8d5c4;--muted:#9a8478;
  --shadow-sm:0 2px 8px rgba(0,0,0,.25);
  --shadow-md:0 4px 24px rgba(0,0,0,.35);
  --shadow-lg:0 12px 40px rgba(0,0,0,.45);
}
[data-theme="dark"] body{background:var(--crema);}
[data-theme="dark"] nav.scrolled{background:rgba(18,12,8,.93);}
[data-theme="dark"] .hero-text-col::before{background:linear-gradient(135deg,#1a1210 0%,#3a1a28 50%,#2a1018 100%);}
[data-theme="dark"] .rellenos-card,
[data-theme="dark"] .faq-item,
[data-theme="dark"] .detail-card,
[data-theme="dark"] .tipo-card,
[data-theme="dark"] .incluye-card,
[data-theme="dark"] .mesa-card{background:#1e1612;box-shadow:var(--shadow-sm);}
[data-theme="dark"] .faq-item summary,
[data-theme="dark"] .faq-item p{color:var(--choco-l);}
[data-theme="dark"] .faq-item summary::after{color:var(--rosa);}
[data-theme="dark"] footer{background:#0a0604;}
[data-theme="dark"] .marquee-wrap{background:#0a0604;}
[data-theme="dark"] #pwa-prompt{background:#1e1612;}
[data-theme="dark"] .mapa-tag{background:var(--nude);border-color:var(--rosa);color:var(--choco-l);}
[data-theme="dark"] .mapa-tag:hover{background:var(--rosa-d);color:white;}

/* Theme toggle button */
.theme-toggle{
  background:none;border:none;cursor:pointer;padding:.4rem;
  color:var(--choco);font-size:1.2rem;line-height:1;
  transition:transform var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out);
}
.theme-toggle:hover{transform:rotate(20deg);color:var(--rosa-d);}

/* ===== LIGHTBOX ===== */
.lightbox{
  position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.92);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity var(--duration-normal) var(--ease-out);
}
.lightbox.active{opacity:1;pointer-events:auto;}
.lightbox img{
  max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--radius-md);
  transform:scale(.9);transition:transform var(--duration-normal) var(--ease-out-expo);
}
.lightbox.active img{transform:scale(1);}
.lightbox-close{
  position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;
  color:white;font-size:2rem;cursor:pointer;opacity:.7;
  transition:opacity var(--duration-fast);
}
.lightbox-close:hover{opacity:1;}
.lightbox-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,.15);border:none;color:white;
  font-size:2rem;padding:.5rem 1rem;cursor:pointer;border-radius:var(--radius-sm);
  transition:background var(--duration-fast);
}
.lightbox-nav:hover{background:rgba(255,255,255,.3);}
.lightbox-prev{left:1.5rem;}
.lightbox-next{right:1.5rem;}
.lightbox-counter{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.6);font-size:.85rem;letter-spacing:.1em;
}

/* ===== INSTAGRAM SECTION ===== */
#instagram-feed{background:var(--choco);padding:5rem 1.5rem;}
#instagram-feed .section-label{color:var(--rosa);}
#instagram-feed .section-title{color:white;}
.ig-feed-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);margin-top:2.5rem;
}
@media(max-width:768px){.ig-feed-grid{grid-template-columns:repeat(2,1fr);}}
.ig-feed-item{
  aspect-ratio:1;overflow:hidden;border-radius:var(--radius-sm);position:relative;
  display:block;text-decoration:none;
}
.ig-feed-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform var(--duration-normal) var(--ease-out);
}
.ig-feed-item:hover img{transform:scale(1.08);}
.ig-feed-overlay{
  position:absolute;inset:0;background:rgba(92,51,23,.4);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity var(--duration-normal) var(--ease-out);
}
.ig-feed-item:hover .ig-feed-overlay{opacity:1;}
.ig-feed-overlay svg{width:28px;height:28px;fill:white;}
.ig-feed-cta{text-align:center;margin-top:2.5rem;}

/* ===== FOOTER MEJORADO ===== */
.footer-inner{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem;
  max-width:1000px;margin:0 auto;
}
@media(max-width:768px){.footer-inner{grid-template-columns:1fr;gap:1.5rem;}}
.footer-col h4{
  font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:600;
  color:var(--rosa);margin-bottom:.5rem;
}
.footer-col p,.footer-col a{
  color:rgba(255,255,255,.7);font-size:.75rem;line-height:1.6;
}
.footer-col a{
  text-decoration:none;display:block;transition:color var(--duration-fast);
}
.footer-col a:hover{color:var(--rosa);}
.footer-bottom{
  margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1);
  text-align:center;font-size:.7rem;color:rgba(255,255,255,.55);
}

/* ===== MICRO-INTERACCIONES ===== */
@keyframes countUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}



.paso{position:relative;overflow:hidden;}
.paso::before{
  content:'';position:absolute;top:0;left:0;width:3px;height:0;
  background:var(--rosa);transition:height var(--duration-slow) var(--ease-out);
}
.paso:hover::before{height:100%;}

.rellenos-card{position:relative;}
.rellenos-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--rosa),var(--rosa-d));
  transform:scaleX(0);transition:transform var(--duration-normal) var(--ease-out);
  transform-origin:left;
}
.rellenos-card:hover::after{transform:scaleX(1);}

/* CTA shimmer effect */
@keyframes shimmer{0%{background-position:-200% center;}100%{background-position:200% center;}}
.btn-wa-shimmer{
  background-size:200% auto;
  background-image:linear-gradient(90deg,var(--wa) 0%,#4de88a 50%,var(--wa) 100%);
}
.btn-wa-shimmer:hover{animation:shimmer 3s linear infinite;}

/* Exit Intent Popup */
#exit-popup.active{opacity:1;pointer-events:auto;}
