/* =====================================================================
   Chusco · Restaurante — Estilo Lujo Premium
   Tema oscuro dorado · Glassmorphism · Micro-interacciones
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  --c-gold:#c9a03a;
  --c-gold-light:#e0c36a;
  --c-gold-deep:#8b6914;
  --c-gold-glow:rgba(201,160,58,.5);
  --c-amber:#d4843a;
  --grad-gold:linear-gradient(135deg,#c9a03a,#e0c36a,#d4a853);
  --grad-gold-soft:linear-gradient(135deg,rgba(201,160,58,.2),rgba(212,168,83,.08));
  --grad-warm:linear-gradient(100deg,#c9a03a,#d4843a);
  --grad-warm-soft:linear-gradient(100deg,rgba(201,160,58,.18),rgba(212,132,58,.10));

  --font-display:'Playfair Display','Cormorant Garamond',Georgia,serif;
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  --radius-sm:12px; --radius:18px; --radius-lg:26px; --radius-xl:34px;
  --container:1200px;
  --header-h:74px;

  --ease:cubic-bezier(.22,1,.36,1);
  --shadow-soft:0 8px 32px rgba(0,0,0,.25);
  --shadow-card:0 20px 60px rgba(0,0,0,.35),0 0 0 1px rgba(201,160,58,.06);
  --shadow-gold:0 12px 40px rgba(201,160,58,.12);
}

/* Tema oscuro dorado (único) */
:root{
  --bg:#060608; --bg-2:#0d0d15; --surface:rgba(255,255,255,.035);
  --surface-2:rgba(255,255,255,.06); --border:rgba(255,255,255,.08);
  --text:#ecebf3; --text-soft:#a7a4ba; --text-mute:#6b677b;
  --glass-bg:rgba(14,12,24,.65); --glass-border:rgba(201,160,58,.10);
  color-scheme:dark;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}
body{
  font-family:var(--font-body);background:var(--bg);color:var(--text);
  line-height:1.6;overflow-x:hidden;min-height:100vh}
}

/* Scrollbar dorada premium */
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:rgba(201,160,58,.25);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:rgba(201,160,58,.4)}
html{scrollbar-color:rgba(201,160,58,.25) var(--bg);scrollbar-width:thin}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
:focus-visible{outline:2px solid var(--c-gold);outline-offset:3px;border-radius:6px}

.container{width:min(var(--container),100% - 2.4rem);margin-inline:auto}

/* ---------- Accesibilidad ---------- */
.skip-link{position:absolute;left:-9999px;top:0;z-index:1000;background:var(--c-gold);
  color:#1a1020;padding:.7rem 1.2rem;border-radius:0 0 12px 0;font-weight:600}
.skip-link:focus{left:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- Tipografía ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.1;letter-spacing:.4px}
.section-title{font-size:clamp(1.9rem,4vw,3rem)}
.section-eyebrow{text-transform:uppercase;letter-spacing:.28em;font-size:.74rem;
  font-weight:600;color:var(--c-gold);font-family:var(--font-body)}
.section-desc{color:var(--text-soft);max-width:560px;margin:.6rem auto 0}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.8rem 1.5rem;
  border-radius:50px;font-weight:600;font-size:.95rem;transition:.3s var(--ease);
  white-space:nowrap;position:relative;overflow:hidden}
.btn-lg{padding:1rem 1.9rem;font-size:1rem}
.btn-block{width:100%;justify-content:center}
.btn-primary{background:var(--grad-warm);color:#0d0b06;box-shadow:0 8px 28px rgba(201,160,58,.25)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(201,160,58,.35)}
.btn-ghost{border:1.5px solid rgba(201,160,58,.2);color:var(--text);background:var(--surface)}
.btn-ghost:hover{border-color:var(--c-gold);color:var(--c-gold);transform:translateY(-3px);box-shadow:0 8px 24px rgba(201,160,58,.1)}
.btn-pill{background:var(--grad-warm);color:#0d0b06;padding:.6rem 1.2rem;font-size:.9rem}
.btn-pill:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(201,160,58,.3)}

.glass{background:var(--glass-bg);border:1px solid var(--glass-border);
  -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg)}

.chip{display:inline-block;padding:.28rem .7rem;border-radius:50px;font-size:.72rem;
  font-weight:600;background:var(--grad-gold-soft);color:var(--c-gold);
  border:1px solid rgba(201,160,58,.2)}

/* ---------- Loader ---------- */
.page-loader{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;
  background:var(--bg);transition:opacity .6s var(--ease),visibility .6s}
.page-loader.hidden{opacity:0;visibility:hidden}
.loader-plate{display:flex;gap:.5rem;margin-bottom:1rem}
.loader-plate span{width:14px;height:14px;border-radius:50%;background:var(--grad-warm);
  animation:bounce 1s infinite ease-in-out}
.loader-plate span:nth-child(2){animation-delay:.15s}
.loader-plate span:nth-child(3){animation-delay:.3s}
.loader-text{font-family:var(--font-display);font-size:1.5rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--text-soft)}
@keyframes bounce{0%,80%,100%{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}

/* ---------- Cursor personalizado ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;
  z-index:9998;transform:translate(-50%,-50%);mix-blend-mode:difference}
.cursor-dot{width:7px;height:7px;background:#fff}
.cursor-ring{width:38px;height:38px;border:1.5px solid var(--c-gold);
  transition:width .25s,height .25s,background .25s}
.cursor-ring.hover{width:60px;height:60px;background:rgba(247,183,51,.12)}
@media (hover:none),(pointer:coarse){.cursor-dot,.cursor-ring{display:none}}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:900;height:var(--header-h);
  display:flex;align-items:center;transition:.4s var(--ease)}
.site-header.scrolled{background:var(--glass-bg);-webkit-backdrop-filter:blur(18px);
  backdrop-filter:blur(18px);border-bottom:1px solid var(--glass-border);
  box-shadow:0 6px 30px rgba(0,0,0,.15)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:min(var(--container),100% - 2.4rem);margin-inline:auto}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);
  font-size:1.4rem;font-weight:700;letter-spacing:.5px}
.brand-mark{width:40px;height:40px;display:grid;place-items:center;border-radius:12px;
  background:var(--grad-warm);color:#1a1020;font-size:1.1rem}
.main-nav{display:flex;gap:.4rem}
.main-nav a{padding:.5rem .9rem;border-radius:50px;font-weight:500;font-size:.95rem;
  color:var(--text-soft);transition:.25s}
.main-nav a:hover,.main-nav a.active{color:var(--text);background:var(--surface)}
.header-actions{display:flex;align-items:center;gap:.6rem}
.nav-toggle{flex-direction:column;gap:5px;display:none}
.nav-toggle span{width:20px;height:2px;background:currentColor;border-radius:2px;transition:.3s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:880px){
  .header-inner{justify-content:space-between}
  .brand{position:absolute;left:50%;transform:translateX(-50%)}
  .brand-logo-img{width:32px;height:32px}
  .brand-name{font-size:1rem}
  .main-nav{position:fixed;inset:var(--header-h) 0 auto 0;flex-direction:column;
    background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
    padding:1.5rem;gap:.4rem;transform:translateY(-130%);transition:.4s var(--ease);
    border-bottom:1px solid var(--glass-border)}
  .main-nav.open{transform:translateY(0)}
  .main-nav a{padding:.9rem 1rem}
  .nav-toggle{display:flex}
  .btn-pill{display:none}
}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:grid;place-items:center;
  text-align:center;padding:calc(var(--header-h) + 3rem) 0 4rem;overflow:hidden}
/* Vídeo de fondo */
.hero-media{position:absolute;inset:0;z-index:0}
.hero-video{width:100%;height:100%;object-fit:cover;display:block !important;position:absolute;inset:0;
  animation:fadeInVideo 1.4s var(--ease) both;z-index:0}
@keyframes fadeInVideo{from{opacity:0;transform:scale(1.04)}to{opacity:1;transform:scale(1)}}
.hero-overlay{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(4,4,8,.4) 0%,rgba(4,4,8,.15) 35%,rgba(4,4,8,.5) 70%,rgba(4,4,8,.9) 100%)}
.hero-bg{position:absolute;inset:0;z-index:1;background:
  radial-gradient(circle at 75% 25%,rgba(212,132,58,.08),transparent 45%),
  radial-gradient(circle at 20% 80%,rgba(201,160,58,.06),transparent 50%);
  pointer-events:none}
.hero-glow{position:absolute;width:60vw;height:60vw;max-width:680px;max-height:680px;
  border-radius:50%;background:var(--grad-warm);filter:blur(140px);opacity:.12;
  top:8%;left:50%;transform:translateX(-50%);animation:float 9s ease-in-out infinite;z-index:1}
@keyframes float{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,-30px)}}
.hero-inner{position:relative;z-index:5;max-width:880px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem 1rem;
  border-radius:50px;background:var(--surface);border:1px solid var(--border);
  font-size:.8rem;font-weight:600;color:var(--c-gold);margin-bottom:1.4rem}
.eyebrow-divider{font-size:.5rem;opacity:.4}
.hero-title{font-size:clamp(2.8rem,8vw,6rem);line-height:.98;margin-bottom:1.2rem}
.hero-title .line{display:block;overflow:hidden}
.hero-title .accent{background:var(--grad-warm);-webkit-background-clip:text;
  background-clip:text;color:transparent;font-style:italic}
.hero-sub{font-size:clamp(1rem,2vw,1.25rem);color:var(--text-soft);max-width:600px;
  margin:0 auto 2rem}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}
.hero-stats{display:flex;gap:2.5rem;justify-content:center;flex-wrap:wrap;align-items:center}
.stat{display:flex;flex-direction:column}
.stat-num{font-family:var(--font-display);font-size:2.4rem;font-weight:700;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-label{font-size:.8rem;color:var(--text-mute);text-transform:uppercase;letter-spacing:.1em}
.stat-divider{width:1px;height:36px;background:linear-gradient(180deg,transparent,rgba(201,160,58,.3),transparent)}
@media(max-width:640px){.stat-divider{display:none}}
.scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:3}
.scroll-text{font-size:.65rem;text-transform:uppercase;letter-spacing:.22em;color:var(--c-gold);opacity:.6}
.scroll-line{width:1px;height:28px;background:linear-gradient(180deg,var(--c-gold),transparent);
  animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1)}100%{transform:scaleY(0);transform-origin:bottom}}

/* ─── Hero cinematográfico ─── */
.hero-luxury .hero-media{position:absolute;inset:0;z-index:0}
.hero-luxury .hero-video{filter:brightness(0.5) saturate(0.9) contrast(1.1);transform:scale(1.02)}
.hero-vignette{position:absolute;inset:0;
  background:radial-gradient(ellipse at center,transparent 50%,rgba(4,4,8,.6) 100%);
  pointer-events:none;z-index:2}
.hero-scanlines{position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);
  pointer-events:none;z-index:2;opacity:.4}
.hero-glow-1{position:absolute;width:50vw;height:50vw;max-width:600px;max-height:600px;
  border-radius:50%;background:radial-gradient(circle,rgba(201,160,58,.15),transparent 70%);
  filter:blur(80px);top:5%;left:10%;animation:floatGlow 12s ease-in-out infinite;z-index:1;pointer-events:none}
.hero-glow-2{position:absolute;width:40vw;height:40vw;max-width:500px;max-height:500px;
  border-radius:50%;background:radial-gradient(circle,rgba(212,168,83,.1),transparent 70%);
  filter:blur(100px);bottom:10%;right:5%;animation:floatGlow 16s ease-in-out infinite reverse;z-index:1;pointer-events:none}
@keyframes floatGlow{0%,100%{transform:translate(0,0)}33%{transform:translate(30px,-20px)}66%{transform:translate(-20px,15px)}}

/* ─── Hero Luxury · Restaurante Premium ─── */
.hero-luxury .hero-inner{max-width:780px;display:flex;flex-direction:column;align-items:center}
.hero-brand{margin-bottom:1.2rem}
.hero-logo{width:100px;height:100px;border-radius:50%;object-fit:contain;
  background:rgba(0,0,0,.3);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);
  padding:12px;border:1px solid rgba(201,160,58,.2);
  box-shadow:0 0 60px rgba(201,160,58,.2),0 0 100px rgba(201,160,58,.08)}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.7rem;
  font-size:.78rem;font-weight:500;color:var(--c-gold);letter-spacing:.18em;
  text-transform:uppercase;margin-bottom:1rem}
.hero-sep-dot{font-size:6px;opacity:.5}
.hero-title{font-family:var(--font-display);margin-bottom:.8rem}
.hero-title-line{font-size:clamp(2.4rem,7vw,5.5rem);font-weight:700;line-height:1.05;
  letter-spacing:.03em;color:var(--text);text-shadow:0 2px 40px rgba(0,0,0,.6)}
.hero-separator{display:flex;align-items:center;gap:20px;margin-bottom:1.2rem}
.hero-sep-line{width:50px;height:1px;background:linear-gradient(90deg,transparent,rgba(201,160,58,.5),transparent)}
.hero-sep-icon{font-size:9px;color:var(--c-gold);opacity:.6}
.hero-sub{font-size:clamp(1rem,1.8vw,1.15rem);color:var(--text-soft);max-width:560px;
  margin:0 auto 2.2rem;line-height:1.5;font-style:italic;font-family:var(--font-display)}
/* CTA Luxury */
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
.hero-cta-btn{position:relative;display:inline-flex;align-items:center;gap:10px;
  padding:.9rem 2rem;border-radius:60px;font-weight:600;font-size:.95rem;
  cursor:pointer;transition:all .5s cubic-bezier(.16,1,.3,1);text-decoration:none;
  letter-spacing:.02em;overflow:hidden}
.hero-cta-primary{background:linear-gradient(135deg,#c9a03a,#e0c36a,#8b6914);color:#0d0b06;
  border:none;box-shadow:0 6px 24px rgba(201,160,58,.25)}
.hero-cta-primary:hover{transform:translateY(-2px);box-shadow:0 10px 35px rgba(201,160,58,.4)}
.hero-cta-ghost{background:rgba(12,12,20,.55);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(201,160,58,.25);color:var(--c-gold-light)}
.hero-cta-ghost:hover{transform:translateY(-2px);border-color:rgba(201,160,58,.5);
  box-shadow:0 8px 30px rgba(0,0,0,.4),0 0 30px rgba(201,160,58,.08)}
.hero-cta-shine{position:absolute;top:-50%;left:-100%;width:50%;height:200%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
  transform:rotate(25deg);animation:ctaShine 4s ease-in-out infinite}
@keyframes ctaShine{0%,100%{left:-100%}50%{left:150%}}
.hero-cta-arrow{font-size:.75rem;transition:transform .3s}
.hero-cta-primary:hover .hero-cta-arrow{transform:translateX(4px)}
/* Features */
.hero-features{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center}
.hero-feat{display:flex;align-items:center;gap:5px;font-size:.72rem;font-weight:400;
  letter-spacing:.12em;text-transform:uppercase;color:var(--text-mute)}
.hero-feat i{font-size:.6rem;color:var(--c-gold);opacity:.7}
.hero-feat-num{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--c-gold-light);letter-spacing:0;margin-left:2px}
.hero-feat-div{font-size:.6rem;color:var(--text-mute);opacity:.25}

.hero-particles{position:absolute;inset:0;z-index:2;pointer-events:none}

@media(max-width:600px){
  .hero{padding:calc(var(--header-h) + 2rem) 0 3rem}
  .hero-logo{width:75px;height:75px;padding:8px}
  .hero-title-line{font-size:clamp(2rem,8vw,3rem)}
  .hero-sep-line{width:30px}
  .hero-cta-btn{padding:.75rem 1.5rem;font-size:.88rem}
  .hero-luxury .hero-video{filter:brightness(0.45) saturate(1)}
  .hero-video{object-position:center}
}
.eyebrow-star{color:var(--c-gold);font-size:.65rem}

/* ---------- Secciones ---------- */
.section{padding:clamp(3.5rem,8vw,7rem) 0}
.section-head{text-align:center;margin-bottom:3rem}
.section-head .section-title{margin-top:.4rem}
.center-cta{text-align:center;margin-top:3rem}
.empty-note{grid-column:1/-1;text-align:center;color:var(--text-mute);padding:3rem}

/* ---------- Ornamento separador ---------- */
.section-ornament{display:flex;align-items:center;justify-content:center;gap:1rem;
  padding:1.5rem 0;color:var(--c-gold);opacity:.5}
.ornament-line{display:block;width:60px;height:1px;
  background:linear-gradient(90deg,transparent,var(--c-gold),transparent)}

/* ─── Categorías · Luxury Editorial ─── */
.section-head-luxe{text-align:center;margin-bottom:3rem}
.luxe-eyebrow{font-size:.7rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;
  color:var(--c-gold);margin-bottom:.6rem}
.luxe-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.2rem);font-weight:700;
  color:var(--text);margin:0 0 .8rem;letter-spacing:.02em}
.luxe-ornament{font-size:10px;color:var(--c-gold);opacity:.4}

/* Grid de categorías principales */
.luxe-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(201,160,58,.06);
  max-width:1000px;margin:0 auto 3rem;border:1px solid rgba(201,160,58,.06)}
.luxe-card{position:relative;display:flex;align-items:center;justify-content:center;
  padding:2.2rem 1rem;text-decoration:none;background:var(--bg);text-align:center;
  transition:all .4s ease;overflow:hidden;min-height:120px}
.luxe-card:hover{background:#0c0c16;z-index:1}
.luxe-card-bg{position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity .5s ease}
.luxe-card:hover .luxe-card-bg{opacity:.12}
.luxe-card-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:.6rem}
.luxe-card-icon{font-size:1.3rem;color:var(--c-gold);opacity:.5;transition:.3s}
.luxe-card:hover .luxe-card-icon{opacity:1;transform:translateY(-3px)}
.luxe-card-name{font-family:var(--font-display);font-size:.88rem;font-weight:600;
  color:var(--text-soft);letter-spacing:.04em;transition:.3s;line-height:1.2}
.luxe-card:hover .luxe-card-name{color:var(--c-gold-light)}
.luxe-card-line{width:0;height:1px;background:var(--c-gold);transition:width .4s ease}
.luxe-card:hover .luxe-card-line{width:30px}

/* Bodega */
.luxe-bodega{text-align:center;max-width:700px;margin:0 auto}
.luxe-subtitle{font-family:var(--font-display);font-size:1.2rem;font-weight:600;
  color:var(--c-gold-light);letter-spacing:.08em;margin-bottom:1.2rem}
.luxe-bodega-list{display:flex;justify-content:center;flex-wrap:wrap;gap:.4rem 2rem}
.luxe-bodega-link{font-size:.85rem;color:var(--text-soft);text-decoration:none;
  letter-spacing:.06em;padding:.3rem 0;transition:.3s;border-bottom:1px solid transparent}
/* ─── Mapa ─── */
.section-map{padding:4rem 0 2rem}
.map-wrapper{max-width:900px;margin:0 auto 1.5rem;border-radius:16px;overflow:hidden;
  border:1px solid rgba(201,160,58,.12);box-shadow:0 20px 60px rgba(0,0,0,.4)}
.map-wrapper iframe{display:block}
.map-address{text-align:center;font-size:.85rem;color:var(--text-soft);letter-spacing:.04em}
/* ─── Testimonios Carousel ─── */
.section-testimonials{padding:4rem 0 2rem;overflow:hidden}
.testi-carousel-wrapper{max-width:100%;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.testi-carousel-track{display:flex;gap:1.2rem;width:max-content;animation:testiScroll 40s linear infinite}
.testi-carousel-track:hover{animation-play-state:paused}
.testi-slide{flex:0 0 320px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:1.4rem;min-height:180px;display:flex;flex-direction:column}
.testi-stars{color:var(--c-gold);font-size:.85rem;margin-bottom:.6rem;letter-spacing:2px}
.testi-text{font-size:.85rem;color:var(--text-soft);line-height:1.55;flex:1;font-style:italic}
.testi-author{display:flex;align-items:center;gap:.6rem;margin-top:.8rem;padding-top:.8rem;border-top:1px solid var(--border)}
.testi-photo{width:40px;height:40px;border-radius:50%;flex-shrink:0;object-fit:cover}
.testi-author strong{display:block;font-size:.82rem;color:var(--text)}
.testi-date{font-size:.7rem;color:var(--text-mute)}

@keyframes testiScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

@media(max-width:600px){
  .testi-slide{flex:0 0 280px;padding:1.1rem}
}@media(max-width:600px){.map-wrapper iframe{height:250px}}
.footer-map{border-radius:10px;overflow:hidden;border:1px solid rgba(201,160,58,.08)}
@media(max-width:600px){.map-wrapper iframe{height:250px}}

@media(max-width:768px){
  .luxe-grid{grid-template-columns:repeat(2,1fr)}
  .luxe-card{padding:1.5rem .8rem;min-height:90px}
  .luxe-card-name{font-size:.78rem}
}
@media(max-width:380px){
  .luxe-grid{grid-template-columns:1fr 1fr}
  .luxe-card{padding:1.2rem .5rem;min-height:70px}
  .luxe-card-name{font-size:.7rem}
}

/* ---------- Grid de productos ---------- */
.products-grid{display:grid;gap:1.6rem;
  grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}
.product-card{position:relative;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;transition:transform .4s var(--ease),
  box-shadow .4s var(--ease),border-color .4s;transform-style:preserve-3d;will-change:transform}
.product-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-card),0 0 30px rgba(201,160,58,.06);
  border-color:rgba(201,160,58,.3)}
.product-card.no-disponible{opacity:.55;filter:grayscale(.4)}
.product-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.product-media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.product-card:hover .product-media img{transform:scale(1.08)}
.product-badges{position:absolute;top:.8rem;left:.8rem;display:flex;gap:.4rem;flex-wrap:wrap}
.badge-destacado{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .7rem;
  border-radius:50px;font-size:.7rem;font-weight:700;background:var(--grad-warm);color:#1a1020}
.badge-recom{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;
  background:rgba(0,0,0,.5);color:#ff6b6b;font-size:.8rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.fav-btn{position:absolute;top:.7rem;right:.7rem;width:38px;height:38px;border-radius:50%;
  background:rgba(0,0,0,.45);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;
  display:grid;place-items:center;transition:.25s}
.fav-btn:hover,.fav-btn.is-fav{background:var(--grad-warm);color:#1a1020;transform:scale(1.1)}
.fav-btn.is-fav i{font-weight:900}
.product-body{padding:1.3rem}
.product-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.8rem}
.product-title{font-size:1.35rem;line-height:1.15}
.product-price{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--c-gold);white-space:nowrap}
.product-desc{color:var(--text-soft);font-size:.9rem;margin:.5rem 0 .8rem;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.product-meta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.7rem}
.meta-item{font-size:.8rem;color:var(--text-mute);display:inline-flex;gap:.35rem;align-items:center}
.product-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.7rem}
.product-link{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;font-size:.9rem;
  color:var(--c-gold);margin-top:.3rem;transition:gap .25s}
.product-link:hover{gap:.7rem}

/* ---------- Alérgenos ---------- */
.alergenos-grid{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.8rem}
.alergeno-badge{width:30px;height:30px;display:inline-grid;place-items:center;border-radius:9px;
  background:var(--surface-2);border:1px solid var(--border);color:var(--c-gold)}
.alergeno-badge svg{width:18px;height:18px}
.alergeno-badge small{display:none}
.alergenos-grid.with-text .alergeno-badge,
.detail-block .alergeno-badge{width:auto;padding:.4rem .7rem;gap:.4rem;display:inline-flex}
.detail-block .alergeno-badge small{display:inline;font-size:.78rem;color:var(--text-soft)}

/* ---------- Experiencia ---------- */
.exp-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.exp-text p{color:var(--text-soft);margin:1rem 0}
.feature-list{margin:1.5rem 0}
.feature-list li{display:flex;align-items:center;gap:.8rem;padding:.5rem 0;color:var(--text)}
.feature-list i{color:var(--c-gold);width:24px}
.exp-card{padding:2.5rem;text-align:center}
.exp-card i.fa-quote-left{font-size:2rem;color:var(--c-gold);opacity:.5}
.exp-card p{font-family:var(--font-display);font-size:1.4rem;line-height:1.4;margin:1rem 0}
.exp-rating{color:var(--c-gold)}
@media(max-width:820px){.exp-grid{grid-template-columns:1fr;gap:2rem}}

/* ---------- Menú: layout filtros ---------- */
.menu-hero,.form-hero{padding:calc(var(--header-h) + 3rem) 0 1rem;text-align:center}
.page-title{font-size:clamp(2.4rem,6vw,4rem);margin:.3rem 0}
.page-lead{color:var(--text-soft);max-width:560px;margin:.5rem auto 0}
.menu-layout{display:grid;grid-template-columns:290px 1fr;gap:2rem;align-items:start}
.menu-filters{padding:1.5rem;position:sticky;top:calc(var(--header-h) + 1rem)}
.filter-search{position:relative;margin-bottom:1.4rem}
.filter-search i{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-mute)}
.filter-search input{width:100%;padding:.85rem 1rem .85rem 2.6rem;border-radius:50px;
  background:var(--surface);border:1px solid var(--border);color:var(--text)}
.filter-block{margin-bottom:1.5rem}
.filter-title{font-family:var(--font-body);font-size:.82rem;text-transform:uppercase;
  letter-spacing:.1em;color:var(--text-mute);margin-bottom:.8rem}
.filter-cats{display:flex;flex-wrap:wrap;gap:.5rem}
.cat-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .9rem;border-radius:50px;
  background:var(--surface);border:1px solid var(--border);font-size:.85rem;font-weight:500;transition:.25s}
.cat-pill:hover{border-color:var(--c-gold)}
.cat-pill.is-active{background:var(--grad-warm);color:#1a1020;border-color:transparent}
input[type=range]{width:100%;accent-color:var(--c-amber);height:6px}
.filter-alergenos{display:grid;grid-template-columns:1fr;gap:.35rem;max-height:280px;overflow-y:auto}
.alerg-check{display:flex;align-items:center;gap:.6rem;padding:.4rem .5rem;border-radius:10px;
  cursor:pointer;transition:.2s;font-size:.85rem}
.alerg-check:hover{background:var(--surface)}
.alerg-check input{accent-color:var(--c-amber)}
.alerg-ico{width:22px;height:22px;color:var(--c-gold)}
.alerg-ico svg{width:20px;height:20px}
.menu-results{min-height:300px}
.results-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem}
.results-bar p{color:var(--text-soft);font-size:.9rem}
.filters-toggle{display:none;width:auto;padding:.5rem 1rem;gap:.4rem}
.no-results{text-align:center;padding:4rem 1rem;color:var(--text-mute);font-size:1.1rem}
.no-results i{display:block;font-size:2.5rem;margin-bottom:1rem;color:var(--c-gold);opacity:.5}

@media(max-width:880px){
  .menu-layout{grid-template-columns:1fr}
  .menu-filters{position:fixed;inset:0 0 0 auto;width:min(340px,86vw);z-index:950;
    border-radius:0;transform:translateX(110%);transition:.4s var(--ease);overflow-y:auto;
    top:0;height:100dvh;padding-top:2rem}
  .menu-filters.open{transform:translateX(0)}
  .filters-toggle{display:inline-flex}
}

/* ---------- Detalle de producto ---------- */
.product-detail{padding:calc(var(--header-h) + 2rem) 0 2rem}
.breadcrumb{font-size:.85rem;color:var(--text-mute);margin-bottom:1.5rem}
.breadcrumb a:hover{color:var(--c-gold)}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.detail-media{position:relative}
.detail-img-wrap{border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:1;box-shadow:var(--shadow-card)}
.detail-img-wrap img{width:100%;height:100%;object-fit:cover}
.detail-flag{position:absolute;top:1rem;left:1rem;padding:.5rem 1rem;border-radius:50px;
  background:var(--grad-warm);color:#1a1020;font-weight:700;font-size:.8rem}
.detail-flag.no-disp{background:#444;color:#fff}
.detail-cat{text-transform:uppercase;letter-spacing:.15em;font-size:.78rem;color:var(--c-gold);font-weight:600}
.detail-title{font-size:clamp(2rem,5vw,3.2rem);margin:.3rem 0}
.detail-price{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--c-gold);margin:.5rem 0 1rem}
.detail-desc{color:var(--text-soft);font-size:1.05rem;margin:1rem 0}
.detail-meta{display:flex;gap:1rem;flex-wrap:wrap;margin:1.5rem 0}
.meta-box{flex:1;min-width:100px;padding:1rem;border-radius:var(--radius);background:var(--surface);
  border:1px solid var(--border);text-align:center}
.meta-box i{color:var(--c-gold);font-size:1.2rem}
.meta-box span{display:block;font-weight:700;margin-top:.3rem}
.meta-box small{color:var(--text-mute);font-size:.72rem}
.detail-block{margin:1.5rem 0;padding-top:1.5rem;border-top:1px solid var(--border)}
.detail-block h2{font-size:1.2rem;display:flex;align-items:center;gap:.5rem;margin-bottom:.7rem}
.detail-block h2 i{color:var(--c-gold);font-size:1rem}
.detail-block p{color:var(--text-soft)}
.detail-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.5rem}
.related{margin-top:4rem}
.related .section-title{margin-bottom:2rem;text-align:center}
@media(max-width:820px){.detail-grid{grid-template-columns:1fr;gap:2rem}}

/* ---------- Formularios ---------- */
.form-layout{display:grid;grid-template-columns:1.4fr .8fr;gap:2rem;align-items:start}
.form-card{padding:2.2rem}
.styled-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.4rem;color:var(--text-soft)}
.field input,.field textarea,.field select{width:100%;padding:.85rem 1rem;border-radius:var(--radius-sm);
  background:var(--surface);border:1px solid var(--border);color:var(--text);font:inherit;transition:.25s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--c-gold);
  background:var(--surface-2);outline:none}
.field textarea{resize:vertical}
.form-aside{display:flex;flex-direction:column;gap:1rem}
.info-card{padding:1.4rem}
.info-card h3{font-family:var(--font-body);font-size:1rem;display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}
.info-card h3 i{color:var(--c-gold)}
.info-card p{color:var(--text-soft);font-size:.92rem}
.alert{display:flex;gap:.7rem;padding:1rem 1.2rem;border-radius:var(--radius-sm);margin-bottom:1.5rem;font-size:.92rem}
.alert ul{margin-left:.5rem}
.alert-success{background:rgba(57,217,138,.12);border:1px solid rgba(57,217,138,.3);color:#39d98a}
.alert-error{background:rgba(255,93,93,.1);border:1px solid rgba(255,93,93,.3);color:#ff7a7a}
@media(max-width:820px){.form-layout{grid-template-columns:1fr}.styled-form .form-row{grid-template-columns:1fr}}

/* ---------- Estado vacío / 404 ---------- */
.empty-state{text-align:center;padding:5rem 1rem}
.empty-state i{font-size:3.5rem;color:var(--c-gold);opacity:.5;margin-bottom:1rem}
.empty-state h1{font-size:2rem;margin-bottom:.5rem}
.empty-state p{color:var(--text-soft);margin-bottom:1.5rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--bg-2);border-top:1px solid var(--border);padding-top:4rem;margin-top:2rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem;padding-bottom:3rem}
.footer-slogan{color:var(--text-soft);margin-top:1rem;font-family:var(--font-display);font-size:1.1rem}
.footer-col h4{font-family:var(--font-body);font-size:.85rem;text-transform:uppercase;
  letter-spacing:.12em;color:var(--text-mute);margin-bottom:1rem}
.footer-col p{color:var(--text-soft);font-size:.92rem;margin-bottom:.6rem;display:flex;gap:.5rem;align-items:flex-start}
.footer-col p i{color:var(--c-gold);margin-top:.2rem}
.footer-nav{display:flex;flex-direction:column;gap:.5rem}
.footer-nav a{color:var(--text-soft);transition:.2s}
.footer-nav a:hover{color:var(--c-gold);padding-left:.3rem}
.social-row{display:flex;gap:.7rem}
.social-row a{width:40px;height:40px;display:grid;place-items:center;border-radius:50%;
  background:var(--surface);border:1px solid var(--border);transition:.25s}
.social-row a:hover{background:var(--grad-warm);color:#1a1020;transform:translateY(-3px)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;
  padding:1.5rem 0;border-top:1px solid var(--border);color:var(--text-mute);font-size:.85rem}
.footer-bottom i{color:var(--c-amber)}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Back to top ---------- */
.back-to-top{position:fixed;bottom:1.5rem;right:1.5rem;width:48px;height:48px;border-radius:50%;
  background:var(--grad-warm);color:#1a1020;display:grid;place-items:center;z-index:800;
  opacity:0;visibility:hidden;transform:translateY(20px);transition:.35s var(--ease);box-shadow:var(--shadow-card)}
.back-to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{transform:translateY(-4px) scale(1.05)}

/* ---------- AOS fallback (si no carga JS) ---------- */
[data-aos]{opacity:1}
.aos-init[data-aos]{opacity:0}
.aos-init.aos-animate[data-aos]{opacity:1}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(120%);
  background:var(--glass-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border:1px solid var(--glass-border);padding:.9rem 1.4rem;border-radius:50px;z-index:9000;
  transition:.4s var(--ease);box-shadow:var(--shadow-card);font-size:.9rem;display:flex;gap:.5rem;align-items:center}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast i{color:var(--c-gold)}

/* ---------- WhatsApp flotante ---------- */
.whatsapp-float{position:fixed;bottom:6rem;right:1.5rem;width:56px;height:56px;
  border-radius:50%;background:#25d366;color:#fff;display:grid;place-items:center;
  z-index:800;box-shadow:0 8px 30px rgba(37,211,102,.4);font-size:1.6rem;
  transition:.3s var(--ease);animation:waPulse 2s ease-in-out infinite}
.whatsapp-float:hover{transform:scale(1.15);box-shadow:0 12px 40px rgba(37,211,102,.6)}
@keyframes waPulse{0%,100%{box-shadow:0 8px 30px rgba(37,211,102,.4)}50%{box-shadow:0 8px 40px rgba(37,211,102,.7)}}
