:root{
  --bg:#0b0c10;
  --panel:#0f121a;
  --panel2:#121827;
  --text:#f4f7ff;
  --muted:rgba(244,247,255,.72);
  --line:rgba(244,247,255,.14);
  --gold:#ffc43d;
  --shadow:0 18px 60px rgba(0,0,0,.45);
  --radius:12px;
  --radius2:16px;
  --container:1120px;
  --pad:clamp(18px, 3vw, 32px);
  --h1:clamp(40px, 5vw, 72px);
  --h2:clamp(28px, 3.4vw, 42px);
  --h3:clamp(18px, 2.3vw, 24px);
  --lead:clamp(16px, 1.6vw, 18px);
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Helvetica Neue", Helvetica, sans-serif;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

*{ box-sizing:border-box }
html{ scroll-behavior:smooth }
body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  background:
    radial-gradient(900px 620px at 10% -10%, rgba(255,196,61,.18), transparent 60%),
    radial-gradient(900px 620px at 100% 0%, rgba(93,168,255,.14), transparent 55%),
    var(--bg);
  line-height:1.5;
}
a{ color:inherit; text-decoration:none }
a:hover{ text-decoration:underline }
img{ max-width:100%; display:block }
.container{ width:min(var(--container), calc(100% - 2*var(--pad))); margin-inline:auto }
.sr-only{ position:absolute!important; width:1px;height:1px; padding:0;margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.tiny{ font-size:12px }
.muted{ color:var(--muted) }
.kicker{ text-transform:uppercase; letter-spacing:.22em; font-weight:900; font-size:12px; color:rgba(244,247,255,.74) }
.divider{ height:1px; background:rgba(244,247,255,.10); margin:16px 0 }

.skip-link{
  position:absolute; left:12px; top:12px;
  transform:translateY(-140%);
  background:var(--panel);
  border:1px solid var(--line);
  padding:10px 12px;
  border-radius:12px;
  z-index:9999;
}
.skip-link:focus{ transform:translateY(0) }

/* Header: similar rhythm to Starbucks (top util + nav) */
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(140%) blur(10px);
  background:rgba(11,12,16,.78);
  border-bottom:1px solid rgba(244,247,255,.10);
  transition: box-shadow .2s ease, background .2s ease;
}
.site-header.is-elevated{ box-shadow:0 6px 20px rgba(0,0,0,.25); background:rgba(11,12,16,.96) }
.topbar{ border-bottom:1px solid rgba(244,247,255,.10); background:rgba(11,12,16,.60) }
.topbar-inner{ display:flex; align-items:center; justify-content:space-between; padding:8px 0; gap:12px; flex-wrap:wrap }
/* ===== TOPBAR LINK STYLE (mais premium) ===== */
.topbar a{
  text-decoration: none;
  position: relative;
  font-weight: 600;
  letter-spacing: .02em;
  transition: color .15s ease;
}

.topbar a::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: -3px;
  width: 100%;
  height: 1px;
  background: rgba(244,247,255,.35);
  transform: scaleX(.4);
  transform-origin: left;
  transition: transform .15s ease, background .15s ease;
}

.topbar a:hover{
  color: rgba(255,196,61,.9);
}

.topbar a:hover::after{
  transform: scaleX(1);
  background: rgba(255,196,61,.9);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:12px 0 }
.brand{ display:flex; align-items:center; gap:12px }
.brand-mark{ width:42px; height:42px; border-radius:10px; border:2px solid rgba(255,196,61,.95); position:relative; box-shadow:0 10px 24px rgba(0,0,0,.4) }
.brand-mark::after{ content:"N"; position:absolute; inset:0; display:grid; place-items:center; font-weight:900; font-size:20px }
.brand-text strong{ display:block; font-size:14px; text-transform:uppercase; letter-spacing:.26em }
.brand-text em{ display:block; font-style:normal; color:var(--muted); font-size:12px; margin-top:1px }

.nav{ display:flex; align-items:center; gap:14px }
.nav a{ padding:10px 10px; border-radius:10px; font-weight:800; letter-spacing:.01em; color:rgba(244,247,255,.90) }
.nav a:hover{ text-decoration:none; background:rgba(244,247,255,.06) }
.nav .nav-cta{
  background:linear-gradient(135deg, rgba(255,196,61,.98), rgba(255,221,118,.90));
  color:#0b0c10;
  padding:10px 14px;
  box-shadow:0 14px 34px rgba(255,196,61,.14);
}
.nav-toggle{
  display:none;
  border:1px solid rgba(244,247,255,.18);
  background:rgba(244,247,255,.06);
  border-radius:10px;
  width:46px;height:46px;
  align-items:center; justify-content:center;
}
.nav-toggle-bars{ width:18px;height:12px; position:relative }
.nav-toggle-bars::before,.nav-toggle-bars::after,.nav-toggle-bars span{
  content:""; position:absolute; left:0; right:0; height:2px; border-radius:999px; background:rgba(244,247,255,.92)
}
.nav-toggle-bars::before{ top:0 }
.nav-toggle-bars::after{ bottom:0 }
.nav-toggle-bars span{ top:50%; transform:translateY(-50%) }

@media (max-width: 980px){
  .nav-toggle{ display:flex }
  .nav{
    position:fixed; inset:110px 12px auto 12px;
    background:rgba(15,18,26,.96);
    border:1px solid rgba(244,247,255,.16);
    border-radius:10px;
    padding:14px;
    box-shadow:var(--shadow);
    flex-direction:column; align-items:stretch; gap:6px;
    transform:translateY(-10px); opacity:0; pointer-events:none;
    transition:opacity .18s ease, transform .18s ease;
  }
  .nav.is-open{ opacity:1; transform:translateY(0); pointer-events:auto }
  .nav a{ padding:12px 14px }
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 18px;
  border-radius:10px; /* menos arredondado (Starbucks-like) */
  border:1px solid rgba(244,247,255,.14);
  background:rgba(244,247,255,.06);
  color:var(--text);
  font-weight:900;
  letter-spacing:.02em;
  cursor:pointer;
  text-decoration:none!important;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{ transform:translateY(-1px); background:rgba(244,247,255,.09); border-color:rgba(244,247,255,.20) }
.btn:focus-visible{ outline:2px solid rgba(255,196,61,.7); outline-offset:2px }
.btn-gold{ background:linear-gradient(135deg, rgba(255,196,61,.98), rgba(255,221,118,.90)); color:#0b0c10; border-color:rgba(255,196,61,.55) }
.btn-ghost{ background:transparent }

/* Hero: Starbucks-style split, but dark + aggressive */
.hero-split{
  position:relative;
  border-bottom:1px solid rgba(244,247,255,.10);
}
.hero-split .wrap{
  display:grid;
  grid-template-columns: 1fr 1fr;
  min-height: clamp(520px, 70vh, 760px);
}
@media (max-width: 980px){ .hero-split .wrap{ grid-template-columns:1fr; min-height:auto } }
.hero-split .copy{
  padding: clamp(34px, 5vw, 64px);
  display:flex; flex-direction:column; justify-content:center;
  background:linear-gradient(180deg, rgba(15,18,26,.92), rgba(11,12,16,.96));
}
.hero-split h1{
  font-size:var(--h1);
  line-height:1.02;
  margin:12px 0 12px;
  text-transform:uppercase;
  letter-spacing:-.03em;
}
.hero-split .lead{ font-size:var(--lead); color:rgba(244,247,255,.82); max-width:60ch }
.hero-split .actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:18px }
.hero-split .badges{ display:flex; gap:10px; flex-wrap:wrap; margin-top:18px }
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:8px; /* não é pílula */
  border:1px solid rgba(244,247,255,.14);
  background:rgba(244,247,255,.05);
  color:rgba(244,247,255,.86);
  font-weight:900;
  letter-spacing:.03em;
  text-transform:uppercase;
  font-size:12px;
}
.hero-split .media{
  position:relative;
  overflow:hidden;
}
.hero-split .media img{ width:100%; height:100%; object-fit:cover; filter:contrast(1.06) saturate(1.08) }
.hero-split .media::after{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(11,12,16,.75) 0%, rgba(11,12,16,.30) 35%, rgba(0,0,0,.55) 100%),
    linear-gradient(180deg, rgba(0,0,0,.20) 0%, rgba(0,0,0,.65) 100%);
}

/* Starbucks-like promo modules (alternating image/text blocks) */
.promo-stack{ padding: clamp(28px, 4vw, 56px) 0 }
.promo{
  display:grid;
  grid-template-columns: 1fr 1fr;
  border-radius:var(--radius2);
  overflow:hidden;
  border:1px solid rgba(244,247,255,.14);
  background:rgba(18,24,39,.92);
  box-shadow:0 18px 60px rgba(0,0,0,.35);
  margin-bottom:16px;
}
.promo.reverse{ direction:rtl }
.promo.reverse > *{ direction:ltr }
@media (max-width: 980px){ .promo{ grid-template-columns:1fr } .promo.reverse{ direction:ltr } }
.promo .p-media{ position:relative; min-height: 360px; }
.promo .p-media img{ width:100%; height:100%; object-fit:cover }
.promo .p-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.70) 100%);
}
.promo .p-copy{
  padding: clamp(22px, 3vw, 40px);
  display:flex; flex-direction:column; justify-content:center;
}
.promo .p-copy h2{
  font-size:clamp(26px, 3.2vw, 44px);
  margin:10px 0 10px;
  text-transform:uppercase;
}
.promo .p-copy p{ margin:0; color:rgba(244,247,255,.80); max-width:62ch }
.promo .p-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:16px }

/* Sections */
.section{ padding: clamp(44px, 6vw, 84px) 0 }
.section-title{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:18px; flex-wrap:wrap }
.section-title h2{ font-size:var(--h2); margin:0; text-transform:uppercase; letter-spacing:-.01em }
.section-title p{ margin:0; color:var(--muted); max-width:72ch }

/* Menu list */
.menu-grid{ display:grid; gap:12px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (max-width: 900px){ .menu-grid{ grid-template-columns:1fr } }
.menu-item{
  padding:16px;
  border-radius:10px;
  border:1px solid rgba(244,247,255,.12);
  background:rgba(244,247,255,.04);
  display:grid;
  grid-template-columns: 1fr auto;
  gap:10px 14px;
}
.menu-item:hover{ border-color:rgba(244,247,255,.20); background:rgba(244,247,255,.06) }
.menu-item h3{ margin:0; font-size:18px; text-transform:uppercase }
.menu-item p{ margin:0; color:var(--muted) }
.price{ font-family:var(--mono); font-weight:900; font-size:14px; color:rgba(255,221,118,.95); white-space:nowrap; }
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:8px; /* quadrado/retangular */
  border:1px solid rgba(255,196,61,.26);
  background:rgba(255,196,61,.10);
  color:rgba(255,221,118,.98);
  font-weight:950;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:11px;
}
.menu-meta{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-top:10px }

/* Gallery grid like Batel's "Gastronomia" */
.gallery{
  display:grid;
  grid-template-columns: repeat(6, 1fr);
  gap:10px;
}
.gallery figure{
  margin:0;
  position:relative;
  border-radius:10px;
  overflow:hidden;
  border:1px solid rgba(244,247,255,.12);
  background:rgba(244,247,255,.04);
  min-height:160px;
}
.gallery img{ width:100%; height:100%; object-fit:cover; transform:scale(1.02); filter:contrast(1.03) saturate(1.06) }
.gallery figcaption{
  position:absolute; inset:auto 0 0 0;
  padding:12px 12px;
  background:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.72) 100%);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:12px;
}
.gallery figure:nth-child(1){ grid-column: span 2; grid-row: span 2; min-height:340px }
.gallery figure:nth-child(2){ grid-column: span 2; min-height:165px }
.gallery figure:nth-child(3){ grid-column: span 2; min-height:165px }
.gallery figure:nth-child(4){ grid-column: span 3; min-height:220px }
.gallery figure:nth-child(5){ grid-column: span 3; min-height:220px }
.gallery figure:nth-child(6){ grid-column: span 6; min-height:240px }
@media (max-width: 980px){
  .gallery{ grid-template-columns:1fr; }
  .gallery figure{ grid-column:auto !important; grid-row:auto !important; min-height:220px }
}

/* CTA strip */
.cta-strip{
  border-top:1px solid rgba(244,247,255,.10);
  border-bottom:1px solid rgba(244,247,255,.10);
  background:
    radial-gradient(900px 520px at 10% 0%, rgba(255,196,61,.12), transparent 55%),
    linear-gradient(180deg, rgba(15,18,26,.92), rgba(11,12,16,.96));
}
.cta-inner{ display:flex; align-items:center; justify-content:space-between; gap:18px; padding:22px 0; flex-wrap:wrap }
.cta-inner h3{ margin:0; text-transform:uppercase }
.cta-inner p{ margin:0; color:var(--muted) }

/* Page hero */
.page-hero{ padding:46px 0 24px }
.breadcrumb{ display:flex; gap:8px; flex-wrap:wrap; color:rgba(244,247,255,.72); font-weight:800 }
.page-hero h1{ margin:12px 0 10px; font-size:clamp(34px, 4.2vw, 54px); line-height:1.05; text-transform:uppercase }
.page-hero p{ margin:0; color:var(--muted); max-width:78ch }

/* Cards */
.grid{ display:grid; gap:16px }
.grid.cols-2{ grid-template-columns: repeat(2, minmax(0, 1fr)) }
.grid.cols-3{ grid-template-columns: repeat(3, minmax(0, 1fr)) }
@media (max-width: 980px){ .grid.cols-2,.grid.cols-3{ grid-template-columns:1fr } }
.card{
  background:linear-gradient(180deg, rgba(18,24,39,.96), rgba(15,18,26,.96));
  border:1px solid rgba(244,247,255,.14);
  border-radius:var(--radius2);
  box-shadow:0 12px 40px rgba(0,0,0,.35);
  overflow:hidden;
}
.card-pad{ padding:18px }

/* Forms */
form{ margin:0 }
.field{ display:grid; gap:8px }
.label{ font-weight:900; letter-spacing:.04em; text-transform:uppercase; font-size:12px; color:rgba(244,247,255,.80) }
input, select, textarea{
  font: inherit;
  color:var(--text);
  background:rgba(244,247,255,.05);
  border:1px solid rgba(244,247,255,.16);
  border-radius:10px;
  padding:12px 14px;
}
textarea{ min-height:120px; resize:vertical }
input:focus, select:focus, textarea:focus{ outline:2px solid rgba(255,196,61,.55); outline-offset:2px }
.form-grid{ display:grid; gap:12px; grid-template-columns: repeat(2, minmax(0, 1fr)) }
@media (max-width: 900px){ .form-grid{ grid-template-columns:1fr } }
.form-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:12px }
.form-msg{ margin:10px 0 0; color:rgba(244,247,255,.78); min-height:1.2em }
.form-msg.is-ok{ color:rgba(61,220,151,.92) }
.form-msg.is-bad{ color:rgba(255,77,77,.92) }

/* Footer */
.site-footer{ border-top:1px solid rgba(244,247,255,.12); padding:48px 0 28px; background:linear-gradient(180deg, rgba(11,12,16,.96), rgba(9,10,14,.98)) }
.footer-grid{ display:grid; grid-template-columns: 1.2fr 1fr 1fr 1.2fr; gap:18px }
@media (max-width: 980px){ .footer-grid{ grid-template-columns:1fr } }
.footer-col h3{ margin:0 0 10px; text-transform:uppercase; letter-spacing:.14em; font-size:12px; color:rgba(244,247,255,.80) }
.footer-list{ list-style:none; padding:0; margin:0; display:grid; gap:10px }
.footer-brand{ display:flex; gap:12px; align-items:flex-start; margin-bottom:14px }
.footer-bottom{ display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; margin-top:26px; padding-top:18px; border-top:1px solid rgba(244,247,255,.10) }

/* Toast */
.toast{
  position:fixed; left:50%; bottom:18px;
  transform:translateX(-50%) translateY(20px);
  opacity:0; pointer-events:none;
  padding:12px 14px;
  border-radius:10px;
  border:1px solid rgba(244,247,255,.18);
  background:rgba(15,18,26,.96);
  box-shadow:0 12px 40px rgba(0,0,0,.35);
  transition: opacity .18s ease, transform .18s ease;
  max-width:min(640px, calc(100% - 24px));
}
.toast.is-show{ opacity:1; transform:translateX(-50%) translateY(0) }


/* Menu filters: retangular e firme */
.filter-btn{
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(244,247,255,.16);
  background:rgba(244,247,255,.04);
  color:rgba(244,247,255,.90);
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  cursor:pointer;
}
.filter-btn[aria-pressed="true"]{
  background:rgba(255,196,61,.14);
  border-color:rgba(255,196,61,.32);
  color:rgba(255,221,118,.98);
}


/* =========================================================
   v4 OVERRIDES — "Rede grande / Starbucks-like"
   Objetivo: FLAT, editorial, módulos sólidos, sem glassmorphism,
   sem borda brilhante, sem pílulas, cantos discretos, muito respiro.
   ========================================================= */

:root{
  --radius: 10px;
  --radius2: 12px;
  --shadow: none;
  --panel: #0f121a;
  --panel2: #0b0c10;
  --line: rgba(244,247,255,.10);
}

/* Fundo mais limpo (menos efeitos) */
body{
  background: var(--bg);
}

/* Remove “vidro” do header e exageros */
.site-header{
  background: rgba(11,12,16,.98);
  backdrop-filter: none;
  border-bottom: 1px solid rgba(244,247,255,.10);
}
.site-header.is-elevated{ box-shadow: none; }

.topbar{ background: rgba(11,12,16,.98); }

/* Links de navegação: simples, sem “capsula” */
.nav a{
  border-radius: 8px;
  background: transparent;
}
.nav a:hover{
  background: rgba(244,247,255,.06);
}

/* Botões: retangulares e “firmes” */
.btn{
  border-radius: 8px;
  box-shadow: none;
}
.btn:hover{ transform: none; }

/* Tags/badges: sem pílula (visual de rede grande) */
.pill, .badge{
  border-radius: 6px;
  background: transparent;
  border: 1px solid rgba(244,247,255,.14);
  color: rgba(244,247,255,.90);
  letter-spacing: .10em;
}
.badge{
  border-color: rgba(255,196,61,.40);
  color: rgba(255,221,118,.98);
}

/* HERO: tira o “soft gradient” e deixa editorial + impacto */
.hero-split .copy{
  background: transparent;
}
.hero-split{
  border-bottom: 1px solid rgba(244,247,255,.10);
}
.hero-split .media::after{
  background:
    linear-gradient(90deg, rgba(11,12,16,.92) 0%, rgba(11,12,16,.55) 35%, rgba(0,0,0,.72) 100%);
}
.hero-split h1{
  letter-spacing: -.02em;
}

/* PROMO MODULES: blocos sólidos, estilo Starbucks (sem brilho) */
.promo-stack{ padding: 40px 0; }
.promo{
  border-radius: 12px;
  border: 1px solid rgba(244,247,255,.10);
  box-shadow: none;
  background: rgba(18,24,39,.55);
}
.promo .p-media::after{ display:none; }
.promo .p-copy h2{
  letter-spacing: -.01em;
}
.promo .p-copy p{
  color: rgba(244,247,255,.78);
}

/* Cards e itens do menu: flat */
.card, .menu-item{
  border-radius: 12px;
  box-shadow: none;
  background: rgba(244,247,255,.03);
  border: 1px solid rgba(244,247,255,.10);
}
.menu-item:hover{ background: rgba(244,247,255,.05); }

/* CTA strip: flat */
.cta-strip{
  background: rgba(18,24,39,.55);
  border-top: 1px solid rgba(244,247,255,.10);
  border-bottom: 1px solid rgba(244,247,255,.10);
}

/* Gallery: flat e com menos rounding */
.gallery figure{
  border-radius: 12px;
  box-shadow: none;
}
.gallery figcaption{
  background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.78) 100%);
}

/* Inputs: flat */
input, select, textarea{
  border-radius: 10px;
  background: rgba(244,247,255,.03);
  border: 1px solid rgba(244,247,255,.12);
}

/* Footer: flat */
.site-footer{
  background: rgba(11,12,16,.98);
}

/* Ajuste de espaçamento (mais respiro) */
.section{ padding: 72px 0; }
.section-title{ margin-bottom: 22px; }


/* ===== MOBILE COMPATIBILITY FIXES (sem alterar desktop) ===== */
body{ overflow-x:hidden; }
@media (max-width: 980px){
  .container{ width:min(var(--container), calc(100% - 32px)); }
  .topbar-inner{ align-items:flex-start; }
  .topbar-right{ width:100%; }
  .header-inner{
    align-items:center;
    gap:12px;
    padding:10px 0;
  }
  .brand{ min-width:0; }
  .brand-text{ min-width:0; }
  .brand-text strong,
  .brand-text em{
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .nav{
    position:absolute;
    top:calc(100% + 8px);
    left:12px;
    right:12px;
    inset:auto 12px auto 12px;
    max-height:calc(100svh - 140px);
    overflow:auto;
  }
  .nav a,
  .nav .nav-cta{ width:100%; }
  .hero-split .copy{ padding:28px 16px 26px; }
  .hero-split .actions,
  .hero-split .badges,
  .promo .p-actions,
  .form-actions,
  .cta-inner{
    flex-direction:column;
    align-items:stretch;
  }
  .hero-split .actions .btn,
  .promo .p-actions .btn,
  .form-actions .btn,
  .cta-inner .btn{ width:100%; }
  .menu-toolbar > *{ width:100%; }
  .search{
    min-width:0 !important;
    width:100%;
    justify-content:stretch !important;
  }
  .search input{ flex:1 1 auto; min-width:0; width:100% !important; }
  .menu-item{ grid-template-columns:1fr; }
  .menu-item .right{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
  dialog#menu-modal{
    width:min(100% - 24px, 680px);
    margin:auto;
  }
}

@media (max-width: 640px){
  .topbar-left .tiny{ display:block; line-height:1.45; }
  .hero-split h1{ font-size:clamp(2rem, 11vw, 3rem); }
  .page-hero{ padding:34px 0 18px; }
  .page-hero h1{ font-size:clamp(30px, 10vw, 42px); }
  .section{ padding:56px 0; }
}

body.menu-open{overflow:hidden}
