/**
 * Tepuy Burger — correcciones globales (cargar DESPUÉS de estilos inline de cada página).
 * Scroll, capas (footer/stickers), tokens de superficie y accesibilidad táctil.
 */

:root {
  --surface: #fff8ef;
  --surface-alt: #fffaf2;
}

/* --- Scroll: una sola fuente de verdad --- */
html {
  overflow-x: clip;
  overflow-y: auto !important;
  overscroll-behavior-y: auto !important;
  scroll-behavior: smooth;
}

body {
  overflow-x: clip;
  overflow-y: visible !important;
  overscroll-behavior-y: auto !important;
  min-height: 100svh;
}

/* Footer por encima de stickers flotantes; por debajo de header/CTA/cookies */
.footer {
  position: relative;
  z-index: 20;
}

/* Stickers arrastrables: permitir scroll vertical al pasar el dedo */
.arepa-sticker,
.gluten-home-sticker,
.gluten-sticker {
  touch-action: pan-y;
  z-index: 18;
}

.arepa-sticker.is-dragging,
.gluten-home-sticker.is-dragging,
.gluten-sticker.is-dragging {
  touch-action: none;
}

/* Logos footer: dimensiones reales de visualización (no 2362px intrínsecos) */
.footer-logo,
img.footer-logo {
  width: min(190px, 56vw) !important;
  max-width: 190px !important;
  height: auto !important;
}

header.topbar .logo img,
header.topbar img.logo,
body > header > a.logo img {
  width: auto !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: 58px !important;
  object-fit: contain !important;
}

/* Unificar fondos de tarjeta (opcional, baja especificidad) */
.proof-button {
  background: var(--surface) !important;
}

.local-services-card {
  background: var(--surface-alt);
}

/* Selector de idioma en drawer (4 idiomas visibles) */
.drawer-language {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.drawer-language a {
  min-width: 2.5rem;
  text-align: center;
}

/* Icono hamburguesa: tres líneas centradas en el círculo */
button.icon-button[data-menu-toggle],
header.topbar > button.icon-button {
  display: grid !important;
  place-items: center !important;
  padding: 0 !important;
}

.burger-lines {
  display: block !important;
  width: 18px !important;
  height: 2px !important;
  margin: 0 auto !important;
  border: none !important;
  border-radius: 1px;
  background: currentColor !important;
  box-shadow: 0 -6px 0 currentColor, 0 6px 0 currentColor;
  position: relative !important;
  flex-shrink: 0;
}

.burger-lines::before {
  display: none !important;
  content: none !important;
}

/* Botón volver: chevron geométrico centrado (vence al selector inline del header) */
body > header > a.icon-button:first-child:not(.logo):not(.top-reserve):not(.header-reserve),
header.topbar > a.icon-button.header-home,
header.topbar > a.icon-button:first-child {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  font-size: 0 !important;
  line-height: 0 !important;
  color: var(--ink, #171717) !important;
  text-decoration: none !important;
  overflow: hidden !important;
}

body > header > a.icon-button:first-child:not(.logo):not(.top-reserve):not(.header-reserve)::before,
header.topbar > a.icon-button.header-home::before,
header.topbar > a.icon-button:first-child::before {
  content: none !important;
  display: none !important;
}

body > header > a.icon-button:first-child:not(.logo):not(.top-reserve):not(.header-reserve)::after,
header.topbar > a.icon-button.header-home::after,
header.topbar > a.icon-button:first-child::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  box-sizing: border-box;
  border-left: 2.5px solid var(--ink, #171717);
  border-bottom: 2.5px solid var(--ink, #171717);
  transform: rotate(45deg) translateX(2px);
  flex-shrink: 0;
}

/* Fichas de local: la reserva sticky tapaba la tarjeta SEO de la columna derecha */
@media (min-width: 760px) {
  .page-local .grid .reserve-box {
    position: static;
    top: auto;
  }

  .page-local .grid .reserve-box + .card:not(.local-faq-card) {
    grid-column: 2;
    align-self: start;
  }
}

/* Fichas de local: tablet estrecha — una columna hasta ~960px (evita tarjetas ~244px) */
@media (min-width: 760px) and (max-width: 959px) {
  .page-local .section.grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .page-local .grid .reserve-box {
    grid-column: auto !important;
    grid-row: auto !important;
  }

  .page-local .grid .reserve-box + .card:not(.local-faq-card) {
    grid-column: auto !important;
  }
}

/* Horario: 3 columnas solo con ancho real (no dentro de columna estrecha del grid) */
@media (max-width: 1099px) {
  .page-local .hours-list p {
    grid-template-columns: 1fr !important;
    gap: 4px !important;
    align-items: start !important;
  }
}

@media (min-width: 1100px) {
  .page-local .hours-list p {
    grid-template-columns: minmax(160px, 0.9fr) 1fr 1fr !important;
    align-items: center !important;
    gap: 14px !important;
  }
}

/* FAQ: ancho completo en tablet / grid 2 columnas estrecho */
@media (min-width: 760px) and (max-width: 1099px) {
  .page-local .local-faq-card {
    grid-column: 1 / -1 !important;
  }
}

/* Locales: hero con imagen por sede (--local-hero-image en <body> desde local.php) */
.page-local .section.hero {
  background:
    linear-gradient(180deg, rgba(23, 23, 23, 0.08), rgba(23, 23, 23, 0.8)),
    var(--local-hero-image) center / cover no-repeat !important;
}

/* Tarjetas de local: títulos legibles en móvil (no heredar escala de hero) */
@media (max-width: 759px) {
  .page-local .section.grid .card h2 {
    font-size: clamp(1.35rem, 6.5vw, 1.85rem) !important;
    line-height: 1.08 !important;
    overflow-wrap: anywhere;
  }

  .page-local .local-faq-card p {
    overflow-wrap: anywhere;
  }
}

.reserve-box .reserve-lead-name {
  display: block;
  font-weight: 950;
  margin-top: 0.2em;
  line-height: 1.2;
}

/* Carta digital ORCHA: crédito discreto */
.carta-orcha-credit {
  margin: 0;
  padding: 6px 18px 72px;
  text-align: center;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: rgba(23, 23, 23, 0.34);
}

.carta-orcha-credit a {
  color: inherit;
  font-weight: 700;
  text-decoration: none;
}

.carta-orcha-credit a:hover,
.carta-orcha-credit a:focus-visible {
  color: rgba(23, 23, 23, 0.52);
  text-decoration: underline;
}

.footer button.tepuy-cookie-link {
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  color: inherit;
  cursor: pointer;
  font: inherit;
  text-align: left;
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: 900;
}

@media (min-width: 760px) {
  .carta-orcha-credit {
    padding-bottom: 28px;
  }
}

/* Carta ORCHA: el recorte 1:1 debe respetar object-position inline (punto focal) */
.page-carta .menu-card .recommended-media img,
.page-carta .menu-card .recommended-media video {
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

/* Página Nosotros */
body.page-nosotros .section.hero {
  display: block;
}

body.page-nosotros .section.hero h1 {
  max-width: none;
}

body.page-nosotros .about-grid {
  display: grid;
  gap: 14px;
  max-width: 1180px;
  margin-inline: auto;
}

body.page-nosotros .about-card {
  padding: 20px;
  border: 2px solid var(--ink, #171717);
  border-radius: var(--radius, 8px);
  background: var(--surface, #fff8ef);
  box-shadow: 5px 5px 0 var(--ink, #171717);
}

body.page-nosotros .about-card h3 {
  margin-bottom: 14px;
  font-family: "Space Mono", ui-monospace, monospace;
  text-transform: uppercase;
  line-height: 1.05;
}

body.page-nosotros .about-card p {
  margin-bottom: 14px;
  color: #3f352f;
  font-weight: 600;
}

body.page-nosotros .about-quote {
  margin: 18px 0 12px;
  padding: 14px 16px;
  border-left: 4px solid var(--teal, #1d9793);
  background: rgba(29, 151, 147, 0.08);
  font-weight: 800;
  font-style: italic;
}

body.page-nosotros .about-attribution {
  margin: 0;
  font-weight: 900;
  text-transform: uppercase;
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  color: var(--ink, #171717);
}

@media (min-width: 760px) {
  body.page-nosotros .section.hero {
    display: block;
  }

  body.page-nosotros .section.hero h1 {
    font-size: clamp(3.2rem, 8vw, 5.5rem);
    max-width: 14ch;
  }

  body.page-nosotros .section.hero .lead {
    max-width: 680px;
  }

  body.page-nosotros .about-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(18px, 3vw, 28px);
  }
}

/* Carta digital: hero en columna izquierda (como ultima/carta-digital.html) */
@media (min-width: 760px) {
  body.page-carta .section.hero {
    display: grid !important;
    grid-template-columns: minmax(0, .95fr) minmax(300px, .7fr) !important;
    gap: clamp(28px, 5vw, 72px) !important;
    align-items: end !important;
  }

  body.page-carta .section.hero > .eyebrow,
  body.page-carta .section.hero > h1,
  body.page-carta .section.hero > .lead,
  body.page-carta .section.hero .hero-actions,
  body.page-carta .section.hero .mini-trust {
    grid-column: 1 !important;
  }

  body.page-carta .section.hero h1 {
    max-width: 9ch !important;
    font-size: clamp(4.2rem, 8vw, 7rem) !important;
    letter-spacing: 0 !important;
    line-height: .9 !important;
  }

  body.page-carta .section.hero .lead {
    max-width: 620px !important;
    font-size: 1.04rem !important;
  }
}

@media (max-width: 768px) {
  body.page-carta .section.hero h1 {
    max-width: 9ch !important;
    font-size: clamp(3.2rem, 17vw, 5.4rem) !important;
    letter-spacing: 0 !important;
    line-height: .9 !important;
  }
}
