/* Generado desde ultima/index.html */
:root {
      --bg: #feeedf;
      --ink: #171717;
      --muted: #534840;
      --brand: #f08242;
      --brand-dark: #be1622;
      --cream: #feeedf;
      --yellow: #e6b837;
      --teal: #1d9793;
      --line: #171717;
      --dark: #171717;
      --radius: 8px;
      --shadow: 0 16px 36px rgba(32, 23, 16, .14);
    }

    * { box-sizing: border-box; }

    html {
      scroll-behavior: smooth;
      overscroll-behavior-y: none;
    }

    body {
      margin: 0;
      min-height: 100svh;
      overflow-x: hidden;
      overscroll-behavior-y: none;
      background:
        linear-gradient(90deg, rgba(23, 23, 23, .035) 1px, transparent 1px),
        linear-gradient(180deg, rgba(23, 23, 23, .035) 1px, transparent 1px),
        var(--bg);
      background-size: 28px 28px;
      color: var(--ink);
      font-family: "Plus Jakarta Sans", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      line-height: 1.45;
    }

    a {
      color: inherit;
      text-decoration: none;
    }

    img,
    svg {
      display: block;
      max-width: 100%;
    }

    .topbar {
      position: sticky;
      top: 0;
      z-index: 20;
      display: grid;
      grid-template-columns: 48px 1fr auto auto;
      align-items: center;
      min-height: 76px;
      padding: 10px 14px 8px;
      background: rgba(254, 238, 223, .96);
      border-bottom: 2px solid var(--line);
      backdrop-filter: blur(10px);
    }

    .icon-button {
      display: grid;
      place-items: center;
      width: 42px;
      height: 42px;
      border: 2px solid var(--ink);
      border-radius: 999px;
      background: var(--cream);
      color: var(--ink);
      cursor: pointer;
    }

    .burger-lines {
      width: 18px;
      height: 12px;
      border-top: 2px solid currentColor;
      border-bottom: 2px solid currentColor;
      position: relative;
    }

    .burger-lines::before {
      content: "";
      position: absolute;
      left: 0;
      top: 4px;
      width: 18px;
      border-top: 2px solid currentColor;
    }

    .logo {
      justify-self: center;
      display: grid;
      place-items: center;
      width: 154px;
      height: 58px;
    }

    .logo img {
      width: 154px;
      height: 58px;
      object-fit: contain;
    }

    .top-reserve {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 38px;
      padding: 8px 10px;
      border: 2px solid var(--ink);
      border-radius: 999px;
      background: var(--brand);
      color: var(--ink);
      box-shadow: 3px 3px 0 var(--ink);
      font-weight: 900;
      font-size: .78rem;
      text-transform: uppercase;
      white-space: nowrap;
    }

    .quick-cta {
      display: grid;
      position: fixed;
      left: 0;
      right: 0;
      bottom: 0;
      z-index: 25;
      grid-template-columns: 1fr 1fr;
      border-top: 1px solid rgba(255, 255, 255, .35);
      box-shadow: 0 -10px 30px rgba(32, 23, 16, .18);
      animation: ctaPop .5s .35s ease both;
    }

    .quick-cta a {
      display: grid;
      place-items: center;
      min-height: 58px;
      padding: 12px;
      color: white;
      font-weight: 900;
      text-transform: uppercase;
      font-size: .88rem;
      letter-spacing: .02em;
    }

    .quick-cta a:first-child { background: var(--brand-dark); }
    .quick-cta a:last-child {
      background: var(--brand);
      color: var(--ink);
    }

    .drawer {
      display: block;
      position: fixed;
      inset: 76px 0 auto 0;
      z-index: 19;
      padding: 18px;
      background: var(--cream);
      border-bottom: 1px solid var(--line);
      box-shadow: var(--shadow);
      opacity: 0;
      transform: translateY(-12px);
      visibility: hidden;
      pointer-events: none;
      transition: opacity .22s ease, transform .22s ease, visibility .22s ease;
    }

    .drawer.is-open {
      opacity: 1;
      transform: translateY(0);
      visibility: visible;
      pointer-events: auto;
    }

    .drawer nav {
      display: grid;
      gap: 4px;
    }

    .drawer a {
      padding: 15px 4px;
      border-bottom: 1px solid var(--line);
      font-weight: 900;
      text-transform: uppercase;
    }

    .drawer .drawer-actions {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 10px;
      margin-top: 18px;
    }

    .button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 46px;
      padding: 12px 18px;
      border: 2px solid var(--ink);
      border-radius: 8px;
      font-weight: 900;
      text-transform: uppercase;
      box-shadow: 5px 5px 0 var(--ink);
      background: var(--cream);
      color: var(--ink);
      transition: transform .16s ease, box-shadow .16s ease;
    }

    .button:active {
      transform: translate(3px, 3px);
      box-shadow: 2px 2px 0 var(--ink);
    }

    .button.primary {
      background: var(--brand);
      color: var(--ink);
    }

    .button.ghost {
      background: #fff8ef;
    }

    .button:hover,
    .location-item .reserve-button:hover {
      transform: translate(-1px, -1px);
      box-shadow: 6px 6px 0 var(--ink);
    }

    .button:active,
    .location-item .reserve-button:active,
    .quick-cta a:active {
      transform: translate(3px, 3px);
      box-shadow: 2px 2px 0 var(--ink);
    }

    .section {
      padding: 54px 18px;
    }

    .section[id],
    .hero[id] {
      scroll-margin-top: 86px;
    }

    .hero {
      position: relative;
      min-height: calc(100svh - 76px);
      display: grid;
      align-content: end;
      padding: 18px 18px 92px;
      color: white;
      background:
        radial-gradient(circle at 12% 14%, rgba(240, 130, 66, .7), transparent 30%),
        radial-gradient(circle at 88% 16%, rgba(230, 184, 55, .45), transparent 28%),
        linear-gradient(150deg, var(--teal), var(--ink) 58%);
    }

    .hero-visual {
      position: relative;
      display: grid;
      place-items: center;
      justify-self: center;
      width: 100%;
      max-width: 390px;
      aspect-ratio: 1.18;
      margin-bottom: 26px;
      overflow: hidden;
      border: 4px solid var(--cream);
      border-radius: var(--radius);
      background: var(--ink);
      box-shadow: 9px 9px 0 var(--brand);
    }

    .hero-visual img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center 58%;
      transition: transform .7s ease;
    }

    .hero-visual.is-visible img,
    .thumb.is-visible img,
    .placeholder.is-visible img {
      transform: scale(1.035);
    }

    .eyebrow {
      margin: 0 0 8px;
      color: var(--teal);
      font-weight: 900;
      letter-spacing: .08em;
      text-transform: uppercase;
      font-size: .78rem;
    }

    .hero .eyebrow { color: var(--yellow); }

    h1,
    h2,
    h3,
    p {
      margin-top: 0;
    }

    h1 {
      max-width: 8ch;
      margin-bottom: 18px;
      font-size: clamp(3.25rem, 17vw, 5.4rem);
      line-height: .9;
      letter-spacing: 0;
      text-transform: uppercase;
      font-family: "Space Mono", "Plus Jakarta Sans", ui-monospace, monospace;
    }

    h2 {
      margin-bottom: 18px;
      font-size: clamp(2rem, 9.6vw, 3.45rem);
      line-height: .94;
      letter-spacing: 0;
      text-transform: uppercase;
      font-family: "Space Mono", "Plus Jakarta Sans", ui-monospace, monospace;
      overflow-wrap: break-word;
      text-wrap: balance;
    }

    h3 {
      margin-bottom: 8px;
      font-size: 1.38rem;
      line-height: 1;
      text-transform: uppercase;
    }

    .lead {
      max-width: 34rem;
      color: #4f453d;
      font-size: 1.04rem;
    }

    .hero .lead {
      max-width: 20rem;
      color: rgba(254, 238, 223, .9);
    }

    .social-proof {
      padding: 14px 18px;
      border-top: 3px solid var(--ink);
      border-bottom: 3px solid var(--ink);
      background: var(--ink);
      color: var(--cream);
    }

    .social-proof-card {
      display: grid;
      grid-template-columns: auto 1fr;
      gap: 10px 12px;
      align-items: center;
      max-width: 1180px;
      margin-inline: auto;
      padding: 12px 14px;
      border: 2px solid rgba(254, 238, 223, .85);
      border-radius: var(--radius);
      background: linear-gradient(135deg, rgba(240, 130, 66, .18), rgba(230, 184, 55, .08));
      box-shadow: 4px 4px 0 rgba(240, 130, 66, .72);
    }

    .social-proof .rating-badge {
      display: grid;
      place-items: center;
      width: 76px;
      min-height: 76px;
      border: 2px solid var(--ink);
      border-radius: 50%;
      background: var(--yellow);
      color: var(--ink);
      box-shadow: 3px 3px 0 var(--brand);
      font-family: "Space Mono", "Plus Jakarta Sans", ui-monospace, monospace;
      font-size: 1.2rem;
      font-weight: 950;
      line-height: .92;
      text-align: center;
    }

    .social-proof .review-count {
      display: block;
      font-family: "Space Mono", "Plus Jakarta Sans", ui-monospace, monospace;
      font-size: clamp(1.05rem, 5vw, 1.75rem);
      font-weight: 950;
      line-height: 1;
      text-transform: uppercase;
    }

    .social-proof .review-rating {
      display: block;
      margin-top: 4px;
      color: rgba(254, 238, 223, .84);
      font-size: .88rem;
      font-weight: 850;
    }

    .social-proof .review-locations {
      grid-column: 1 / -1;
      margin: 0;
      color: rgba(254, 238, 223, .76);
      font-size: .78rem;
      font-weight: 900;
      letter-spacing: .03em;
      text-transform: uppercase;
    }

    .cta-row {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      align-items: center;
      margin-top: 22px;
    }

    .intro {
      display: grid;
      gap: 24px;
      background: var(--cream);
      border-top: 6px solid var(--ink);
    }

    .note {
      padding-left: 14px;
      border-left: 3px solid var(--teal);
      color: var(--muted);
      font-size: .93rem;
    }

    .value-list {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 8px;
      margin: 18px 0;
    }

    .value-list span,
    .star-grid article {
      padding: 12px;
      border: 2px solid var(--ink);
      border-radius: var(--radius);
      background: #fff8ef;
      box-shadow: 4px 4px 0 var(--ink);
      font-weight: 900;
    }

    .pending {
      display: inline-flex;
      width: fit-content;
      padding: 6px 10px;
      border: 2px solid var(--ink);
      border-radius: 999px;
      background: var(--yellow);
      color: var(--ink);
      font-weight: 900;
      text-transform: uppercase;
      font-size: .74rem;
    }

    .placeholder {
      min-height: 260px;
      overflow: hidden;
      border: 2px solid var(--ink);
      border-radius: var(--radius);
      background: var(--cream);
      box-shadow: 6px 6px 0 var(--ink);
    }

    .placeholder img,
    .placeholder video,
    .thumb img,
    .thumb video {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .placeholder picture,
    .thumb picture {
      display: block;
      width: 100%;
      height: 100%;
    }

    .placeholder:has(video) {
      min-height: 0;
      aspect-ratio: 1 / 1;
      background: #000;
    }

    .burger-video-poster {
      background: #000 url("assets/mejor-hamburguesa-alicante.webp") center / cover no-repeat;
    }

    .burger-video-poster video {
      opacity: 0;
      transition: opacity .18s ease;
    }

    .burger-video-poster video.is-ready {
      opacity: 1;
    }

    .placeholder video {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
      background: #000;
    }

    .promo {
      background: var(--brand);
      color: var(--ink);
      text-align: center;
      border-block: 6px solid var(--ink);
    }

    .promo .eyebrow,
    .delivery .eyebrow {
      color: var(--yellow);
    }

    .promo h2 {
      margin-inline: auto;
      max-width: 8ch;
    }

    .promo .placeholder {
      margin: 24px 0;
      background: var(--ink);
    }

    .delivery {
      position: relative;
      display: grid;
      min-height: 560px;
      align-content: end;
      overflow: hidden;
      color: #fff;
      background: var(--ink);
    }

    .delivery .lead {
      color: #fff;
    }

    .delivery-content {
      position: relative;
      z-index: 1;
      padding-top: 300px;
    }

    .delivery-visual {
      position: absolute;
      inset: 0;
      background: #000;
    }

    .delivery-visual::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(23,23,23,.05), rgba(23,23,23,.88));
    }

    .delivery-visual img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center;
    }

    .order-draft {
      background: #fff8ef;
    }

    .order-draft .lead {
      color: #4f453d;
    }

    .order-options {
      display: grid;
      gap: 14px;
      margin-top: 24px;
    }

    .order-options article {
      padding: 18px;
      border: 1.5px solid var(--ink);
      border-radius: var(--radius);
      background: var(--cream);
      box-shadow: 3px 3px 0 var(--ink);
    }

    .order-options strong {
      display: block;
      margin-bottom: 8px;
      text-transform: uppercase;
      font-size: 1.02rem;
    }

    .order-options p {
      margin-bottom: 10px;
      color: #4f453d;
      font-weight: 650;
    }

    .news {
      background: var(--bg);
    }

    .news-list {
      display: grid;
      gap: 16px;
      margin-top: 24px;
    }

    .news-card {
      overflow: hidden;
      border: 2px solid var(--ink);
      border-radius: var(--radius);
      background: var(--cream);
      box-shadow: 6px 6px 0 var(--ink);
    }

    .news-card .thumb {
      display: grid;
      place-items: center;
      min-height: 170px;
      background: var(--brand);
    }

    .news-card .body {
      padding: 18px;
    }

    .menu-day-visual {
      display: grid;
      gap: 10px;
      min-height: 190px;
      padding: 18px;
      align-content: center;
      background:
        radial-gradient(circle at 82% 18%, rgba(230, 184, 55, .9), transparent 28%),
        linear-gradient(135deg, var(--brand), #fff8ef 72%);
      color: var(--ink);
      border-bottom: 2px solid var(--ink);
    }

    .menu-day-visual strong {
      width: fit-content;
      padding: 8px 10px;
      border: 2px solid var(--ink);
      border-radius: 999px;
      background: var(--yellow);
      font-size: 2rem;
      line-height: 1;
      box-shadow: 4px 4px 0 var(--ink);
    }

    .menu-day-visual span {
      font-family: "Space Mono", ui-monospace, monospace;
      font-weight: 900;
      font-size: 1.35rem;
      line-height: .95;
      text-transform: uppercase;
    }

    .locations {
      background: var(--cream);
    }

    .stars {
      background: #fff8ef;
      border-top: 6px solid var(--ink);
    }

    .star-grid {
      display: grid;
      gap: 12px;
      margin-top: 20px;
    }

    .star-grid strong {
      display: block;
      margin-bottom: 8px;
      font-size: 1.12rem;
      text-transform: uppercase;
    }

    .star-grid p {
      margin: 0;
      font-weight: 600;
      color: #4f453d;
    }

    .star-image {
      overflow: hidden;
      margin: 18px 0 0;
      border: 2px solid var(--ink);
      border-radius: var(--radius);
      background: var(--cream);
      box-shadow: 6px 6px 0 var(--ink);
    }

    .star-image img {
      width: 100%;
      aspect-ratio: 1 / 1;
      object-fit: cover;
    }

    .star-image figcaption {
      padding: 12px 14px;
      background: #fff8ef;
      font-weight: 900;
      text-transform: uppercase;
    }

    .star-video {
      overflow: hidden;
      margin-top: 18px;
      border: 2px solid var(--ink);
      border-radius: var(--radius);
      background: var(--ink);
      box-shadow: 6px 6px 0 var(--ink);
    }

    .star-video video {
      display: block;
      width: 100%;
      aspect-ratio: 1 / 1;
      object-fit: cover;
      background: #000;
    }

    .star-video .body {
      padding: 16px;
      background: #fff8ef;
    }

    .star-video strong {
      display: block;
      margin-bottom: 8px;
      text-transform: uppercase;
    }

    .star-video p {
      margin: 0;
      color: #4f453d;
      font-weight: 700;
    }

    .menu-section {
      background: var(--teal);
      color: #fff;
      border-block: 6px solid var(--ink);
    }

    .menu-section .eyebrow {
      color: var(--yellow);
    }

    .menu-section .lead {
      color: rgba(255, 255, 255, .9);
    }

    .location-list {
      display: grid;
      gap: 12px;
      margin-top: 22px;
    }

    .location-item {
      display: grid;
      gap: 6px;
      padding: 18px;
      border: 2px solid var(--ink);
      border-radius: var(--radius);
      background: #fff8ef;
    }

    .location-item .thumb {
      overflow: hidden;
      margin: -18px -18px 12px;
      aspect-ratio: 16 / 9;
      border-bottom: 2px solid var(--ink);
      background: var(--ink);
    }

    .location-item strong {
      font-size: 1.08rem;
      text-transform: uppercase;
    }

    .location-item .map-link {
      width: fit-content;
      color: var(--muted);
      font-weight: 900;
      text-decoration: underline;
      text-decoration-thickness: 2px;
      text-underline-offset: 3px;
    }

    .location-item .reserve-button {
      width: fit-content;
      margin-top: 6px;
      padding: 10px 14px;
      border: 2px solid var(--ink);
      border-radius: 8px;
      background: var(--brand);
      color: var(--ink);
      box-shadow: 4px 4px 0 var(--ink);
      font-weight: 900;
      text-transform: uppercase;
    }

    .loyalty {
      display: grid;
      gap: 20px;
      background: var(--brand);
      color: var(--ink);
      border-block: 6px solid var(--ink);
    }

    .loyalty .lead {
      color: #30251e;
    }

    .loyalty .placeholder {
      background: var(--ink);
      border-color: var(--ink);
      box-shadow: 6px 6px 0 var(--ink);
    }

    .work {
      background: var(--brand);
      color: var(--ink);
      border-top: 6px solid var(--ink);
    }

    .work-teaser {
      background: var(--brand);
      color: var(--ink);
      border-block: 6px solid var(--ink);
      text-align: center;
    }

    .faq {
      background: var(--cream);
      border-top: 6px solid var(--ink);
    }

    .faq-list {
      display: grid;
      gap: 12px;
      margin-top: 22px;
    }

    .faq-item {
      padding: 18px;
      border: 2px solid var(--ink);
      border-radius: var(--radius);
      background: #fff8ef;
      box-shadow: 5px 5px 0 var(--ink);
    }

    .arepa-sticker {
      position: absolute;
      left: 12px;
      bottom: 8px;
      z-index: 11;
      display: grid;
      place-items: center;
      width: 104px;
      min-height: 68px;
      padding: 9px;
      border: 2px solid var(--ink);
      border-radius: 46% 54% 48% 52% / 42% 45% 55% 58%;
      background: var(--yellow);
      color: var(--ink);
      box-shadow: 4px 4px 0 var(--ink);
      font-family: "Space Mono", ui-monospace, monospace;
      font-weight: 900;
      line-height: .95;
      text-align: center;
      text-transform: uppercase;
      transform: rotate(-7deg);
      touch-action: none;
      cursor: grab;
      user-select: none;
    }

    .arepa-sticker:active {
      cursor: grabbing;
    }

    .gluten-home-sticker {
      position: absolute;
      right: 12px;
      top: clamp(348px, 56svh, 420px);
      z-index: 11;
      display: grid;
      place-items: center;
      width: 96px;
      min-height: 62px;
      padding: 10px;
      border: 3px solid var(--ink);
      border-radius: 58% 42% 47% 53% / 45% 57% 43% 55%;
      background: var(--teal);
      color: #fff;
      box-shadow: 5px 5px 0 var(--ink);
      font-family: "Space Mono", ui-monospace, monospace;
      font-weight: 900;
      font-size: .82rem;
      line-height: .9;
      text-align: center;
      text-transform: uppercase;
      transform: rotate(-6deg);
      touch-action: none;
      cursor: grab;
      user-select: none;
    }

    .gluten-home-sticker:active {
      cursor: grabbing;
    }

    .section,
    .location-item,
    .news-card,
    .faq-item,
    .star-grid article {
      opacity: 0;
      transform: translateY(16px);
      transition: opacity .46s ease, transform .46s ease;
    }

    .section.is-visible,
    .location-item.is-visible,
    .news-card.is-visible,
    .faq-item.is-visible,
    .star-grid article.is-visible {
      opacity: 1;
      transform: translateY(0);
    }

    .location-item.is-visible:hover,
    .news-card.is-visible:hover,
    .star-grid article.is-visible:hover {
      transform: translateY(-2px);
      box-shadow: 6px 6px 0 var(--ink);
    }

    @keyframes ctaPop {
      from { transform: translateY(12px); opacity: 0; }
      70% { transform: translateY(-3px); opacity: 1; }
      to { transform: translateY(0); opacity: 1; }
    }

    @media (prefers-reduced-motion: reduce) {
      *, *::before, *::after {
        animation: none !important;
        transition: none !important;
        scroll-behavior: auto !important;
      }
    }

    .footer {
      padding: 44px 18px 92px;
      background: var(--ink);
      color: #fff;
    }

    .footer-grid {
      display: grid;
      gap: 28px;
    }

    .footer h2 {
      font-size: 2.4rem;
      margin-bottom: 10px;
    }

    .footer-logo {
      width: 190px;
      margin-bottom: 18px;
      padding: 0;
      border-radius: 0;
      background: transparent;
    }

    .footer h3 {
      font-size: .92rem;
      letter-spacing: .08em;
      color: #ffd9a6;
    }

    .footer ul {
      display: grid;
      gap: 10px;
      padding: 0;
      margin: 0;
      list-style: none;
      color: rgba(255, 255, 255, .82);
    }

    .social {
      display: flex;
      gap: 10px;
      margin-top: 14px;
    }

    .social a {
      display: grid;
      place-items: center;
      width: 38px;
      height: 38px;
      border: 1px solid rgba(255, 255, 255, .5);
      border-radius: 50%;
      font-weight: 900;
    }

    .social svg {
      width: 19px;
      height: 19px;
      fill: #fff;
    }

    @media (min-width: 760px) {
      body {
        max-width: none;
        margin-inline: 0;
        border-inline: 0;
      }

      .topbar {
        grid-template-columns: 72px 1fr auto auto;
        padding-inline: clamp(28px, 5vw, 72px);
      }

      .drawer {
        max-width: 420px;
      }

      .quick-cta {
        left: 50%;
        right: auto;
        bottom: 24px;
        width: min(560px, calc(100vw - 48px));
        animation: none;
        overflow: hidden;
        border: 2px solid var(--ink);
        border-radius: 999px;
        box-shadow: 0 12px 34px rgba(23,23,23,.28);
        transform: translateX(-50%);
      }

      .hero {
        min-height: calc(100svh - 76px);
        display: grid;
        grid-template-columns: minmax(0, .9fr) minmax(360px, 1fr);
        column-gap: clamp(34px, 6vw, 88px);
        align-items: center;
        padding: 80px clamp(36px, 7vw, 96px) 88px;
      }

      .hero-visual {
        grid-column: 2;
        grid-row: 1 / span 5;
        align-self: center;
        max-width: 660px;
        margin-left: auto;
      }

      .hero > .eyebrow,
      .hero > h1,
      .hero > .lead,
      .hero > .cta-row {
        grid-column: 1;
      }

      .hero h1 {
        max-width: 9.5ch;
        font-size: clamp(4.8rem, 8vw, 7.4rem);
      }

      .hero .lead {
        max-width: 33rem;
        font-size: 1.16rem;
      }

      .section {
        padding: 84px clamp(36px, 7vw, 96px);
      }

      .section > .eyebrow,
      .section > h2,
      .section > .lead,
      .section > p:not(.eyebrow),
      .section > .note,
      .section > .button {
        max-width: 1180px;
      }

      .value-section {
        display: grid;
        grid-template-columns: minmax(0, .95fr) minmax(320px, .8fr);
        gap: clamp(28px, 5vw, 72px);
        align-items: center;
      }

      .value-section > div:first-child {
        max-width: 620px;
      }

      .value-section .placeholder {
        margin: 0;
        max-width: 520px;
        justify-self: end;
      }

      .value-section > .button {
        grid-column: 1;
        width: fit-content;
      }

      .stars {
        display: grid;
        grid-template-columns: minmax(280px, .72fr) minmax(0, 1fr);
        gap: clamp(24px, 4vw, 54px);
        align-items: start;
      }

      .stars > .eyebrow,
      .stars > h2 {
        grid-column: 1 / -1;
      }

      .stars > h2 {
        max-width: 20ch;
        font-size: clamp(3.4rem, 6.5vw, 6.3rem);
      }

      .star-image {
        margin-top: 0;
        max-width: 460px;
        align-self: stretch;
      }

      .star-image img {
        height: 100%;
        max-height: 420px;
        aspect-ratio: auto;
        object-fit: cover;
      }

      .star-grid {
        margin-top: 0;
        grid-template-columns: repeat(3, minmax(0, 1fr));
      }

      .star-video {
        grid-column: 1 / -1;
        display: grid;
        grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr);
        align-items: stretch;
        width: 100%;
        max-width: 1180px;
        justify-self: center;
      }

      .star-video video {
        height: 100%;
        min-height: 420px;
        aspect-ratio: 16 / 9;
      }

      .star-video .body {
        display: grid;
        align-content: center;
        padding: clamp(24px, 4vw, 44px);
      }

      .stars > .button {
        grid-column: 1 / -1;
        justify-self: start;
        margin-top: -18px;
      }

      .menu-section {
        display: grid;
        grid-template-columns: minmax(0, .8fr) minmax(0, 1fr);
        gap: 28px;
        align-items: center;
      }

      .menu-section .eyebrow,
      .menu-section h2 {
        grid-column: 1;
      }

      .menu-section .lead,
      .menu-section .button {
        grid-column: 2;
      }

      .delivery {
        min-height: auto;
        grid-template-columns: minmax(320px, .95fr) minmax(0, 1fr);
        gap: clamp(28px, 5vw, 72px);
        align-items: center;
        color: #fff;
      }

      .delivery-visual {
        position: relative;
        min-height: 460px;
        border: 2px solid var(--ink);
        border-radius: var(--radius);
        box-shadow: 6px 6px 0 var(--brand);
        overflow: hidden;
      }

      .delivery-content {
        padding-top: 0;
      }

      .news-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: 1180px;
      }

      .location-list {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        max-width: 1180px;
      }

      .location-item {
        align-content: start;
      }

      .story-brief {
        display: grid;
        grid-template-columns: minmax(0, .65fr) minmax(0, 1fr);
        gap: clamp(24px, 5vw, 72px);
        align-items: start;
      }

      .story-brief .eyebrow,
      .story-brief h2 {
        grid-column: 1;
      }

      .story-brief p:not(.eyebrow) {
        grid-column: 2;
        max-width: 680px;
      }

      .faq-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: 1180px;
      }

      .footer-grid {
        display: grid;
        grid-template-columns: minmax(280px, 1.2fr) repeat(2, minmax(180px, .6fr));
        gap: clamp(28px, 5vw, 72px);
        max-width: 1180px;
        margin-inline: auto;
      }
    }

    @media (min-width: 1180px) {
      .stars {
        grid-template-columns: minmax(360px, .9fr) minmax(320px, .55fr);
        column-gap: clamp(28px, 5vw, 72px);
      }

      .stars > h2 {
        max-width: 24ch;
      }

      .star-image {
        width: 100%;
        max-width: none;
      }

      .star-image img {
        max-height: 560px;
      }

      .star-grid {
        grid-template-columns: 1fr;
        align-self: stretch;
        align-content: stretch;
      }

      .star-grid article {
        display: grid;
        align-content: center;
        min-height: 0;
      }

      .news-card {
        display: grid;
        grid-template-columns: minmax(230px, .85fr) 1fr;
      }

      .news-card .thumb,
      .menu-day-visual {
        min-height: 100%;
        border-bottom: 0;
        border-right: 2px solid var(--ink);
      }
    }
      .language-switch{display:inline-flex;align-items:center;gap:2px;padding:3px;border:2px solid var(--ink,#171717);border-radius:999px;background:var(--bg,#feeedf);box-shadow:3px 3px 0 var(--ink,#171717);font-weight:950;font-size:.7rem;line-height:1;text-transform:uppercase;white-space:nowrap;}
    .language-switch a{padding:6px 7px;border-radius:999px;color:inherit;text-decoration:none;}
    .language-switch a[aria-current="true"]{background:var(--ink,#171717);color:#fff;}
      .skip-link{position:absolute;left:12px;top:-60px;z-index:9999;padding:10px 14px;border:2px solid var(--ink,#171717);border-radius:8px;background:#fff;color:#171717;box-shadow:4px 4px 0 var(--ink,#171717);font-weight:900;text-decoration:none;}
    .skip-link:focus{top:12px;}
    :focus-visible{outline:3px solid var(--yellow,#e6b837);outline-offset:3px;}      .phone-link{display:inline-flex;align-items:center;gap:6px;width:max-content;margin:6px 0 10px;color:var(--muted,#534840);font-size:.9rem;font-weight:800;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;}
    .phone-link:hover{color:var(--ink,#171717);}
  
    /* Responsive repair after intrinsic width/height attributes. */
    img {
      max-width: 100%;
      height: auto;
    }

    .footer-logo {
      display: block;
      width: min(190px, 56vw) !important;
      max-width: 190px !important;
      height: auto !important;
      object-fit: contain !important;
    }

    .logo img,
    .hero-visual img,
    .delivery-visual img,
    .media-card img,
    .thumb img,
    .placeholder img,
    .poster img,
    .gluten-poster img,
    .product-media img {
      height: 100%;
    }

    .star-image img,
    .menu-card img,
    .press-card img,
    .store-card img,
    .card img:not(.footer-logo) {
      width: 100%;
      height: auto;
    }

    .top-reserve,
    .header-reserve {
      max-width: none !important;
      overflow: visible !important;
      text-overflow: clip !important;
      flex: 0 0 auto;
      min-width: max-content;
      white-space: nowrap;
      font-size: clamp(.68rem, 2.45vw, .78rem);
      padding-inline: clamp(8px, 2.4vw, 12px);
    }

    @media (max-width: 390px) {
      .topbar {
        grid-template-columns: 42px minmax(92px, 1fr) auto auto;
        gap: 6px;
        padding-inline: 8px;
      }
      .logo,
      .logo img {
        width: clamp(96px, 30vw, 132px);
      }
      .top-reserve,
      .header-reserve {
        font-size: .66rem;
        padding-inline: 7px;
      }
    }
    /* Header logo hard clamp: prevents intrinsic image dimensions from escaping the topbar. */
    .topbar .logo {
      width: clamp(96px, 28vw, 154px) !important;
      height: 58px !important;
      max-width: clamp(96px, 28vw, 154px) !important;
      overflow: hidden !important;
      display: grid !important;
      place-items: center !important;
      flex: 0 1 auto !important;
    }

    .topbar .logo img {
      display: block !important;
      width: 100% !important;
      height: 100% !important;
      max-width: 100% !important;
      max-height: 100% !important;
      object-fit: contain !important;
    }

    header img.logo {
      width: clamp(96px, 28vw, 142px) !important;
      height: 54px !important;
      max-width: clamp(96px, 28vw, 142px) !important;
      max-height: 54px !important;
      object-fit: contain !important;
      flex: 0 1 auto !important;
    }
    /* Final header logo sizing: header logo is independent from footer logo. */
    .topbar > a.logo {
      width: clamp(72px, 18vw, 92px) !important;
      height: 54px !important;
      max-width: clamp(72px, 18vw, 92px) !important;
      min-width: 72px !important;
      overflow: visible !important;
      display: grid !important;
      place-items: center !important;
      justify-self: center !important;
      flex: 0 0 auto !important;
    }

    .topbar > a.logo img {
      width: 100% !important;
      height: 100% !important;
      max-width: 100% !important;
      max-height: 100% !important;
      object-fit: contain !important;
      object-position: center !important;
      display: block !important;
    }

    @media (max-width: 390px) {
      .topbar {
        grid-template-columns: 42px minmax(74px, 1fr) auto auto !important;
        gap: 6px !important;
      }
      .topbar > a.logo {
        width: 74px !important;
        min-width: 74px !important;
        height: 50px !important;
      }
    }
  
    /* Header/logo final guard: header and footer logos use independent sizing. */
    header.topbar {
      align-items: center !important;
      overflow: hidden !important;
    }

    header.topbar > a.logo {
      width: 84px !important;
      min-width: 84px !important;
      max-width: 84px !important;
      height: 56px !important;
      max-height: 56px !important;
      padding: 0 !important;
      margin: 0 auto !important;
      overflow: hidden !important;
      display: grid !important;
      place-items: center !important;
      flex: 0 0 84px !important;
      line-height: 0 !important;
      background: transparent !important;
      border: 0 !important;
      box-shadow: none !important;
    }

    header.topbar > a.logo img,
    header.topbar img.logo {
      width: 84px !important;
      min-width: 84px !important;
      max-width: 84px !important;
      height: 56px !important;
      max-height: 56px !important;
      object-fit: contain !important;
      object-position: center !important;
      display: block !important;
      transform: none !important;
      aspect-ratio: auto !important;
    }

    footer .footer-logo,
    img.footer-logo {
      width: min(190px, 56vw) !important;
      max-width: 190px !important;
      height: auto !important;
      max-height: none !important;
      object-fit: contain !important;
    }

    .proof-button {
      display: inline-flex !important;
      align-items: center !important;
      justify-content: center !important;
      gap: 4px !important;
      width: max-content !important;
      min-width: 0 !important;
      max-width: 100% !important;
      padding: 4px 8px !important;
      border: 2px solid var(--ink, #171717) !important;
      border-radius: 999px !important;
      background: #fff7ed !important;
      color: var(--ink, #171717) !important;
      box-shadow: 2px 2px 0 var(--ink, #171717) !important;
      font-size: .72rem !important;
      line-height: 1 !important;
      font-weight: 900 !important;
      white-space: nowrap !important;
      text-transform: none !important;
    }

    .proof-button .heart {
      color: #c51622 !important;
      font-size: .78rem !important;
      line-height: 1 !important;
    }

    @media (max-width: 430px) {
      header.topbar {
        grid-template-columns: 42px 84px minmax(58px, auto) minmax(104px, auto) !important;
        gap: 5px !important;
        padding-inline: 8px !important;
      }
      header.topbar > a.logo,
      header.topbar > a.logo img,
      header.topbar img.logo {
        width: 78px !important;
        min-width: 78px !important;
        max-width: 78px !important;
        height: 52px !important;
        max-height: 52px !important;
      }
      header.topbar .language-switch {
        transform: scale(.84) !important;
        transform-origin: center !important;
      }
      header.topbar .top-reserve,
      header.topbar .header-reserve {
        font-size: .67rem !important;
        padding-inline: 8px !important;
        min-width: 0 !important;
      }
    }
  
    /* Final responsive header system: 3 zones, centered brand, language moved to drawer. */
    html, body {
      max-width: 100%;
      overflow-x: hidden;
    }

    header.topbar,
    body > header:not(.footer) {
      position: sticky;
      top: 0;
      z-index: 30;
      display: grid !important;
      grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) !important;
      align-items: center !important;
      gap: 10px !important;
      min-height: 76px !important;
      padding: 10px clamp(14px, 4vw, 42px) !important;
      background: rgba(254, 238, 223, .98) !important;
      border-bottom: 3px solid var(--ink, #171717) !important;
      overflow: hidden !important;
    }

    header.topbar > .language-switch,
    body > header > .language-switch {
      display: none !important;
    }

    header.topbar > .icon-button,
    body > header > .icon-button,
    body > header > a:first-child:not(.logo):not(.top-reserve):not(.header-reserve) {
      grid-column: 1 !important;
      justify-self: start !important;
      display: inline-grid !important;
      place-items: center !important;
      width: 48px !important;
      height: 48px !important;
      min-width: 48px !important;
      padding: 0 !important;
      border: 2px solid var(--ink, #171717) !important;
      border-radius: 999px !important;
      background: transparent !important;
      color: var(--ink, #171717) !important;
      box-shadow: none !important;
      font-size: 1.35rem !important;
      font-weight: 900 !important;
      line-height: 1 !important;
      text-decoration: none !important;
    }

    header.topbar > a.logo,
    body > header > a.logo {
      grid-column: 2 !important;
      justify-self: center !important;
      width: clamp(88px, 9vw, 110px) !important;
      min-width: clamp(88px, 9vw, 110px) !important;
      max-width: clamp(88px, 9vw, 110px) !important;
      height: auto !important;
      min-height: 0 !important;
      max-height: none !important;
      padding: 0 !important;
      margin: 0 !important;
      overflow: visible !important;
      display: grid !important;
      place-items: center !important;
      line-height: 0 !important;
      background: transparent !important;
      border: 0 !important;
      box-shadow: none !important;
    }

    header.topbar > a.logo img,
    body > header > a.logo img,
    body > header > img.logo {
      width: 100% !important;
      height: auto !important;
      max-width: 100% !important;
      max-height: 62px !important;
      object-fit: contain !important;
      object-position: center !important;
      display: block !important;
      transform: none !important;
      aspect-ratio: auto !important;
    }

    header.topbar > .top-reserve,
    header.topbar > .header-reserve,
    body > header > .top-reserve,
    body > header > .header-reserve {
      grid-column: 3 !important;
      justify-self: end !important;
      display: inline-flex !important;
      align-items: center !important;
      justify-content: center !important;
      min-height: 44px !important;
      max-width: 100% !important;
      padding: 9px 14px !important;
      border: 2px solid var(--ink, #171717) !important;
      border-radius: 999px !important;
      background: var(--brand, #f47f35) !important;
      color: var(--ink, #171717) !important;
      box-shadow: 4px 4px 0 var(--ink, #171717) !important;
      font-size: .78rem !important;
      font-weight: 950 !important;
      line-height: 1 !important;
      text-transform: uppercase !important;
      white-space: nowrap !important;
      text-decoration: none !important;
    }

    .drawer-language {
      display: flex;
      gap: 8px;
      flex-wrap: wrap;
      margin-top: 18px;
      padding-top: 18px;
      border-top: 2px solid rgba(23, 23, 23, .16);
    }

    .drawer-language a {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 54px;
      min-height: 38px;
      padding: 8px 12px;
      border: 2px solid var(--ink, #171717);
      border-radius: 999px;
      background: var(--bg, #feeedf);
      color: var(--ink, #171717);
      box-shadow: 3px 3px 0 var(--ink, #171717);
      font-weight: 950;
      text-transform: uppercase;
      text-decoration: none;
    }

    .drawer-language a[aria-current="true"] {
      background: var(--ink, #171717);
      color: #fff;
    }

    @media (max-width: 768px) {
      header.topbar,
      body > header:not(.footer) {
        min-height: 68px !important;
        grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) !important;
        gap: 6px !important;
        padding: 8px 10px !important;
      }

      header.topbar > .icon-button,
      body > header > .icon-button,
      body > header > a:first-child:not(.logo):not(.top-reserve):not(.header-reserve) {
        width: 44px !important;
        height: 44px !important;
        min-width: 44px !important;
        font-size: 1.2rem !important;
      }

      header.topbar > a.logo,
      body > header > a.logo {
        width: clamp(64px, 18vw, 75px) !important;
        min-width: clamp(64px, 18vw, 75px) !important;
        max-width: clamp(64px, 18vw, 75px) !important;
      }

      header.topbar > a.logo img,
      body > header > a.logo img,
      body > header > img.logo {
        max-height: 52px !important;
      }

      header.topbar > .top-reserve,
      header.topbar > .header-reserve,
      body > header > .top-reserve,
      body > header > .header-reserve {
        min-height: 40px !important;
        padding: 8px 10px !important;
        font-size: clamp(.62rem, 2.6vw, .72rem) !important;
        box-shadow: 3px 3px 0 var(--ink, #171717) !important;
      }

      .section.hero,
      .restaurant-hero,
      .restaurants-hero,
      .hero-restaurantes {
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
        padding-left: 20px !important;
        padding-right: 20px !important;
        box-sizing: border-box !important;
      }

      .section.hero > *,
      .restaurant-hero__content,
      .restaurants-hero__content,
      .hero-content {
        max-width: 100% !important;
        box-sizing: border-box !important;
      }

      .section.hero h1,
      .restaurant-hero h1,
      .restaurants-hero h1,
      .hero-restaurantes h1 {
        font-size: clamp(42px, 13vw, 58px) !important;
        line-height: .92 !important;
        letter-spacing: -.03em !important;
        max-width: 100% !important;
        white-space: normal !important;
        overflow-wrap: normal !important;
        word-break: normal !important;
      }

      .section.hero p,
      .restaurant-hero p,
      .restaurants-hero p,
      .hero-restaurantes p {
        font-size: 16px !important;
        line-height: 1.45 !important;
        max-width: 100% !important;
      }
    }
      

    body {
      overflow-y: visible;
      overscroll-behavior-y: auto;
    }
