/* =========================================================
   LA HISTÓRICA — Cantina de Autor
   Estilo: periódico / newsprint vintage
   ========================================================= */

/* ---------- Tipografías propias (Envato) ---------- */
@font-face{font-family:'Lenia Sans';src:url('../assets/fonts/LeniaSans-Regular.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Lenia Sans';src:url('../assets/fonts/LeniaSans-Italic.ttf') format('truetype');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Lenia Sans';src:url('../assets/fonts/LeniaSans-Medium.ttf') format('truetype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Lenia Sans';src:url('../assets/fonts/LeniaSans-SemiBold.ttf') format('truetype');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Lenia Sans';src:url('../assets/fonts/LeniaSans-Bold.ttf') format('truetype');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Lenia Sans';src:url('../assets/fonts/LeniaSans-Black.ttf') format('truetype');font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:'Abigaila';src:url('../assets/fonts/AbigailaSignature.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Mairo';src:url('../assets/fonts/Mairo.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap}

/* helpers tipográficos */
.f-lenia{font-family:'Lenia Sans',sans-serif}
.script-abi{font-family:'Abigaila',cursive}
.script-mairo{font-family:'Mairo',cursive}
/* palabra/realce importante dentro de un párrafo normal */
.accent{font-family:'Mairo',cursive;color:var(--oxblood);font-size:1.3em;line-height:.8;font-weight:400;margin:0 .08em;display:inline-block}
.accent-abi{font-family:'Abigaila',cursive;color:var(--oxblood);font-size:1.5em;line-height:.8}
/* antetítulo manuscrito sobre un titular */
.script-eyebrow{font-family:'Abigaila',cursive;color:var(--gold-dk);font-size:2.2rem;line-height:.9;display:block;margin-bottom:-2px}
/* sobre fondos oscuros, cursivas en oro claro */
.feature .script-eyebrow,.qr-band .script-eyebrow,.menu-hero .script-eyebrow,.hero-caption .script-eyebrow,.feature .accent,.qr-band .accent,.menu-hero .accent,.hero-caption .accent{color:var(--gold)}
/* efecto "escritura": barrido de izquierda a derecha al entrar en pantalla (lo activa main.js con .scribe) */
.accent.scribe,.accent-abi.scribe{display:inline-block}
.scribe{
  clip-path:inset(-35% 100% -35% -20%);-webkit-clip-path:inset(-35% 100% -35% -20%);
  transition:clip-path 1.05s cubic-bezier(.66,0,.34,1) .15s,-webkit-clip-path 1.05s cubic-bezier(.66,0,.34,1) .15s;
}
.scribe.scribe-in{clip-path:inset(-35% -20% -35% -20%);-webkit-clip-path:inset(-35% -20% -35% -20%)}
@media (prefers-reduced-motion: reduce){.scribe,.scribe.scribe-in{clip-path:none;-webkit-clip-path:none;transition:none}}

:root{
  --ink:#1b1815;          /* tinta */
  --ink-soft:#403a33;
  --paper:#f4efe3;        /* papel periódico */
  --paper-2:#ece5d4;
  --paper-3:#e3dbc6;
  --oxblood:#7a1f1f;      /* acento cantina */
  --oxblood-dk:#5c1414;
  --gold:#b08a3e;
  --gold-dk:#8a6a28;
  --line:#cdbfa3;
  --shadow:0 18px 50px rgba(20,15,10,.18);
  --serif:'Playfair Display', Georgia, 'Times New Roman', serif;
  --cond:'Oswald', 'Arial Narrow', sans-serif;
  --body:'Lora', Georgia, serif;
  --maxw:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  /* textura sutil de papel */
  background-image:
    radial-gradient(rgba(120,100,70,.05) 1px, transparent 1px);
  background-size:4px 4px;
  color:var(--ink);
  font-family:var(--body);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}

h1,h2,h3{font-family:var(--serif);font-weight:800;line-height:1.05;margin:0}
.kicker{
  font-family:var(--cond);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.72rem;
  color:var(--oxblood);
  font-weight:600;
}
.rule{height:1px;background:var(--line);border:0;margin:0}
.rule-thick{height:3px;background:var(--ink);border:0}
.rule-double{border:0;border-top:3px double var(--ink);height:6px}

/* ===================== TOP BAR ===================== */
.topbar{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--cond);
  font-size:.74rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:38px;gap:14px}
.topbar a{color:var(--paper);opacity:.85}
.topbar a:hover{opacity:1;color:var(--gold)}
.topbar .tb-right{display:flex;gap:18px;align-items:center}

/* idioma */
.lang-switch{display:inline-flex;border:1px solid rgba(244,239,227,.35);border-radius:2px;overflow:hidden}
.lang-switch button,.lang-switch a{
  background:transparent;color:var(--paper);border:0;cursor:pointer;display:inline-block;text-decoration:none;
  font-family:var(--cond);letter-spacing:.12em;font-size:.72rem;padding:3px 9px;text-transform:uppercase;
}
.lang-switch button.active,.lang-switch a.active{background:var(--gold);color:var(--ink);font-weight:600}

/* ===================== MASTHEAD ===================== */
.masthead{padding:20px 0 10px;text-align:center;border-bottom:3px double var(--ink)}
.masthead .dateline{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--cond);text-transform:uppercase;letter-spacing:.16em;
  font-size:.7rem;color:var(--ink-soft);padding-bottom:10px;
}
.masthead .dateline span{flex:1}
.masthead .dateline .mid{text-align:center}
.masthead .dateline .right{text-align:right}
.masthead-logo{max-width:520px;width:78%;margin:6px auto 8px;mix-blend-mode:multiply}
.masthead .tagline{
  font-family:var(--cond);text-transform:uppercase;letter-spacing:.34em;
  font-size:.8rem;color:var(--oxblood);margin-top:2px;
}

/* ===================== NAV ===================== */
.nav{
  position:sticky;top:0;z-index:50;
  background:var(--paper);
  border-bottom:1px solid var(--line);
  box-shadow:0 2px 0 var(--ink), 0 10px 24px rgba(20,15,10,.06);
}
.nav .container{display:flex;align-items:center;justify-content:center;gap:30px;height:54px;position:relative}
.nav a.navlink{
  font-family:var(--cond);text-transform:uppercase;letter-spacing:.2em;
  font-size:.82rem;color:var(--ink);position:relative;padding:6px 2px;
}
.nav a.navlink::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--oxblood);transition:right .25s}
.nav a.navlink:hover::after,.nav a.navlink.active::after{right:0}
.nav .nav-mini-logo{position:absolute;left:22px;height:26px;opacity:0;transition:opacity .3s;mix-blend-mode:multiply}
.nav.shrunk .nav-mini-logo{opacity:1}
.nav .nav-cta-group{position:absolute;right:22px;display:flex;gap:10px;align-items:center}
.nav>.container>.nav-cta{position:absolute;right:22px}
.btn{
  display:inline-block;font-family:var(--cond);text-transform:uppercase;letter-spacing:.16em;
  font-size:.78rem;background:var(--oxblood);color:var(--paper);padding:9px 16px;border:1.5px solid transparent;cursor:pointer;
  border-radius:2px;transition:background .2s,transform .1s;
}
.btn:hover{background:var(--oxblood-dk)}
.btn:active{transform:translateY(1px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-dk);color:var(--paper)}

/* hamburguesa */
.nav-toggle{display:none;position:absolute;right:22px;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);display:block;transition:transform .3s ease, opacity .2s ease}
.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)}
.nav-cta-mobile,.nav-fact-mobile{display:none}
.nav-cta-mini{display:none}
.nav-close{display:none}
.nb{white-space:nowrap}

/* ===================== HERO ===================== */
.hero{position:relative;padding:38px 0 30px}
.hero-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:0;border:1px solid var(--ink)}
.hero-main{position:relative;min-height:520px;overflow:hidden;border-right:1px solid var(--ink)}
.hero-main img{width:100%;height:100%;object-fit:cover;object-position:50% 78%;position:absolute;inset:0;filter:saturate(1.02)}
.hero-main .overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(20,15,10,.1) 0%, rgba(20,15,10,.35) 45%, rgba(20,15,10,.72) 78%, rgba(20,15,10,.92) 100%);
}
.hero-caption{position:absolute;left:0;right:0;bottom:0;padding:34px 32px;color:var(--paper)}
.hero-caption .script-eyebrow{color:#e9c87a;text-shadow:0 2px 14px rgba(0,0,0,.75),0 1px 3px rgba(0,0,0,.9)}
.hero-caption .kicker{color:#e9c87a;text-shadow:0 1px 10px rgba(0,0,0,.85)}
.hero-caption h1{font-size:clamp(2.2rem,4.4vw,3.6rem);color:#fff;margin:8px 0 10px;text-shadow:0 2px 18px rgba(0,0,0,.4)}
.hero-caption p{max-width:40ch;color:#f0e9da;font-size:1.02rem}
.hero-side{display:flex;flex-direction:column}
.hero-side .side-box{padding:24px 22px;border-bottom:1px solid var(--ink)}
.hero-side .side-box:last-child{border-bottom:0}
.hero-side h3{font-size:1.35rem;margin-bottom:6px}
.hero-side .small{font-size:.92rem;color:var(--ink-soft)}
.hours-line{display:flex;justify-content:space-between;font-family:var(--cond);letter-spacing:.05em;font-size:.92rem;padding:3px 0;border-bottom:1px dotted var(--line)}
.hours-line:last-child{border-bottom:0}
.badge-live{display:inline-flex;align-items:center;gap:8px;font-family:var(--cond);text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;color:var(--oxblood);font-weight:600}
.badge-live .dot{width:9px;height:9px;border-radius:50%;background:var(--oxblood);box-shadow:0 0 0 0 rgba(122,31,31,.6);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(122,31,31,.55)}70%{box-shadow:0 0 0 12px rgba(122,31,31,0)}100%{box-shadow:0 0 0 0 rgba(122,31,31,0)}}

/* ===================== SECTION SHELL ===================== */
.section{padding:64px 0}
.section-head{text-align:center;margin-bottom:40px}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.8rem);margin:8px 0}
.section-head .lead{max-width:62ch;margin:10px auto 0;color:var(--ink-soft)}
.dingbat{font-family:var(--serif);color:var(--oxblood);font-size:1.4rem;letter-spacing:.5em;text-align:center;margin:0 0 4px}

/* ===================== HISTORIA / COLUMNAS ===================== */
.cols{column-count:2;column-gap:34px;column-rule:1px solid var(--line)}
.cols p{margin:0 0 14px;text-align:justify;hyphens:auto}
.cols p:first-child::first-letter{
  font-family:var(--serif);font-size:3.6rem;line-height:.8;float:left;
  padding:6px 10px 0 0;color:var(--oxblood);font-weight:800;
}
.historia-wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:36px;align-items:start}
.historia-fig figure{margin:0;border:1px solid var(--ink);background:#fff;padding:8px}
.historia-fig img{width:100%;height:360px;object-fit:cover}
.historia-fig figcaption{font-family:var(--cond);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--ink-soft);padding:8px 2px 2px;text-align:center}

/* ===================== CHEF ===================== */
.chef{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.chef-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:50px;align-items:center}
/* fotos estilo recorte de periódico (marco blanco + filete + pie) */
.chef-figs{display:grid;grid-template-columns:1.2fr .9fr;gap:18px;align-items:start}
.chef-figs figure{margin:0;border:1px solid var(--ink);background:#fff;padding:8px}
.chef-figs figure img,.chef-figs figure video{width:100%;object-fit:cover;display:block}
.chef-figs .main img{height:420px;filter:grayscale(1) contrast(1.04)}
.chef-figs .side{margin-top:36px}
.chef-figs .side img,.chef-figs .side video{height:300px}
.chef-figs figcaption{font-family:var(--cond);text-transform:uppercase;letter-spacing:.12em;font-size:.66rem;color:var(--ink-soft);text-align:center;padding:8px 2px 2px}
.chef-txt h2{color:var(--ink);font-size:clamp(2rem,3.6vw,2.9rem);margin:4px 0 4px}
.chef-role{font-family:var(--cond);text-transform:uppercase;letter-spacing:.24em;font-size:.82rem;color:var(--oxblood);margin-bottom:18px}
.chef-txt p{color:var(--ink-soft);max-width:52ch}
.chef-quote{border-left:3px solid var(--oxblood);padding:6px 0 6px 20px;margin:24px 0 0;font-family:var(--serif);font-style:italic;font-size:1.25rem;color:var(--ink)}
@media(max-width:980px){.chef-grid{grid-template-columns:1fr;gap:30px}.chef-figs{max-width:560px}.chef-figs .main img{height:360px}.chef-figs .side img,.chef-figs .side video{height:260px}}

/* ===================== GALERÍA / MOSAICO ===================== */
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:10px}
.mosaic figure{margin:0;position:relative;overflow:hidden;border:1px solid var(--ink)}
.mosaic img,.mosaic video{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.mosaic figure:hover img,.mosaic figure:hover video{transform:scale(1.06)}
.mosaic .wide{grid-column:span 2}
.mosaic .tall{grid-row:span 2}
.mosaic figure figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:10px 12px;color:#fff;
  background:linear-gradient(transparent,rgba(20,15,10,.75));
  font-family:var(--cond);text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;
  opacity:0;transform:translateY(8px);transition:.3s;
}
.mosaic figure:hover figcaption{opacity:1;transform:none}

/* ===================== VIERNES SALSA (video de fondo) ===================== */
.feature{position:relative;overflow:hidden;background:var(--ink);color:var(--paper)}
.feature-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.feature-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(18,13,9,.94) 0%,rgba(18,13,9,.78) 38%,rgba(18,13,9,.36) 70%,rgba(18,13,9,.62) 100%)}
.feature .container{position:relative;z-index:2;padding-top:64px;padding-bottom:64px}
.feature-grid{display:grid;grid-template-columns:1fr;gap:0}
.feature-txt{padding:6px 0;max-width:560px}
.feature-txt .kicker{color:var(--gold)}
.feature-txt h2{color:#fff;font-size:clamp(2rem,3.8vw,3rem);margin:10px 0 14px}
.feature-txt p{color:#ece3d2;max-width:42ch}
.feature-stamp{
  display:inline-flex;align-items:center;gap:9px;border:1px solid var(--gold);color:var(--gold);
  font-family:var(--cond);text-transform:uppercase;letter-spacing:.22em;font-size:.74rem;font-weight:500;
  padding:7px 16px;margin-bottom:18px;border-radius:2px;
}
.feature-stamp::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold)}

/* marquesina infinita arriba/abajo */
.marquee{position:relative;z-index:3;overflow:hidden;background:var(--ink);border-block:2px solid var(--oxblood);user-select:none}
.marquee-track{display:flex;width:max-content;animation:mq-left 26s linear infinite}
.marquee.marquee-bottom .marquee-track{animation-name:mq-right}
.marquee-item{flex:0 0 auto;display:inline-flex;align-items:center;gap:16px;color:var(--paper);
  font-family:var(--cond);text-transform:uppercase;letter-spacing:.3em;font-size:.86rem;font-weight:500;padding:12px 16px}
.mq-star{color:var(--gold);font-size:.85em;line-height:1}
@keyframes mq-left{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes mq-right{from{transform:translateX(-50%)}to{transform:translateX(0)}}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* ===================== PREMIO / RECONOCIMIENTO ===================== */
.award{background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.award-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:46px;align-items:center}
.award-photo{margin:0;position:relative}
.award-photo img{width:100%;height:520px;object-fit:cover;border:1px solid var(--ink);box-shadow:var(--shadow)}
.award-seal-img{position:absolute;top:-60px;right:-70px;width:188px;height:188px;display:block;pointer-events:none}
.award-seal-img img{width:100%;height:100%;object-fit:contain;border:0;box-shadow:none;filter:drop-shadow(0 6px 12px rgba(20,15,10,.28))}
.award-txt .kicker{margin-top:4px}
.award-txt h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin:6px 0 16px}
.award-txt p{color:var(--ink-soft);max-width:48ch}
.award-stars{color:var(--gold);letter-spacing:4px;font-size:1.2rem;margin-bottom:8px}
@media(max-width:980px){.award-grid{grid-template-columns:1fr;gap:34px}.award-photo img{height:380px}.award-seal-img{width:140px;height:140px;top:-44px;right:-12px}}

/* ===================== OPINIONES ===================== */
.reviews{background:var(--paper-2)}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review-card{background:var(--paper);border:1px solid var(--ink);padding:26px 24px;position:relative}
.review-card .stars{color:var(--gold);letter-spacing:3px;font-size:1.05rem}
.review-card blockquote{margin:14px 0;font-family:var(--serif);font-style:italic;font-size:1.12rem;line-height:1.45}
.review-card .who{font-family:var(--cond);text-transform:uppercase;letter-spacing:.14em;font-size:.76rem;color:var(--ink-soft)}
.review-card .quote-mark{position:absolute;top:6px;right:16px;font-family:var(--serif);font-size:3.4rem;color:var(--line)}
/* rotación aleatoria de opiniones */
.review-card{transition:opacity .5s ease, transform .5s ease}
.review-card.rv-hidden{opacity:0;transform:translateY(12px)}
.rating-summary{text-align:center;margin-bottom:34px}
.rating-summary .big{font-family:var(--serif);font-size:3.4rem;font-weight:800;line-height:1}
.rating-summary .stars{color:var(--gold);font-size:1.4rem;letter-spacing:4px}

/* ===================== VISITA / CONTACTO ===================== */
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--ink)}
.visit-info{padding:44px 40px}
.visit-info .info-row{display:flex;gap:14px;padding:16px 0;border-bottom:1px dotted var(--line)}
.visit-info .info-row:last-child{border-bottom:0}
.visit-info .info-row .ico{color:var(--oxblood);width:26px;display:flex;justify-content:center;padding-top:2px}
.visit-info .info-row .ico svg{width:21px;height:21px}
.visit-info .info-row b{font-family:var(--cond);text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:var(--ink-soft);display:block;margin-bottom:2px}
.visit-map{min-height:440px;border-left:1px solid var(--ink)}
.visit-map iframe{width:100%;height:100%;min-height:440px;border:0;filter:grayscale(.3) sepia(.12)}

/* ===================== QR ===================== */
.qr-band{background:var(--oxblood);color:var(--paper);text-align:center;padding:40px 0}
.qr-band h2{color:#fff;font-size:1.8rem}
.qr-band p{color:#f1ddd6;max-width:50ch;margin:8px auto 18px}

/* ===================== FOOTER (estilo periódico) ===================== */
.footer{background:var(--paper-2);color:var(--ink);padding:34px 0 18px;border-top:3px double var(--ink)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1.2fr;gap:30px;align-items:start}
.footer img.f-logo{width:170px;filter:none;mix-blend-mode:multiply;margin-bottom:10px}
.footer .f-brand p{color:var(--ink-soft);max-width:36ch;font-size:.86rem;line-height:1.5}
.footer h4{font-family:var(--cond);text-transform:uppercase;letter-spacing:.2em;font-size:.74rem;color:var(--oxblood);margin:0 0 10px;padding-bottom:6px;border-bottom:1px solid var(--line)}
.footer a{color:var(--ink-soft);display:block;padding:3px 0;font-size:.88rem}
.footer a:hover{color:var(--oxblood)}
.footer address{font-style:normal;color:var(--ink-soft);font-size:.88rem;line-height:1.55}
.footer address a{display:inline;padding:0}
.footer .socials{display:flex;gap:10px;margin-top:12px}
.footer .socials a{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border:1px solid var(--ink);border-radius:50%;color:var(--ink);padding:0}
.footer .socials a svg{width:17px;height:17px}
.footer .socials a:hover{background:var(--oxblood);color:var(--paper);border-color:var(--oxblood)}
.footer-bottom{border-top:1px solid var(--line);margin-top:26px;padding-top:16px;display:flex;justify-content:space-between;font-family:var(--cond);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);flex-wrap:wrap;gap:8px}
.footer-bottom a{display:inline;color:var(--ink-soft)}
.footer-bottom a:hover{color:var(--oxblood)}
.footer-dev{flex-basis:100%;text-align:right}
.footer-dev .accent{text-transform:none;letter-spacing:0;font-size:1.7em;color:var(--oxblood);vertical-align:-2px}

/* ===================== MENÚ (página) ===================== */
.menu-hero{background:var(--ink);color:var(--paper);text-align:center;padding:56px 0 40px;border-bottom:3px double var(--gold)}
.menu-hero h1{color:#fff;font-size:clamp(2.2rem,5vw,3.4rem)}
.menu-hero .kicker{color:var(--gold)}
.menu-tabs{position:sticky;top:54px;z-index:40;background:var(--paper);border-bottom:1px solid var(--ink);box-shadow:0 6px 16px rgba(20,15,10,.06)}
.menu-tabs .container{display:flex;justify-content:center;gap:0}
.menu-tab{
  flex:0 0 auto;background:transparent;border:0;cursor:pointer;
  font-family:var(--cond);text-transform:uppercase;letter-spacing:.2em;font-size:.92rem;
  padding:18px 30px;color:var(--ink-soft);border-bottom:3px solid transparent;position:relative;
}
.menu-tab .sub{display:block;font-size:.62rem;letter-spacing:.18em;color:var(--gold);margin-top:3px}
.menu-tab.active{color:var(--ink);border-bottom-color:var(--oxblood)}
.menu-tab:hover{color:var(--ink)}

.menu-panel{display:none;padding:50px 0 70px}
.menu-panel.active{display:block;animation:fade .4s}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.menu-cat{margin-bottom:46px}
.menu-cat-head{display:flex;align-items:center;gap:14px;margin-bottom:10px;flex-wrap:wrap}
.menu-cat-head h3{font-size:1.7rem;white-space:nowrap}
.menu-cat-head .line{flex:1 1 30px;height:1px;background:var(--line);min-width:24px}
.menu-cat-head .ct-note{font-family:var(--cond);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap}
.menu-items{display:grid;grid-template-columns:1fr 1fr;gap:4px 56px}
.menu-item{padding:12px 0;border-bottom:1px dotted var(--line)}
.menu-item .mi-row{display:flex;align-items:baseline;gap:10px}
.menu-item .mi-name{flex:0 1 auto;min-width:0;font-family:var(--serif);font-weight:700;font-size:1.08rem;line-height:1.3}
.menu-item .mi-name .tag{display:inline-block;white-space:nowrap;font-family:var(--cond);font-size:.56rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--oxblood);border:1px solid var(--oxblood);padding:2px 6px;margin-left:8px;border-radius:2px;line-height:1;vertical-align:middle;position:relative;top:-2px}
.menu-item .mi-desc{font-size:.9rem;color:var(--ink-soft);line-height:1.45;margin-top:4px;max-width:46ch}
.menu-item .mi-dots{flex:1 1 auto;min-width:16px;align-self:baseline;border-bottom:1px dotted var(--line);transform:translateY(-4px)}
.menu-item .mi-price{flex:0 0 auto;font-family:var(--cond);font-weight:600;font-size:1.05rem;color:var(--oxblood);white-space:nowrap}
.menu-note{background:var(--paper-2);border:1px solid var(--line);padding:14px 18px;font-size:.86rem;color:var(--ink-soft);text-align:center;margin-top:30px}

/* ===================== PÁGINAS SIMPLES (aviso / 404) ===================== */
.page{padding:60px 0 80px;min-height:50vh}
.page h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:6px}
.page h2{font-family:var(--serif);font-size:1.4rem;margin:30px 0 10px}
.page p,.page li{color:var(--ink-soft);margin:0 0 12px}
.page ul{padding-left:20px}
.legal-meta{font-family:var(--cond);text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:var(--ink-soft);margin-bottom:30px}
.notfound{text-align:center;padding:90px 0}
.notfound .code{font-family:var(--serif);font-size:9rem;font-weight:800;line-height:.9;color:var(--oxblood)}
.notfound .code small{display:block;font-family:var(--cond);font-size:1rem;letter-spacing:.4em;color:var(--ink);text-transform:uppercase;margin-top:10px}

/* ===================== i18n helpers ===================== */
[data-lang-en]{display:none}
body.en [data-lang-es]{display:none}
body.en [data-lang-en]{display:initial}
/* mantener grid/flex al cambiar idioma */
body.en p[data-lang-en],body.en span[data-lang-en],body.en h1[data-lang-en],
body.en h2[data-lang-en],body.en h3[data-lang-en]{display:revert}

/* ===================== REVEAL ===================== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ===================== RESPONSIVE ===================== */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-main{border-right:0;border-bottom:1px solid var(--ink)}
  .historia-wrap{grid-template-columns:1fr}
  .feature-grid{grid-template-columns:1fr}
  .feature-txt{padding:50px 0 30px}
  .feature-img{margin:0 -22px;min-height:300px}
  .review-grid{grid-template-columns:1fr}
  .visit-grid{grid-template-columns:1fr}
  .visit-map{border-left:0;border-top:1px solid var(--ink)}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer-dev{text-align:left}
  .menu-items{grid-template-columns:1fr;gap:0}
  .cols{column-count:1}
}
@media (max-width:680px){
  body{font-size:16px}
  .topbar .tb-left{display:none}
  .nav .container{justify-content:flex-start;gap:0}
  .nav-toggle{display:flex}
  .nav .nav-cta-mini,.nav>.container>.nav-cta{display:inline-block;position:absolute;right:60px;left:auto;top:50%;transform:translateY(-50%);padding:8px 14px;font-size:.72rem;letter-spacing:.12em;z-index:71}
  body.menu-open .nav .nav-cta-mini,body.menu-open .nav>.container>.nav-cta{display:none}
  .nav .nav-cta-group{display:none}
  .nav-links .nav-close{
    display:flex;align-items:center;justify-content:center;
    position:absolute;top:14px;right:16px;width:46px;height:46px;
    border:1px solid var(--ink);border-radius:50%;background:transparent;color:var(--ink);cursor:pointer;
    opacity:0;transition:opacity .3s ease .12s;z-index:5;
  }
  .nav-links.open .nav-close{opacity:1}
  .nav-links .nav-close svg{width:22px;height:22px}
  /* ----- menú móvil a pantalla completa ----- */
  .nav-links{
    position:fixed;inset:0;height:100dvh;background:var(--paper);
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
    padding:84px 24px calc(14vh + 56px);z-index:70;
    opacity:0;visibility:hidden;transform:translateY(-16px);
    transition:opacity .34s ease, transform .34s ease, visibility 0s linear .34s;
    background-image:radial-gradient(rgba(120,100,70,.05) 1px, transparent 1px);background-size:4px 4px;
  }
  .nav-links.open{opacity:1;visibility:visible;transform:none;transition:opacity .34s ease, transform .34s ease, visibility 0s}
  .nav-links a.navlink{
    font-family:var(--serif);font-weight:700;font-size:1.7rem;letter-spacing:.01em;text-transform:none;
    color:var(--ink);padding:13px 10px;width:auto;text-align:center;
    opacity:0;transform:translateY(12px);transition:opacity .4s ease, transform .4s ease;
  }
  .nav-links a.navlink::after{display:none}
  .nav-links.open a.navlink{opacity:1;transform:none}
  .nav-links.open a.navlink:nth-child(1){transition-delay:.08s}
  .nav-links.open a.navlink:nth-child(2){transition-delay:.12s}
  .nav-links.open a.navlink:nth-child(3){transition-delay:.16s}
  .nav-links.open a.navlink:nth-child(4){transition-delay:.20s}
  .nav-links.open a.navlink:nth-child(5){transition-delay:.24s}
  .nav-links.open a.navlink:nth-child(6){transition-delay:.28s}
  .nav-links .nav-cta-mobile{
    display:inline-flex;justify-content:center;position:absolute;left:24px;right:24px;bottom:7vh;
    font-size:1rem;letter-spacing:.18em;padding:16px;border-radius:2px;
    opacity:0;transform:translateY(12px);transition:opacity .4s ease .32s, transform .4s ease .32s;
  }
  .nav-links.open .nav-cta-mobile{opacity:1;transform:none}
  .nav-links .nav-fact-mobile{
    display:inline-flex;justify-content:center;position:absolute;left:24px;right:24px;bottom:calc(7vh + 64px);
    font-size:1rem;letter-spacing:.18em;padding:16px;border-radius:2px;
    opacity:0;transform:translateY(12px);transition:opacity .4s ease .28s, transform .4s ease .28s;
  }
  .nav-links.open .nav-fact-mobile{opacity:1;transform:none}
  body.menu-open{overflow:hidden}
  /* tagline del masthead que no se parta */
  .masthead .tagline{font-size:.7rem;letter-spacing:.18em;line-height:1.7}
  .mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .mosaic .wide{grid-column:span 2}
  .masthead-logo{width:90%}
  .masthead .dateline span.left,.masthead .dateline span.right{display:none}
  /* ----- menú en celular ----- */
  .menu-tabs .container{gap:0}
  .menu-tab{flex:1 1 0;padding:13px 4px;font-size:.74rem;letter-spacing:.08em;text-align:center}
  .menu-tab .sub{display:none}
  .menu-hero{padding:40px 0 30px}
  .menu-panel{padding:32px 0 50px}
  .menu-cat{margin-bottom:34px}
  .menu-cat-head{gap:10px}
  .menu-cat-head h3{font-size:1.3rem;white-space:normal}
  .menu-item{padding:14px 0}
  .menu-item .mi-row{gap:12px;justify-content:space-between}
  .menu-item .mi-dots{display:none}
  .menu-item .mi-name{font-size:1.05rem}
  .menu-item .mi-price{font-size:1rem}
}

/* ===================== COOKIES (consentimiento) ===================== */
.cc-banner{position:fixed;left:0;right:0;bottom:0;z-index:200;background:var(--paper);border-top:3px double var(--ink);box-shadow:0 -12px 34px rgba(20,15,10,.14);transform:translateY(115%);transition:transform .45s cubic-bezier(.2,.7,.3,1);background-image:radial-gradient(rgba(120,100,70,.05) 1px,transparent 1px);background-size:4px 4px}
.cc-banner.show{transform:none}
.cc-inner{max-width:var(--maxw);margin:0 auto;padding:18px 22px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.cc-text{flex:1 1 360px;font-size:.9rem;color:var(--ink-soft);line-height:1.5}
.cc-text strong{font-family:var(--cond);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--oxblood);display:block;margin-bottom:4px}
.cc-text a{color:var(--oxblood);text-decoration:underline}
.cc-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cc-actions .btn{font-size:.72rem;padding:11px 16px}
@media(max-width:680px){.cc-actions{width:100%}.cc-actions .btn{flex:1 1 30%;text-align:center}}

.cc-modal{position:fixed;inset:0;z-index:210;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(20,15,10,.55)}
.cc-modal.show{display:flex}
.cc-card{background:var(--paper);max-width:560px;width:100%;border:1px solid var(--ink);box-shadow:var(--shadow);max-height:88vh;overflow:auto}
.cc-card-head{padding:22px 26px 16px;border-bottom:3px double var(--ink)}
.cc-card-head .kicker{margin-bottom:4px}
.cc-card-head h3{font-family:var(--serif);font-size:1.55rem}
.cc-card-body{padding:6px 26px 4px}
.cc-row{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;padding:16px 0;border-bottom:1px dotted var(--line)}
.cc-row:last-child{border-bottom:0}
.cc-row h4{font-family:var(--cond);text-transform:uppercase;letter-spacing:.12em;font-size:.82rem;margin:0 0 4px;color:var(--ink)}
.cc-row p{font-size:.84rem;color:var(--ink-soft);margin:0;max-width:40ch;line-height:1.45}
.cc-card-foot{padding:18px 26px 24px;display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}
.cc-switch{position:relative;width:46px;height:26px;flex:0 0 auto;margin-top:2px}
.cc-switch input{opacity:0;width:0;height:0;position:absolute}
.cc-slider{position:absolute;inset:0;background:var(--line);border-radius:20px;transition:.25s;cursor:pointer}
.cc-slider::before{content:"";position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.25s;box-shadow:0 1px 2px rgba(0,0,0,.25)}
.cc-switch input:checked + .cc-slider{background:var(--oxblood)}
.cc-switch input:checked + .cc-slider::before{transform:translateX(20px)}
.cc-switch input:disabled + .cc-slider{opacity:.5;cursor:not-allowed}
.open-cookie-prefs{cursor:pointer}
