/* Generado desde ultima/aviso-legal.html */
html{overscroll-behavior-y:none;} 
    :root{--bg:#feeedf;--ink:#171717;--brand:#f08242;}*{box-sizing:border-box;}body{margin:0;min-height:100svh;overflow-x:hidden;overscroll-behavior-y:none;background:var(--bg);color:var(--ink);font-family:system-ui,-apple-system,"Segoe UI",sans-serif;line-height:1.55;}header,main{padding:18px;}header{display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:2px solid var(--ink);position:sticky;top:0;background:rgba(254,238,223,.96);}a{color:inherit;font-weight:900;}h1,h2{font-family:ui-monospace,monospace;text-transform:uppercase;line-height:.95;}h1{font-size:clamp(2.4rem,13vw,4rem);}section{padding:18px 0;border-bottom:2px solid rgba(23,23,23,.18);}.button,.header-reserve{display:inline-flex;padding:10px 14px;border:2px solid var(--ink);border-radius:8px;background:var(--brand);box-shadow:4px 4px 0 var(--ink);text-decoration:none;text-transform:uppercase;}.header-reserve{border-radius:999px;font-size:.78rem;white-space:nowrap;}@media(min-width:760px){body{max-width:none;margin:0;border-inline:0;}header,main{padding-inline:clamp(36px,7vw,96px);}main{max-width:980px;margin-inline:auto;}h1{font-size:clamp(3.2rem,7vw,5.8rem);}}
      .footer { padding:42px 18px 96px; background:var(--ink); color:#fff; } .footer-logo { width:190px; margin-bottom:18px; } .footer-links { display:grid; gap:10px; margin-top:18px; } .footer-links a { color:rgba(255,255,255,.86); }
      .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);}  
    .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) {
      .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;
      }
    }

    /* 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;
    }
    /* 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;
      }
    }
      /* page scroll repair */
    html {
      overflow-y: auto;
      overscroll-behavior-y: auto;
    }

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