:root {
  --mustard: #C9952A;
  --mustard-light: #E8B84B;
  --mustard-deep: #A67A1E;
  --olive: #6B7C45;
  --olive-deep: #4A5A28;
  --shadow-mustard: rgba(201, 149, 42, 0.2);
  --cream: #FFF8F0;
  --cream-warm: #FFE8D0;
  --bone: #FFFAF5;
  --ink: #1A0500;
  --ink-soft: #3D3028;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Outfit',sans-serif;
  background:var(--bone);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body::before {
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1000;
  opacity:0.04;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ====== HERO ====== */
/* RESPONSIVO: padding móvil primero */
.menu-hero {
  min-height:40vh;
  display:flex;
  align-items:center;
  padding:6rem 1.5rem 3rem;
  position:relative;
  overflow:hidden;
  background:linear-gradient(120deg, var(--cream) 0%, var(--cream-warm) 55%, #fde8d0 100%);
  margin-top:0;
}
.menu-hero-blob {
  position:absolute;
  border-radius:50%;
  filter:blur(90px);
  opacity:0.18;
  pointer-events:none;
}
.menu-hero-blob:nth-child(1) { width:440px; height:440px; background:var(--mustard); top:-100px; right:42%; }
.menu-hero-blob:nth-child(2) { width:300px; height:300px; background:var(--olive); bottom:-40px; left:25%; }
/* RESPONSIVO: contenido a ancho completo en móvil */
.menu-hero-content { position:relative; z-index:2; padding:2rem 0; flex:1; }

/* RESPONSIVO: imagen hero oculta en móvil */
.menu-hero-img {
  display:none;
  position:absolute;
  top:0; right:0;
  width:50%;
  height:100%;
  z-index:1;
  overflow:hidden;
}
.menu-hero-img::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to right, var(--cream) 0%, transparent 18%);
  z-index:2;
  pointer-events:none;
}
.menu-hero-img img {
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:left top;
  display:block;
}
.eyebrow {
  display:inline-flex;
  align-items:center;
  gap:0.5rem;
  font-size:0.75rem;
  font-weight:700;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--mustard);
  margin-bottom:1rem;
}
.eyebrow span { font-family:'Caveat',cursive; font-size:1.3rem; font-weight:400; letter-spacing:0; text-transform:none; }
.menu-hero h1 {
  font-family:'Fraunces',serif;
  font-size:clamp(3rem,6vw,5.5rem);
  line-height:1.05;
  color:var(--ink);
  font-style:italic;
}
.menu-hero h1 em { color:var(--mustard); font-style:italic; }
.menu-hero p {
  margin-top:1.2rem;
  font-size:1.05rem;
  color:var(--ink-soft);
  max-width:420px;
  line-height:1.7;
}

/* ====== MARQUEE ====== */
.marquee-strip {
  background:var(--mustard);
  color:#fff;
  overflow:hidden;
  white-space:nowrap;
  padding:0.85rem 0;
}
.marquee-track { display:inline-flex; animation:marquee 30s linear infinite; }
.marquee-track span { font-size:0.76rem; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; padding:0 2.5rem; }
.marquee-track span.dot { color:var(--mustard-light); font-size:1rem; padding:0; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ====== MENU PAGES (static images) ====== */
.menu-pages-section {
  padding: 0;
  background: var(--bone);
  margin: 0;
}
.menu-pages-header {
  text-align: center;
  padding: 3rem 5% 1.5rem;
}
.menu-pages-header h2 {
  font-family: 'Fraunces', serif;
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  color: var(--ink);
  margin-top: 0.4rem;
}
.menu-pages-header h2 em {
  font-style: italic;
  color: var(--mustard);
}
.menu-pages-grid {
  display: flex;
  flex-direction: row;
  gap: 0;
  width: 100%;
  align-items: flex-start;
}
.menu-page-img {
  width: 50%;
  flex: 0 0 50%;
  border-radius: 0;
  box-shadow: none;
  border: none;
  display: block;
}
@media (max-width: 768px) {
  .menu-pages-header { padding: 2rem 4% 1rem; }
  .menu-pages-grid { flex-direction: column; }
  .menu-page-img { width: 100%; flex: 0 0 100%; }
}

/* ====== ELEGANT MENU ====== */
.em-section {
  padding: 4rem 6% 5rem;
  background: var(--bone);
  max-width: 1400px;
  margin: 0 auto;
}

/* Intro header */
.em-intro {
  text-align: center;
  margin-bottom: 3.5rem;
}
.em-script {
  font-family: 'Great Vibes', cursive;
  font-size: clamp(2.8rem, 5.5vw, 5rem);
  font-weight: 400;
  color: var(--mustard);
  line-height: 1;
  margin: 0 0 0.4rem;
}
.em-tagline {
  font-family: 'Playfair Display', serif;
  font-size: 0.72rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

/* Category block */
.em-category {
  margin-bottom: 3rem;
}

/* Divider with category label */
.em-divider {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.8rem;
}
.em-divider::before,
.em-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(201,149,42,0.3);
}
.em-divider span {
  font-family: 'Playfair Display', serif;
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--mustard);
  white-space: nowrap;
}

/* 4-column grid */
.em-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.6rem 2.2rem;
}

/* Individual dish */
.em-dish {
  border-left: 1.5px solid var(--ink-soft);
  padding-left: 1rem;
  position: relative;
}
.em-dish--featured .em-name {
  color: var(--mustard-deep);
}

/* Dish top row: name + price */
.em-dish-top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
  flex-wrap: wrap;
}
.em-name {
  font-family: 'Outfit', sans-serif;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
  line-height: 1.3;
}
.em-price {
  font-family: 'Playfair Display', serif;
  font-size: 0.82rem;
  font-style: italic;
  color: var(--mustard-deep);
  white-space: nowrap;
  flex-shrink: 0;
}
.em-price-variants {
  font-family: 'Outfit', sans-serif;
  font-size: 0.65rem;
  font-weight: 500;
  color: var(--ink-soft);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  flex-shrink: 0;
}
.em-sep {
  color: var(--mustard);
  opacity: 0.6;
}
.em-desc {
  font-family: 'Outfit', sans-serif;
  font-size: 0.76rem;
  font-weight: 300;
  color: var(--ink-soft);
  line-height: 1.55;
  margin: 0;
}
.em-badge {
  display: inline-block;
  margin-top: 0.5rem;
  font-family: 'Outfit', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mustard);
  border: 1px solid var(--mustard);
  padding: 0.15rem 0.55rem;
  border-radius: 100px;
}

.em-note {
  grid-column: 1 / -1;
  margin-top: 0.8rem;
  font-family: 'Outfit', sans-serif;
  font-size: 0.7rem;
  color: var(--ink-soft);
  font-style: italic;
  letter-spacing: 0.04em;
}

/* CTA */
.em-cta {
  text-align: center;
  margin-top: 4rem;
  padding-top: 3rem;
  border-top: 1px solid rgba(201,149,42,0.2);
}
.em-cta p {
  font-family: 'Outfit', sans-serif;
  font-size: 0.88rem;
  color: var(--ink-soft);
  margin-bottom: 1.1rem;
}
.em-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  background: var(--mustard);
  color: #fff;
  padding: 0.9rem 2.2rem;
  border-radius: 100px;
  font-family: 'Outfit', sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background 0.25s, transform 0.2s;
}
.em-cta-btn:hover {
  background: var(--mustard-deep);
  transform: translateY(-2px);
}

/* Responsive */
@media (max-width: 1100px) {
  .em-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .em-section { padding: 3rem 5% 4rem; }
  .em-grid { grid-template-columns: repeat(2, 1fr); gap: 1.2rem 1.5rem; }
}
@media (max-width: 480px) {
  .em-grid { grid-template-columns: 1fr; }
  .em-script { font-size: 2.8rem; }
}

/* ====== FILTER BAR ====== */
/* RESPONSIVO: padding móvil */
.filter-section {
  padding:1.5rem 1.5rem 1rem;
  background:var(--bone);
  position:sticky;
  top:60px;
  z-index:50;
  border-bottom:1px solid var(--cream-warm);
}
.filter-bar {
  display:flex;
  align-items:center;
  gap:0.7rem;
  flex-wrap:wrap;
  max-width:1300px;
  margin:0 auto;
}
.filter-label {
  font-size:0.72rem;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-right:0.5rem;
}
.filter-btn {
  background:none;
  border:2px solid var(--cream-warm);
  color:var(--ink-soft);
  padding:0.5rem 1.2rem;
  border-radius:100px;
  font-size:0.8rem;
  font-weight:600;
  letter-spacing:0.06em;
  text-transform:uppercase;
  cursor:pointer;
  font-family:'Outfit',sans-serif;
  transition:all 0.25s;
}
.filter-btn:hover { border-color:var(--mustard); color:var(--mustard); }
.filter-btn.active {
  background:var(--mustard);
  border-color:var(--mustard);
  color:#fff;
}
.filter-count {
  font-size:0.7rem;
  background:var(--cream-warm);
  color:var(--ink-soft);
  padding:0.15rem 0.5rem;
  border-radius:100px;
  margin-left:0.3rem;
  font-weight:700;
}
.filter-btn.active .filter-count { background:rgba(255,255,255,0.25); color:#fff; }

/* ====== MENU GRID ====== */
/* RESPONSIVO: padding móvil */
.menu-body {
  padding:2rem 1.5rem 4rem;
  max-width:1400px;
  margin:0 auto;
}
/* RESPONSIVO: 1 columna en móvil */
.menu-grid {
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(1rem, 3vw, 2rem);
}

/* ====== DISH CARD ====== */
.dish-card {
  background:var(--cream);
  border-radius:20px;
  overflow:hidden;
  position:relative;
  outline:2px solid transparent;
  cursor:pointer;
  transition:transform 0.55s cubic-bezier(0.22,1,0.36,1),
             box-shadow 0.55s cubic-bezier(0.22,1,0.36,1),
             outline 0.3s ease,
             opacity 0.4s ease;
  opacity:0;
  transform:translateY(20px);
}
.dish-card.visible { opacity:1; transform:translateY(0); }
.dish-card.hidden-item {
  display:none;
}
.dish-card:hover {
  transform:translateY(-10px) scale(1.02);
  box-shadow:0 32px 72px var(--shadow-mustard);
  outline:2px solid var(--mustard);
}
.dish-image {
  aspect-ratio:4/3;
  overflow:hidden;
  position:relative;
  background:linear-gradient(135deg, var(--mustard-deep), var(--ink));
}
.dish-image img {
  width:100%; height:100%;
  object-fit:cover;
  transition:transform 0.8s cubic-bezier(0.22,1,0.36,1);
  display:block;
}
.dish-card:hover .dish-image img { transform:scale(1.1); }

/* Placeholder for missing images */
.dish-img-placeholder {
  width:100%; height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg, var(--mustard-deep) 0%, var(--ink) 100%);
  font-family:'Fraunces',serif;
  font-style:italic;
  font-size:1.1rem;
  color:rgba(255,255,255,0.4);
  letter-spacing:0.04em;
  text-align:center;
  padding:1rem;
}

.dish-tag {
  position:absolute;
  top:1rem; left:1rem;
  background:var(--bone);
  color:var(--mustard);
  padding:0.35rem 0.85rem;
  border-radius:100px;
  font-size:0.68rem;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  z-index:3;
  transition:opacity 0.3s;
}
.dish-card:hover .dish-tag { opacity:0; }

.dish-price-badge {
  position:absolute;
  top:1rem; right:1rem;
  background:var(--mustard);
  color:var(--ink);
  padding:0.35rem 0.85rem;
  border-radius:100px;
  font-size:0.8rem;
  font-weight:700;
  z-index:3;
  transition:opacity 0.3s;
}
.dish-card:hover .dish-price-badge { opacity:0; }

.dish-overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(26,5,0,0.92) 0%, rgba(107,124,69,0.4) 55%, transparent 100%);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:1.5rem;
  opacity:0;
  transform:translateY(10px);
  transition:opacity 0.45s cubic-bezier(0.22,1,0.36,1), transform 0.45s cubic-bezier(0.22,1,0.36,1);
  z-index:2;
}
.dish-card:hover .dish-overlay { opacity:1; transform:translateY(0); }
.dish-overlay-name {
  font-family:'Fraunces',serif;
  font-size:1.6rem;
  color:#fff;
  line-height:1.1;
  font-style:italic;
  margin-bottom:0.5rem;
}
.dish-overlay-price {
  font-size:1.1rem;
  font-weight:700;
  color:var(--mustard);
  margin-bottom:0.8rem;
}
.dish-overlay-btn {
  display:inline-flex;
  align-items:center;
  gap:0.4rem;
  background:var(--mustard);
  color:var(--ink);
  padding:0.5rem 1rem;
  border-radius:100px;
  font-size:0.7rem;
  font-weight:700;
  letter-spacing:0.12em;
  text-transform:uppercase;
  width:fit-content;
  transform:translateY(6px);
  transition:transform 0.4s cubic-bezier(0.22,1,0.36,1) 0.05s;
}
.dish-card:hover .dish-overlay-btn { transform:translateY(0); }

.dish-content { padding:1.4rem 1.4rem 1.6rem; }
.dish-name {
  font-family:'Fraunces',serif;
  font-size:1.35rem;
  color:var(--ink);
  margin-bottom:0.4rem;
  font-weight:500;
}
.dish-description {
  color:var(--ink-soft);
  font-size:0.88rem;
  line-height:1.6;
  margin-bottom:0.8rem;
}
.dish-footer {
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.dish-price {
  font-size:1.15rem;
  font-weight:700;
  color:var(--mustard);
  font-family:'Fraunces',serif;
}

/* ====== EMPTY STATE ====== */
.menu-empty {
  display:none;
  text-align:center;
  padding:4rem 2rem;
  grid-column:1/-1;
}
.menu-empty.show { display:block; }
.menu-empty p { font-size:1rem; color:var(--ink-soft); }

/* ====== FOOTER ====== */
.menu-footer {
  background:var(--ink);
  color:rgba(255,255,255,0.5);
  text-align:center;
  padding:2rem;
  font-size:0.82rem;
}
.menu-footer a { color:var(--mustard); text-decoration:none; }

/* ====== RESPONSIVE (MOBILE-FIRST, min-width) ====== */

/* 480px: teléfonos medianos */
@media (min-width:480px) {
  /* RESPONSIVO: 2 columnas */
  .menu-grid { grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); }
}

/* 768px: tablets — layouts */
@media (min-width:768px) {
  .menu-hero { padding:0 3rem; min-height:52vh; margin-top:72px; }
  .menu-hero-content { flex:0 0 50%; padding:4rem 0; }
  /* RESPONSIVO: mostrar imagen hero en tablet+ */
  .menu-hero-img { display:block; }
  .filter-section { padding:2rem 3rem 1.25rem; top:72px; }
  .menu-body { padding:3rem 3rem 5rem; }
}

/* 1024px: desktop — 3 columnas */
@media (min-width:1024px) {
  .menu-grid { grid-template-columns:repeat(3, 1fr); }
  .menu-body { padding:3rem 4rem 6rem; }
  .filter-section { padding:3rem 4rem 1.5rem; }
}
