/* ============================================================
   SABROSUR — Sistema de diseño 2.0 · TEMA OSCURO
   Negro cálido · Rojo "Brasa" · Oro
   Display: Bricolage Grotesque · Texto: Hanken Grotesk
   ============================================================ */

:root {
  /* ---- Brasa (rojo brasa) — primario ---- */
  --brasa-50:#FDECE9; --brasa-100:#FBD9D2; --brasa-200:#F4ABA0; --brasa-300:#ED7C6C;
  --brasa-400:#E64E3A; --brasa-500:#E02B1D; --brasa-600:#C21F13; --brasa-700:#9C190F;
  --brasa-800:#74130B; --brasa-900:#4E0D08;

  /* ---- Oro — secundario ---- */
  --oro-50:#FFF8E1; --oro-100:#FFF0C2; --oro-200:#FFE085; --oro-300:#FFCF47;
  --oro-400:#FBB900; --oro-500:#E2A400; --oro-600:#BC8500; --oro-700:#936700;

  /* ---- Carbón (neutros cálidos) ---- */
  --carbon-950:#16110E; --carbon-900:#1C1714; --carbon-800:#2E2622; --carbon-700:#443A33;
  --carbon-600:#5E5147; --carbon-500:#7C6E62; --carbon-400:#9F9286; --carbon-300:#C2B7AC;
  --carbon-200:#DED5CB; --carbon-100:#EFE9E1; --carbon-50:#F7F2EB;

  /* ---- Roast (apetito) ---- */
  --roast-toast:#C77B3C; --roast-crust:#8A4A24; --roast-ember:#5C2C16;

  /* ---- Semánticos (OSCURO) ---- */
  --bg:#0D0B09;            /* fondo casi negro cálido */
  --bg-alt:#141009;        /* secciones alternas */
  --surface:#1A1511;       /* tarjetas */
  --surface-2:#221C16;     /* tarjeta elevada / hover */
  --primary:var(--brasa-500); --primary-hover:var(--brasa-400); --primary-press:var(--brasa-600);
  --secondary:var(--oro-400);
  --fg:#F4ECDD;            /* texto principal (crema) */
  --fg-2:#CBBFAD;          /* texto secundario */
  --fg-3:#8E8676;          /* muted / captions */
  --border:#2A2420;        /* hairline */
  --border-strong:#3A332C;
  --link:var(--brasa-400);
  --open:#5FC27E; --open-bg:rgba(95,194,126,.14); --closed:var(--brasa-400); --focus:var(--oro-400);

  /* ---- Tipografía ---- */
  --font-display:'Bricolage Grotesque','Hanken Grotesk',system-ui,sans-serif;
  --font-text:'Hanken Grotesk',system-ui,-apple-system,sans-serif;

  --text-xs:.75rem; --text-sm:.875rem; --text-base:1rem; --text-lg:1.125rem;
  --text-xl:1.375rem; --text-2xl:1.75rem; --text-3xl:2.25rem; --text-4xl:3rem;
  --text-5xl:clamp(2.75rem,5vw + 1rem,4.5rem);
  --text-6xl:clamp(3.25rem,7vw + 1rem,6rem);

  --tracking-tight:-0.02em; --tracking-snug:-0.01em; --tracking-caps:.12em;

  /* ---- Espaciado / forma ---- */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:24px;
  --space-6:32px; --space-7:48px; --space-8:64px; --space-9:96px; --space-10:128px;

  --radius-xs:6px; --radius-sm:10px; --radius-md:16px; --radius-lg:22px; --radius-xl:30px; --radius-pill:999px;

  /* ---- Sombras (negras, para profundidad sobre fondo oscuro) ---- */
  --shadow-xs:0 1px 2px rgba(0,0,0,.4);
  --shadow-sm:0 2px 8px rgba(0,0,0,.45);
  --shadow-md:0 12px 28px -8px rgba(0,0,0,.6),0 2px 8px rgba(0,0,0,.4);
  --shadow-lg:0 28px 56px -16px rgba(0,0,0,.7),0 8px 18px rgba(0,0,0,.45);
  --shadow-brasa:0 14px 34px -10px rgba(224,43,29,.5);

  /* ---- Movimiento ---- */
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.16,1,.3,1);
  --dur-fast:140ms; --dur:220ms; --dur-slow:420ms;

  /* ---- Layout ---- */
  --header-h:76px;
  --gutter:clamp(20px,5vw,40px);
  --max-w:1200px;
}

/* ====== Reset ====== */
*,*::before,*::after { box-sizing:border-box; }
* { margin:0; }
html {
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
  scroll-padding-top:calc(var(--header-h) + 12px);
}
body {
  font-family:var(--font-text);
  font-weight:400;
  font-size:17px;
  line-height:1.55;
  color:var(--fg);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img,video,svg { display:block; max-width:100%; height:auto; }
button { font:inherit; background:none; border:0; color:inherit; cursor:pointer; padding:0; }
a { color:inherit; text-decoration:none; }
ul,ol { list-style:none; padding:0; }
input,textarea,select { font:inherit; color:inherit; }
:focus-visible { outline:3px solid var(--focus); outline-offset:2px; border-radius:4px; }
::selection { background:var(--brasa-500); color:#fff; }

/* Calidez muy sutil sobre el negro */
body::before {
  content:''; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(60% 45% at 85% -5%, rgba(251,185,0,.07), transparent 60%),
    radial-gradient(55% 45% at -5% 100%, rgba(224,43,29,.07), transparent 55%);
}

/* ====== Tipografía ====== */
h1,h2,h3,h4,h5 { font-family:var(--font-display); color:var(--fg); font-weight:700; }
.h-display { font-size:var(--text-6xl); font-weight:800; line-height:1.02; letter-spacing:-0.025em; }
h1,.h1 { font-size:var(--text-5xl); font-weight:800; line-height:1.05; letter-spacing:var(--tracking-tight); }
h2,.h2 { font-size:var(--text-4xl); line-height:1.08; letter-spacing:var(--tracking-tight); }
h3,.h3 { font-size:var(--text-3xl); line-height:1.12; letter-spacing:var(--tracking-snug); }
h4 { font-size:var(--text-2xl); font-weight:600; line-height:1.15; }
.lead { font-size:var(--text-lg); line-height:1.6; color:var(--fg-2); }
p { color:var(--fg-2); }
strong { color:var(--fg); font-weight:700; }
em { font-style:italic; }

.text-brasa { color:var(--brasa-400); }
.text-oro { color:var(--oro-400); }

/* Eyebrow / overline */
.eyebrow {
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-text); font-weight:800; font-size:13px;
  letter-spacing:var(--tracking-caps); text-transform:uppercase; color:var(--brasa-400);
}
.eyebrow .dot { width:7px; height:7px; border-radius:50%; background:var(--oro-400); flex:none; }
.eyebrow.on-dark { color:var(--oro-400); }

.num { font-variant-numeric:tabular-nums; letter-spacing:-0.01em; }

/* ====== Contenedor ====== */
.wrap { width:100%; max-width:var(--max-w); margin:0 auto; padding:0 var(--gutter); }
.section { position:relative; padding:clamp(64px,10vw,120px) 0; }
.section + .section, .section-alt { border-top:1px solid rgba(255,255,255,.05); }
.section-alt { background:var(--bg-alt); }

/* ============================================================
   BOTONES
   ============================================================ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font-text); font-weight:700; font-size:15px;
  border:0; border-radius:var(--radius-pill); padding:13px 24px; white-space:nowrap;
  transition:transform var(--dur) var(--ease), background var(--dur) var(--ease),
    box-shadow var(--dur) var(--ease), color var(--dur), border-color var(--dur);
}
.btn i,.btn svg { width:18px; height:18px; }
.btn-primary { background:var(--brasa-500); color:#fff; box-shadow:var(--shadow-brasa); }
.btn-primary:hover { background:var(--brasa-400); transform:translateY(-1px); box-shadow:0 18px 38px -10px rgba(224,43,29,.6); }
.btn-primary:active { background:var(--brasa-600); transform:scale(.97); box-shadow:var(--shadow-sm); }
.btn-secondary { background:var(--oro-400); color:var(--carbon-950); }
.btn-secondary:hover { background:var(--oro-300); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn-secondary:active { background:var(--oro-500); transform:scale(.97); }
.btn-ghost { background:transparent; color:var(--brasa-300); box-shadow:inset 0 0 0 1.5px var(--brasa-700); }
.btn-ghost:hover { box-shadow:inset 0 0 0 1.5px var(--brasa-500); background:rgba(224,43,29,.12); color:var(--brasa-200); }
.btn-dark { background:var(--surface-2); color:var(--fg); box-shadow:inset 0 0 0 1px var(--border); }
.btn-dark:hover { background:var(--carbon-800); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn-light { background:rgba(255,255,255,.1); color:#fff; box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.45); backdrop-filter:blur(4px); }
.btn-light:hover { background:rgba(255,255,255,.2); transform:translateY(-1px); }
.btn-lg { padding:16px 30px; font-size:16.5px; }
.btn-sm { padding:10px 18px; font-size:14px; }
.btn-block { width:100%; }
.btn .arrow { transition:transform var(--dur) var(--ease); }
.btn:hover .arrow { transform:translateX(3px); }

/* ============================================================
   CHIPS
   ============================================================ */
.chip {
  display:inline-flex; align-items:center; gap:6px; font-weight:700; font-size:13px;
  border-radius:var(--radius-pill); padding:7px 13px;
}
.chip i,.chip svg { width:14px; height:14px; }
.chip .dot { width:8px; height:8px; border-radius:50%; }
.chip-open { background:var(--open-bg); color:var(--open); box-shadow:inset 0 0 0 1px rgba(95,194,126,.3); }
.chip-open .dot { background:var(--open); box-shadow:0 0 8px var(--open); }
.chip-closed { background:rgba(224,43,29,.14); color:var(--brasa-300); box-shadow:inset 0 0 0 1px rgba(224,43,29,.3); }
.chip-closed .dot { background:var(--brasa-400); }
.chip-oro { background:var(--oro-400); color:var(--carbon-950); }
.chip-outline { background:transparent; color:var(--fg-2); box-shadow:inset 0 0 0 1.5px var(--border-strong); }

/* ============================================================
   TARJETAS
   ============================================================ */
.card {
  background:var(--surface); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm);
  border:1px solid var(--border); overflow:hidden;
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur);
}
.card-hover:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--border-strong); }
.card-img { overflow:hidden; position:relative; background:var(--carbon-900); }
.card-img img { width:100%; height:100%; object-fit:cover; transition:transform var(--dur-slow) var(--ease); }
.card-hover:hover .card-img img { transform:scale(1.05); }

/* ============================================================
   HEADER
   ============================================================ */
.header {
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background var(--dur) var(--ease), border-color var(--dur), backdrop-filter var(--dur);
  border-bottom:1px solid transparent;
}
.header.scrolled {
  background:rgba(13,11,9,.82);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.header-inner {
  height:var(--header-h); display:flex; align-items:center; gap:18px; padding:0 var(--gutter);
  max-width:var(--max-w); margin:0 auto;
}
.brand { display:flex; align-items:center; }
.brand img { height:46px; width:auto; }

.nav { display:none; gap:4px; margin-left:14px; }
.nav a {
  padding:9px 14px; border-radius:var(--radius-pill); font-weight:600; font-size:15px;
  color:rgba(244,236,221,.82); transition:background var(--dur), color var(--dur);
  text-shadow:0 1px 10px rgba(0,0,0,.4);
}
.nav a:hover { background:rgba(255,255,255,.1); color:#fff; }
.header.scrolled .nav a { text-shadow:none; }
@media (min-width:1000px){ .nav { display:flex; } }

.header-actions { margin-left:auto; display:flex; align-items:center; gap:10px; }
.header-cta { display:none; }
@media (min-width:1000px){ .header-cta { display:inline-flex; } }

.hamburger {
  width:44px; height:44px; display:grid; place-items:center; border-radius:12px;
  background:rgba(255,255,255,.1); color:#fff; transition:background var(--dur);
}
.header.scrolled .hamburger { background:var(--surface-2); }
.hamburger i,.hamburger svg { width:22px; height:22px; }
@media (min-width:1000px){ .hamburger { display:none; } }

/* Menú móvil */
.mobile-menu {
  position:fixed; inset:0; z-index:90; background:var(--bg);
  display:flex; flex-direction:column; justify-content:center; align-items:flex-start;
  padding:0 var(--gutter); gap:10px; opacity:0; visibility:hidden;
  transition:opacity var(--dur-slow) var(--ease), visibility var(--dur-slow);
}
.mobile-menu.open { opacity:1; visibility:visible; }
.mobile-menu .label {
  position:absolute; top:calc(var(--header-h) + 8px); left:var(--gutter);
  font-weight:800; font-size:13px; letter-spacing:var(--tracking-caps);
  text-transform:uppercase; color:var(--brasa-400);
}
.mobile-menu a {
  font-family:var(--font-display); font-size:clamp(2.2rem,9vw,3.4rem); font-weight:800;
  letter-spacing:-0.02em; color:var(--fg);
  transform:translateY(16px); opacity:0;
  transition:opacity var(--dur-slow) var(--ease), transform var(--dur-slow) var(--ease), color var(--dur);
}
.mobile-menu a em { font-size:.45em; color:var(--fg-3); font-weight:600; }
.mobile-menu.open a { opacity:1; transform:translateY(0); transition-delay:calc(var(--i,0) * 60ms + 80ms); }
.mobile-menu a:hover { color:var(--brasa-400); }

/* ============================================================
   HERO — sólo vídeo (sin texto encima)
   ============================================================ */
.hero { position:relative; min-height:100svh; overflow:hidden; background:#000; }
.hero-video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.hero-gradient {
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(8,7,6,.55) 0%, rgba(8,7,6,.1) 16%, rgba(8,7,6,0) 55%,
    rgba(8,7,6,.35) 82%, var(--bg) 100%);
}
.hero-sound {
  position:absolute; bottom:28px; right:var(--gutter); z-index:3;
  width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  background:rgba(8,7,6,.45); color:#fff; border:1px solid rgba(255,255,255,.25);
  transition:background var(--dur), border-color var(--dur), transform var(--dur);
}
.hero-sound:hover { background:var(--brasa-500); border-color:var(--brasa-500); transform:scale(1.06); }
.hero-sound i,.hero-sound svg { width:18px; height:18px; }

/* Marquesina de ciudades */
.marquee { background:var(--carbon-950); border-top:1px solid var(--border); border-bottom:1px solid var(--border); overflow:hidden; }
.marquee-inner {
  display:flex; align-items:center; gap:26px; height:56px; flex-wrap:wrap; justify-content:center;
  max-width:var(--max-w); margin:0 auto; padding:0 var(--gutter);
}
.marquee-inner span { font-weight:700; font-size:14px; letter-spacing:.04em; color:var(--fg-2); text-transform:uppercase; }
.marquee-inner .sep { color:var(--brasa-400); }

/* ============================================================
   NOSOTROS
   ============================================================ */
.about-grid { display:grid; grid-template-columns:1fr; gap:40px; }
@media (min-width:900px){ .about-grid { grid-template-columns:minmax(0,5fr) minmax(0,6fr); gap:72px; align-items:center; } }
.about-headline { font-size:clamp(2.4rem,5vw,3.6rem); line-height:1.04; letter-spacing:-0.02em; margin-bottom:28px; }
.about-headline em { font-style:normal; color:var(--brasa-400); }
.about-body { display:flex; flex-direction:column; gap:1.1em; max-width:54ch; }
.about-body p:first-of-type { font-size:1.18rem; color:var(--fg); line-height:1.55; }
.about-body p { font-size:1.05rem; line-height:1.7; }

.fact-row {
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
  margin-top:64px; padding-top:40px; border-top:1px solid var(--border);
}
@media (max-width:640px){ .fact-row { grid-template-columns:1fr; gap:32px; } }
.fact-num { font-family:var(--font-display); font-weight:800; font-size:clamp(2.6rem,4.5vw,3.8rem); line-height:1; letter-spacing:-0.02em; color:var(--fg); }
.fact-num em { font-style:normal; color:var(--brasa-400); }
.fact-text { font-size:.95rem; color:var(--fg-3); max-width:26ch; margin-top:10px; line-height:1.45; }

/* ============================================================
   ENCABEZADOS DE SECCIÓN
   ============================================================ */
.section-head { margin-bottom:48px; }
.section-head.center { text-align:center; }
.section-head .eyebrow { margin-bottom:14px; }
.section-head h2 { margin-bottom:14px; }
.section-head h2 em { font-style:normal; color:var(--brasa-400); }
.section-head .lead { max-width:54ch; }
.section-head.center .lead { margin-inline:auto; }

/* ============================================================
   LOCALES
   ============================================================ */
.filters {
  display:inline-flex; flex-wrap:wrap; gap:6px; background:var(--surface);
  padding:6px; border-radius:var(--radius-pill); margin-bottom:40px; border:1px solid var(--border);
}
.filter {
  border:0; background:transparent; color:var(--fg-2); font-weight:700; font-size:14px;
  padding:9px 18px; border-radius:var(--radius-pill); transition:all var(--dur) var(--ease);
}
.filter:hover { color:var(--fg); }
.filter.active { background:var(--brasa-500); color:#fff; box-shadow:var(--shadow-brasa); }

.locales-grid { display:grid; grid-template-columns:1fr; gap:24px; }
@media (min-width:640px){ .locales-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:1000px){ .locales-grid { grid-template-columns:repeat(3,1fr); } }

.local { display:flex; flex-direction:column; }
.local .card-img { aspect-ratio:16/10; }
.local .card-img .chip { position:absolute; top:12px; left:12px; box-shadow:var(--shadow-sm); backdrop-filter:blur(6px); }
.local-body { padding:16px 18px 18px; display:flex; flex-direction:column; flex:1; }
.local-top { display:flex; align-items:baseline; gap:8px; flex-wrap:wrap; }
.local-name { font-family:var(--font-display); font-weight:700; font-size:20px; color:var(--fg); letter-spacing:-0.01em; }
.local-prov { font-size:13px; color:var(--fg-3); font-weight:600; }
.local-line { display:flex; align-items:center; gap:8px; margin-top:9px; color:var(--fg-2); font-size:14px; line-height:1.35; }
.local-line i,.local-line svg { width:15px; height:15px; color:var(--brasa-400); flex:none; }
.local-line.phone a { font-weight:700; color:var(--brasa-300); }
.local-actions { display:flex; gap:8px; margin-top:16px; }
.local-actions .btn { flex:1; padding:11px 12px; font-size:14px; }
.local-extra { margin-top:10px; display:flex; gap:14px; }
.local-extra a { font-size:13px; color:var(--fg-3); font-weight:600; transition:color var(--dur); }
.local-extra a:hover { color:var(--brasa-300); }

/* ============================================================
   MAPA (Leaflet oscuro)
   ============================================================ */
.map-section { margin-top:72px; }
.map-frame { margin-top:28px; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-md); border:1px solid var(--border); }
#map { height:clamp(400px,55vh,560px); width:100%; background:var(--carbon-950); }
.leaflet-marker-icon-custom {
  background:var(--brasa-500); width:26px !important; height:26px !important; border-radius:50% 50% 50% 0;
  transform:rotate(-45deg); margin-left:-13px !important; margin-top:-26px !important;
  border:3px solid var(--bg); box-shadow:0 0 0 1px var(--brasa-500), 0 6px 16px rgba(0,0,0,.6);
}
.leaflet-container { background:var(--carbon-950) !important; font-family:var(--font-text) !important; }
.leaflet-popup-content-wrapper { background:var(--surface) !important; color:var(--fg) !important; border:1px solid var(--border); border-radius:var(--radius-md) !important; box-shadow:var(--shadow-lg) !important; }
.leaflet-popup-tip { background:var(--surface) !important; box-shadow:none !important; }
.leaflet-popup-content { margin:14px 16px !important; font-family:var(--font-text) !important; font-size:.88rem !important; line-height:1.5; }
.leaflet-popup-content strong { font-family:var(--font-display); font-weight:700; color:var(--fg); font-size:1.08em; }
.leaflet-popup-close-button { color:var(--fg-3) !important; }
.leaflet-control-zoom a { background:var(--surface) !important; color:var(--fg) !important; border:1px solid var(--border) !important; }
.leaflet-control-zoom a:hover { background:var(--brasa-500) !important; color:#fff !important; }
.leaflet-bar { border-radius:10px !important; box-shadow:var(--shadow-sm) !important; border:1px solid var(--border) !important; overflow:hidden; }
.leaflet-control-attribution { background:rgba(13,11,9,.8) !important; color:var(--fg-3) !important; }
.leaflet-control-attribution a { color:var(--fg-2) !important; }
/* Etiquetas de ciudad propias (en español) sobre cada marcador */
.leaflet-tooltip.map-label {
  background:transparent; border:0; box-shadow:none; padding:0;
  color:#fff; font-family:var(--font-text); font-weight:700; font-size:12.5px;
  letter-spacing:.01em; white-space:nowrap;
  text-shadow:0 1px 4px rgba(0,0,0,.95), 0 0 3px rgba(0,0,0,.8);
}
.leaflet-tooltip.map-label::before { display:none; }

/* ============================================================
   CARTA
   ============================================================ */
.carta-intro { display:grid; grid-template-columns:1fr; gap:40px; margin-bottom:72px; align-items:center; }
@media (min-width:900px){ .carta-intro { grid-template-columns:1.1fr 1fr; gap:64px; } }
.carta-headline { font-size:clamp(2.2rem,5vw,3.4rem); line-height:1.05; letter-spacing:-0.02em; margin-bottom:20px; }
.carta-headline em { font-style:normal; color:var(--brasa-400); }
.carta-intro-text { max-width:46ch; font-size:1.05rem; color:var(--fg-2); line-height:1.65; }
.carta-intro-image { aspect-ratio:5/4; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--border); background:var(--carbon-900); }
.carta-intro-image img { width:100%; height:100%; object-fit:cover; }

.cat-block { margin-bottom:72px; }
.cat-block:last-child { margin-bottom:0; }
.cat-head { display:flex; align-items:baseline; gap:16px; margin-bottom:32px; padding-bottom:16px; border-bottom:1px solid var(--border-strong); }
.cat-name { font-family:var(--font-display); font-weight:700; font-size:clamp(1.5rem,3vw,2.1rem); letter-spacing:-0.01em; color:var(--fg); }
.cat-name em { font-style:normal; color:var(--brasa-400); }
.cat-desc { margin-left:auto; font-size:.92rem; color:var(--fg-3); max-width:34ch; text-align:right; }
@media (max-width:680px){ .cat-head { flex-wrap:wrap; } .cat-desc { margin-left:0; text-align:left; width:100%; } }

.dishes { display:grid; gap:24px; grid-template-columns:1fr; }
@media (min-width:600px){ .dishes { grid-template-columns:repeat(2,1fr); } }
@media (min-width:1000px){ .dishes { grid-template-columns:repeat(3,1fr); } }

.dish { display:flex; flex-direction:column; height:100%; }
.dish .card-img { aspect-ratio:1/1; }
.dish-body { padding:15px 17px 18px; display:flex; flex-direction:column; flex:1; }
.dish-name { font-family:var(--font-display); font-weight:700; font-size:19.5px; color:var(--fg); letter-spacing:-0.01em; }
.dish-desc { font-size:13.5px; color:var(--fg-3); margin-top:7px; line-height:1.5; }

.dish.hero-dish { grid-column:1 / -1; display:grid; grid-template-columns:1fr; height:auto; }
@media (min-width:760px){ .dish.hero-dish { grid-template-columns:1.15fr 1fr; align-items:center; } }
.dish.hero-dish .card-img { aspect-ratio:5/4; height:100%; }
.dish.hero-dish .dish-body { padding:clamp(24px,4vw,40px); }
.dish.hero-dish .dish-name { font-size:clamp(1.8rem,3.5vw,2.6rem); }
.dish.hero-dish .dish-desc { font-size:1.02rem; max-width:42ch; margin-top:12px; }
.dish.hero-dish .chip { align-self:flex-start; margin-bottom:14px; }

/* ============================================================
   HORARIO
   ============================================================ */
.schedule-intro { display:grid; grid-template-columns:1fr; gap:32px; margin-bottom:48px; align-items:end; }
@media (min-width:820px){ .schedule-intro { grid-template-columns:1.2fr 1fr; gap:48px; } }
.schedule-intro h2 em { font-style:normal; color:var(--brasa-400); }
.schedule-note {
  font-family:var(--font-display); font-style:italic; font-weight:500; font-size:1.2rem;
  color:var(--fg-2); line-height:1.5; max-width:42ch;
}
.schedule-note::before, .schedule-note::after { content:'“'; color:var(--brasa-400); font-size:1.2em; vertical-align:-0.15em; }
.schedule-note::after { content:'”'; }

.schedule-list { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); padding:14px clamp(18px,3vw,28px); }
.schedule-row {
  display:grid; grid-template-columns:1fr; gap:4px 24px; padding:18px 0;
  border-bottom:1px solid var(--border); position:relative;
}
.schedule-row:last-child { border-bottom:0; }
@media (min-width:560px){ .schedule-row { grid-template-columns:1.3fr 1fr 1fr auto; align-items:center; } }
.schedule-place { font-family:var(--font-display); font-weight:700; font-size:1.12rem; color:var(--fg); letter-spacing:-0.01em; }
.schedule-place small { font-family:var(--font-text); font-size:.78rem; color:var(--fg-3); font-weight:600; margin-left:5px; }
.schedule-slot { font-size:.92rem; color:var(--fg-2); font-variant-numeric:tabular-nums; }
.schedule-slot .lbl { display:block; font-size:.68rem; color:var(--fg-3); text-transform:uppercase; letter-spacing:.08em; margin-bottom:3px; font-weight:700; }
.schedule-slot.empty { color:var(--carbon-600); }
.schedule-now {
  justify-self:start; display:inline-flex; align-items:center; gap:6px;
  background:var(--open-bg); color:var(--open); font-weight:700; font-size:12.5px;
  padding:5px 11px; border-radius:var(--radius-pill); box-shadow:inset 0 0 0 1px rgba(95,194,126,.3);
}
.schedule-now::before { content:''; width:7px; height:7px; border-radius:50%; background:var(--open); box-shadow:0 0 8px var(--open); }
@media (min-width:560px){ .schedule-now { justify-self:end; } }

/* ============================================================
   GALERÍA
   ============================================================ */
.gallery { display:grid; grid-template-columns:repeat(12,1fr); gap:16px; grid-auto-rows:180px; }
.gallery a { border-radius:var(--radius-lg); overflow:hidden; background:var(--carbon-900); position:relative; border:1px solid var(--border); }
.gallery a img { width:100%; height:100%; object-fit:cover; transition:transform var(--dur-slow) var(--ease); }
.gallery a:hover img { transform:scale(1.05); }
.gallery .g1 { grid-column:span 7; grid-row:span 2; }
.gallery .g2 { grid-column:span 5; }
.gallery .g3 { grid-column:span 5; }
.gallery .g4 { grid-column:span 6; }
.gallery .g5 { grid-column:span 6; }
.gallery .g6 { grid-column:span 6; }
.gallery .g7 { grid-column:span 6; }
@media (max-width:760px){
  .gallery { grid-template-columns:repeat(6,1fr); grid-auto-rows:130px; gap:12px; }
  .gallery .g1 { grid-column:span 6; grid-row:span 2; }
  .gallery .g2,.gallery .g3 { grid-column:span 3; }
  .gallery .g4,.gallery .g5,.gallery .g6,.gallery .g7 { grid-column:span 3; }
}

/* ============================================================
   TRABAJA — banda oscura
   ============================================================ */
.join-band {
  position:relative; overflow:hidden; border-radius:var(--radius-xl);
  background:
    radial-gradient(90% 120% at 100% 0%, rgba(224,43,29,.16), transparent 55%),
    var(--surface);
  border:1px solid var(--border);
  color:var(--fg); padding:clamp(36px,5vw,60px);
  display:flex; align-items:center; gap:36px; flex-wrap:wrap;
}
.join-copy { flex:1 1 360px; position:relative; }
.join-copy h2 { color:var(--fg); font-size:clamp(1.8rem,4vw,2.6rem); line-height:1.08; letter-spacing:-0.02em; margin-top:14px; }
.join-copy p { color:var(--fg-2); margin-top:12px; font-size:1.05rem; line-height:1.6; max-width:46ch; }
.join-cta { position:relative; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background:#080706; border-top:1px solid var(--border); color:var(--fg-2); padding:64px 0 32px; }
.footer-grid { display:grid; grid-template-columns:1fr; gap:40px; padding-bottom:44px; }
@media (min-width:760px){ .footer-grid { grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; } }
.footer-brand img { height:56px; width:auto; }
.footer-brand p { margin-top:18px; font-size:14.5px; line-height:1.6; max-width:320px; color:var(--fg-3); }
.footer-brand .btn { margin-top:20px; }
.footer h4 { color:var(--fg); font-family:var(--font-text); font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; margin-bottom:16px; }
.footer ul li { margin-bottom:11px; }
.footer ul a { font-size:14.5px; color:var(--fg-3); transition:color var(--dur); }
.footer ul a:hover { color:var(--fg); }
.footer ul a.oro { color:var(--oro-400); font-weight:700; }
.footer-bottom {
  border-top:1px solid var(--border); padding-top:24px;
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-size:13px; color:var(--fg-3);
}
.footer-bottom a:hover { color:var(--fg-2); }

/* ============================================================
   COOKIES
   ============================================================ */
.cookies {
  position:fixed; bottom:20px; left:20px; z-index:200; max-width:360px;
  padding:22px 24px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); display:flex; flex-direction:column; gap:14px;
  transform:translateY(160%); transition:transform var(--dur-slow) var(--ease);
}
.cookies.show { transform:translateY(0); }
.cookies .eyebrow { font-size:12px; }
.cookies p { font-size:.88rem; line-height:1.5; color:var(--fg-2); }

/* ============================================================
   REVEAL
   ============================================================ */
[data-reveal] { opacity:0; transform:translateY(24px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal].in { opacity:1; transform:translateY(0); }
[data-reveal-delay="100"].in { transition-delay:100ms; }
[data-reveal-delay="200"].in { transition-delay:200ms; }
[data-reveal-delay="300"].in { transition-delay:300ms; }

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after { animation-duration:.001s !important; transition-duration:.001s !important; }
  html { scroll-behavior:auto; }
  [data-reveal] { opacity:1; transform:none; }
}
