/* ============================================================
   CONFRARIA DA CARNE PREMIUM — steakhouse / parrilla
   Warm ember aesthetic
   ============================================================ */
:root{
  --char:#15100c;
  --char-2:#1c140e;
  --char-3:#120d09;
  --surface:#231910;
  --surface-2:#2c2015;
  --surface-3:#37281a;
  --line:rgba(244,235,221,.12);
  --line-strong:rgba(244,235,221,.22);
  --cream:#f4ebdd;
  --cream-dim:#c8b6a1;
  --cream-mute:#9a8973;
  --ember:#e8862e;
  --ember-2:#f4a73c;
  --ember-deep:#b9531a;
  --red:#d8474a;
  --red-soft:#c63c40;
  --red-deep:#8b1e22;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
  font-synthesis:none;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  background:var(--char);
  color:var(--cream);
  font-family:"Archivo",system-ui,sans-serif;
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
@media(max-width:640px){.wrap{padding:0 18px}}

/* ---- type ---- */
.display{font-family:"Anton",sans-serif;font-weight:400;line-height:.92;letter-spacing:.005em;text-transform:uppercase}
.cond{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.04em}
.eyebrow{
  font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.32em;font-size:.74rem;color:var(--ember-2);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:30px;height:1px;background:linear-gradient(90deg,transparent,var(--ember))}
.eyebrow.center::after{content:"";width:30px;height:1px;background:linear-gradient(90deg,var(--ember),transparent)}
.section-title{
  font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.01em;line-height:1.02;
  font-size:clamp(2.1rem,5.2vw,3.7rem);margin:.35em 0 .2em;
}
.section-title em{font-style:normal;color:var(--red)}
.lead{color:var(--cream-dim);font-size:1.06rem;max-width:60ch;text-wrap:pretty}

/* ---- buttons ---- */
.btn{
  --bg:var(--ember);--fg:#1a1006;
  display:inline-flex;align-items:center;gap:.6em;
  font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.12em;font-size:.86rem;
  padding:.95em 1.7em;border-radius:3px;
  background:var(--bg);color:var(--fg);border:1px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  box-shadow:0 10px 30px -12px rgba(232,134,46,.6);
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 38px -12px rgba(232,134,46,.7)}
.btn svg{width:1.15em;height:1.15em}
.btn.ghost{--bg:transparent;--fg:var(--cream);border-color:var(--line-strong);box-shadow:none;backdrop-filter:blur(4px)}
.btn.ghost:hover{border-color:var(--ember);color:var(--ember-2);box-shadow:none}
.btn.wa{--bg:var(--red-soft);--fg:#fff;box-shadow:0 10px 30px -12px rgba(198,60,64,.5)}
.btn.wa:hover{box-shadow:0 16px 38px -12px rgba(198,60,64,.65)}

/* ============================================================ NAV */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;transition:padding .35s var(--ease),background .35s,backdrop-filter .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  padding:11px 28px;background:rgba(18,13,9,.86);
  backdrop-filter:blur(14px) saturate(1.2);border-bottom-color:var(--line);
}
.nav-logo{display:flex;align-items:center;gap:12px}
.nav-logo img{height:100px;width:auto;transition:height .35s var(--ease)}
.nav.scrolled .nav-logo img{height:70px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{
  font-family:"Oswald",sans-serif;font-weight:500;text-transform:uppercase;
  letter-spacing:.13em;font-size:.82rem;color:var(--cream-dim);position:relative;padding:4px 0;
  transition:color .25s;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--ember);transition:width .3s var(--ease)}
.nav-links a:hover{color:var(--cream)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-burger{display:none;width:42px;height:42px;border:1px solid var(--line-strong);border-radius:4px;background:rgba(0,0,0,.2);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.nav-burger span{width:18px;height:2px;background:var(--cream);transition:.3s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:940px){
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(320px,82vw);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:26px;
    background:linear-gradient(160deg,#1d140d,#120c08);padding:40px;
    transform:translateX(105%);transition:transform .4s var(--ease);
    border-left:1px solid var(--line);box-shadow:-30px 0 60px rgba(0,0,0,.5);
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1.15rem}
  .nav-burger{display:flex}
  .nav .btn.desktop-only{display:none}
}

/* ============================================================ HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 45%;transform:scale(1.06);filter:saturate(1.05) contrast(1.04)}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(10,7,4,.8) 0%,rgba(10,7,4,.42) 38%,transparent 70%),
    linear-gradient(180deg,rgba(18,12,8,.35) 0%,transparent 35%,rgba(18,12,8,.45) 72%,var(--char) 100%);
}
.hero-embers{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:1;pointer-events:none}
.hero-inner{position:relative;z-index:2;width:100%;padding-top:90px;padding-bottom:60px}
.hero-kicker{margin-bottom:22px}
.hero h1{
  font-family:"Anton",sans-serif;text-transform:uppercase;line-height:.9;
  font-size:clamp(2.5rem,6.4vw,5rem);letter-spacing:.004em;
  text-shadow:0 6px 40px rgba(0,0,0,.5);
}
.hero h1 .fire{
  background:linear-gradient(180deg,#ffd27a 0%,var(--ember-2) 40%,var(--red-soft) 95%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px 24px rgba(232,134,46,.35));
}
.hero p.tag{margin-top:24px;font-size:clamp(1.05rem,2vw,1.32rem);color:var(--cream-dim);max-width:46ch;text-wrap:pretty}
.hero-actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:38px}
.hero-meta{
  position:absolute;left:0;right:0;bottom:26px;z-index:2;
  display:flex;gap:34px;flex-wrap:wrap;
  font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.14em;
  font-size:.74rem;color:var(--cream-mute);
}
.hero-meta b{color:var(--ember-2);font-weight:600}
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--cream-mute);font-family:"Oswald";font-size:.66rem;letter-spacing:.3em;text-transform:uppercase}
.scroll-cue .dot{width:1px;height:34px;background:linear-gradient(var(--ember),transparent);animation:cue 2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media(max-width:640px){.hero-meta{display:none}.scroll-cue{display:none}}

/* ============================================================ SECTION base */
.section{position:relative;padding:clamp(70px,9vw,130px) 0}
.section.tight{padding:clamp(48px,6vw,80px) 0}
.ribbon{height:2px;width:100%;background:linear-gradient(90deg,transparent,var(--ember-deep),var(--ember),var(--ember-deep),transparent);opacity:.45}

/* subtle section embers (extra ambience) */
.sect-embers{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0;pointer-events:none;opacity:.65}
.story .wrap,.reserva .wrap,.footer .wrap{position:relative;z-index:1}
.footer{position:relative;overflow:hidden}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================================================ HISTÓRIA */
.story{background:var(--char-2);position:relative;overflow:hidden}
.story-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,72px);align-items:center}
.story-copy p{margin-top:1.1em;color:var(--cream-dim)}
.story-copy p.kick{color:var(--cream);font-size:1.18rem;font-weight:500}
.story-signature{margin-top:30px;font-family:"Oswald";text-transform:uppercase;letter-spacing:.18em;font-size:.82rem;color:var(--ember-2)}
.story-media{position:relative}
.story-media .frame{position:relative;border-radius:6px;overflow:hidden;border:1px solid var(--line);box-shadow:0 40px 80px -40px rgba(0,0,0,.8)}
.story-media .frame img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.story-media .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(18,12,8,.5))}
.story-badge{
  position:absolute;bottom:-26px;left:-26px;z-index:3;
  background:linear-gradient(150deg,var(--surface-2),var(--char-3));border:1px solid var(--line-strong);
  border-radius:6px;padding:18px 22px;box-shadow:0 24px 50px -20px rgba(0,0,0,.8);text-align:center;
}
.story-badge .y{font-family:"Anton";font-size:2.5rem;color:var(--ember-2);line-height:1}
.story-badge .l{font-family:"Oswald";text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;color:var(--cream-dim);margin-top:4px}
.timeline{display:flex;gap:0;margin-top:46px;flex-wrap:wrap}
.tl-item{flex:1;min-width:150px;padding:20px 22px;border-left:1px solid var(--line);position:relative}
.tl-item:first-child{border-left:0}
.tl-item .yr{font-family:"Anton";font-size:1.7rem;color:var(--red)}
.tl-item .tx{color:var(--cream-dim);font-size:.92rem;margin-top:4px}
@media(max-width:860px){.story-grid{grid-template-columns:1fr}.story-media{order:-1;max-width:420px}.story-badge{left:auto;right:-14px}}

/* ============================================================ FEATURES */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:14px}
.feature{
  background:linear-gradient(165deg,var(--surface),var(--char-3));
  border:1px solid var(--line);border-radius:7px;padding:30px 28px 32px;position:relative;overflow:hidden;
  transition:border-color .35s,transform .35s var(--ease);
}
.feature:hover{border-color:var(--line-strong);transform:translateY(-4px)}
.feature::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--ember),transparent);opacity:0;transition:opacity .35s}
.feature:hover::before{opacity:1}
.feature .ic{width:46px;height:46px;display:flex;align-items:center;justify-content:center;border:1px solid var(--ember);border-radius:50%;color:var(--ember-2);margin-bottom:18px}
.feature .ic svg{width:24px;height:24px}
.feature h3{font-family:"Oswald";text-transform:uppercase;letter-spacing:.04em;font-size:1.22rem;font-weight:600}
.feature p{color:var(--cream-dim);font-size:.95rem;margin-top:8px}
@media(max-width:780px){.features{grid-template-columns:1fr}}

/* ============================================================ CARDÁPIO */
.menu-head{text-align:center;display:flex;flex-direction:column;align-items:center}
.menu-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:30px 0 8px}
.menu-tab{
  font-family:"Oswald";text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;font-weight:500;
  padding:.6em 1.15em;border:1px solid var(--line);border-radius:40px;color:var(--cream-dim);cursor:pointer;
  background:transparent;transition:.25s;
}
.menu-tab:hover{color:var(--cream);border-color:var(--line-strong)}
.menu-tab.active{background:var(--ember);color:#1a1006;border-color:var(--ember);font-weight:600}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:40px;align-items:start}
.menu-card{
  background:linear-gradient(170deg,var(--surface) 0%,var(--char-3) 100%);
  border:1px solid var(--line);border-radius:8px;padding:30px 30px 34px;position:relative;
}
.menu-card.span2{grid-column:1/-1}
.menu-card h3{
  font-family:"Oswald";text-transform:uppercase;letter-spacing:.05em;font-weight:600;
  font-size:1.5rem;display:flex;align-items:center;gap:12px;
}
.menu-card h3 .gf{font-family:"Oswald";font-size:.6rem;letter-spacing:.14em;background:var(--red-deep);color:var(--cream);padding:.35em .7em;border-radius:30px;font-weight:600}
.menu-card .sub{font-family:"Oswald";text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--ember-2);margin-top:4px}
.menu-card .desc{color:var(--cream-mute);font-size:.88rem;margin-top:6px}
.menu-list{margin-top:18px}
.mrow{display:flex;align-items:baseline;gap:10px;padding:11px 0;border-bottom:1px solid rgba(244,235,221,.07)}
.mrow:last-child{border-bottom:0}
.mrow .nm{font-weight:500;color:var(--cream)}
.mrow .nm small{display:block;color:var(--cream-mute);font-size:.82rem;font-weight:400;letter-spacing:0;text-transform:none}
.mrow .dots{flex:1;border-bottom:1px dotted rgba(244,235,221,.25);transform:translateY(-4px)}
.mrow .pr{font-family:"Oswald";font-weight:600;color:var(--ember-2);font-size:1.05rem;white-space:nowrap}
.mrow.signature .nm{color:#fff}
.mrow.signature .pr{color:var(--red)}
.star{color:var(--red);font-size:.7em;vertical-align:middle;margin-left:6px}
/* price-grid cards (multi column) */
.mtable{margin-top:14px}
.mtable .thead{display:grid;gap:8px;font-family:"Oswald";text-transform:uppercase;letter-spacing:.08em;font-size:.68rem;color:var(--cream-mute);padding-bottom:8px;border-bottom:1px solid var(--line)}
.mtable .trow{display:grid;gap:8px;padding:10px 0;border-bottom:1px solid rgba(244,235,221,.07);align-items:center}
.mtable .trow:last-child{border-bottom:0}
.mtable .trow .nm{font-weight:500}
.mtable .trow .c{font-family:"Oswald";font-weight:600;color:var(--ember-2);text-align:right}
.mtable.cols2 .thead,.mtable.cols2 .trow{grid-template-columns:1fr 70px 70px}
.mtable.cols3 .thead,.mtable.cols3 .trow{grid-template-columns:1fr 64px 64px 64px}
.mtable .thead .c{text-align:right}
.mtable .trow.signature .nm{color:#fff}
.mtable .trow.signature .c{color:var(--red)}
.accomp{margin-top:18px;padding:16px 18px;background:rgba(0,0,0,.22);border:1px solid var(--line);border-radius:6px}
.accomp .t{font-family:"Oswald";text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--ember-2);margin-bottom:6px}
.accomp p{color:var(--cream-dim);font-size:.88rem;text-wrap:pretty}
.menu-note{text-align:center;color:var(--cream-mute);font-size:.85rem;margin-top:26px;font-style:italic}
@media(max-width:780px){.menu-grid{grid-template-columns:1fr}.menu-card.span2{grid-column:auto}}

/* ============================================================ RODÍZIO band */
.rodizio{position:relative;overflow:hidden;background:var(--char-3)}
.rodizio-bg{position:absolute;inset:0;z-index:0}
.rodizio-bg img{width:100%;height:100%;object-fit:cover;opacity:.32;filter:saturate(1.1)}
.rodizio-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 120% at 50% 0%,rgba(232,134,46,.16),transparent 60%),linear-gradient(0deg,var(--char-3),rgba(18,12,8,.6))}
.rodizio-embers{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:1;pointer-events:none}
.rodizio-inner{position:relative;z-index:2;text-align:center;display:flex;flex-direction:column;align-items:center}
.rodizio h2{font-family:"Anton";text-transform:uppercase;font-size:clamp(2.6rem,8vw,5.4rem);line-height:.9;margin:14px 0}
.rodizio .price-tag{display:inline-flex;align-items:baseline;gap:6px;margin:8px 0 4px}
.rodizio .price-tag .cur{font-family:"Oswald";font-weight:600;font-size:1.4rem;color:var(--ember-2)}
.rodizio .price-tag .val{font-family:"Anton";font-size:clamp(3.4rem,11vw,6.2rem);line-height:1;background:linear-gradient(180deg,#ffd27a,var(--ember));-webkit-background-clip:text;background-clip:text;color:transparent}
.rodizio .incl{color:var(--cream-dim);max-width:54ch;margin:14px auto 0;font-size:1.05rem;text-wrap:pretty}
.rodizio .fine{margin-top:10px;font-family:"Oswald";text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;color:var(--cream-mute)}

/* ============================================================ GALERIA */
.gallery{columns:4;column-gap:14px}
.gallery .gitem{break-inside:avoid;margin-bottom:14px;position:relative;border-radius:6px;overflow:hidden;cursor:pointer;border:1px solid var(--line)}
.gallery .gitem img{width:100%;transition:transform .6s var(--ease),filter .4s;filter:saturate(1.02)}
.gallery .gitem::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(18,12,8,.55));opacity:0;transition:opacity .4s}
.gallery .gitem:hover img{transform:scale(1.06)}
.gallery .gitem:hover::after{opacity:1}
.gallery .gitem .zoom{position:absolute;right:12px;bottom:12px;width:34px;height:34px;border-radius:50%;background:rgba(20,14,9,.7);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;color:var(--cream);opacity:0;transform:translateY(6px);transition:.4s}
.gallery .gitem:hover .zoom{opacity:1;transform:none}
@media(max-width:1000px){.gallery{columns:3}}
@media(max-width:680px){.gallery{columns:2;column-gap:10px}.gallery .gitem{margin-bottom:10px}}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:90;background:rgba(10,7,4,.94);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:90vw;max-height:86vh;border-radius:6px;box-shadow:0 30px 80px rgba(0,0,0,.7);transform:scale(.96);transition:transform .35s var(--ease)}
.lightbox.open img{transform:none}
.lb-close,.lb-nav{position:absolute;background:rgba(40,28,18,.7);border:1px solid var(--line-strong);color:var(--cream);width:50px;height:50px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.25s}
.lb-close:hover,.lb-nav:hover{background:var(--ember);color:#1a1006}
.lb-close{top:24px;right:24px}
.lb-nav.prev{left:24px;top:50%;transform:translateY(-50%)}
.lb-nav.next{right:24px;top:50%;transform:translateY(-50%)}
@media(max-width:640px){.lb-nav{width:42px;height:42px}.lb-nav.prev{left:10px}.lb-nav.next{right:10px}}

/* ============================================================ RESERVA */
.reserva{background:var(--char-2);position:relative;overflow:hidden}
.reserva-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,70px);align-items:center}
.reserva-copy .lead{margin-top:18px}
.reserva-perks{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:14px}
.reserva-perks li{display:flex;gap:13px;align-items:flex-start;color:var(--cream-dim)}
.reserva-perks li svg{width:20px;height:20px;color:var(--ember-2);flex:none;margin-top:2px}
.form-card{background:linear-gradient(168deg,var(--surface),var(--char-3));border:1px solid var(--line-strong);border-radius:10px;padding:clamp(26px,3vw,38px);box-shadow:0 40px 90px -40px rgba(0,0,0,.8)}
.form-card h3{font-family:"Oswald";text-transform:uppercase;letter-spacing:.04em;font-size:1.5rem;font-weight:600}
.form-card .fsub{color:var(--cream-mute);font-size:.9rem;margin-top:4px;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-family:"Oswald";text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;color:var(--cream-dim);margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;background:rgba(0,0,0,.28);border:1px solid var(--line);border-radius:5px;
  color:var(--cream);font-family:"Archivo";font-size:.98rem;padding:.8em .9em;transition:border-color .25s,box-shadow .25s;
}
.field input::placeholder,.field textarea::placeholder{color:var(--cream-mute)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ember);box-shadow:0 0 0 3px rgba(232,134,46,.16)}
.field select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%23c8b6a1' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right .9em center}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.pax-row{display:flex;gap:8px;flex-wrap:wrap}
.pax{flex:1;min-width:42px;text-align:center;padding:.7em 0;border:1px solid var(--line);border-radius:5px;background:rgba(0,0,0,.22);color:var(--cream-dim);font-family:"Oswald";font-weight:500;cursor:pointer;transition:.2s}
.pax:hover{border-color:var(--line-strong);color:var(--cream)}
.pax.sel{background:var(--ember);color:#1a1006;border-color:var(--ember)}
.form-card .btn{width:100%;justify-content:center;margin-top:8px}
.form-hint{text-align:center;font-size:.78rem;color:var(--cream-mute);margin-top:14px}
.form-hint b{color:var(--ember-2)}
.form-alt{text-align:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--line);font-size:.84rem;color:var(--cream-mute)}
.form-alt a{color:var(--ember-2);font-weight:500;text-decoration:underline;text-underline-offset:3px}
.req{color:var(--red)}

/* slots */
.slot-row{display:flex;gap:8px;flex-wrap:wrap}
.slot{padding:.6em .9em;border:1px solid var(--line);border-radius:5px;background:rgba(0,0,0,.22);color:var(--cream-dim);font-family:"Oswald";font-weight:500;letter-spacing:.04em;cursor:pointer;transition:.2s;font-size:.92rem}
.slot:hover{border-color:var(--line-strong);color:var(--cream)}
.slot.sel{background:var(--ember);color:#1a1006;border-color:var(--ember)}
.slot-empty{color:var(--cream-mute);font-size:.86rem;font-style:italic}

/* validation */
.field.invalid input,.field.invalid textarea{border-color:var(--red);box-shadow:0 0 0 3px rgba(216,71,74,.14)}
.err-msg{display:none;color:var(--red);font-size:.78rem;margin-top:6px}
.field.invalid .err-msg{display:block}
.slot-field.invalid .slot-row{outline:1px solid var(--red);outline-offset:6px;border-radius:6px}

/* location reminder card */
.loc-reminder{margin-top:30px;border:1px solid var(--line-strong);border-radius:10px;overflow:hidden;background:linear-gradient(160deg,var(--surface),var(--char-3))}
.loc-reminder .lr-head{display:flex;align-items:center;gap:10px;padding:14px 18px;background:rgba(0,0,0,.25);border-bottom:1px solid var(--line)}
.loc-reminder .lr-head svg{width:18px;height:18px;color:var(--ember-2)}
.loc-reminder .lr-head span{font-family:"Oswald";text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--cream)}
.loc-reminder .lr-body{padding:16px 18px}
.lr-line{display:flex;gap:12px;align-items:flex-start;padding:7px 0}
.lr-line svg{width:18px;height:18px;color:var(--ember-2);flex:none;margin-top:2px}
.lr-line .t{font-size:.93rem;color:var(--cream);line-height:1.45}
.lr-line .t small{display:block;color:var(--cream-mute);font-size:.8rem}
.lr-cta{display:inline-flex;align-items:center;gap:7px;margin-top:10px;font-family:"Oswald";text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:var(--ember-2);border:1px solid var(--line-strong);border-radius:40px;padding:.55em 1em;transition:.25s}
.lr-cta:hover{border-color:var(--ember);background:rgba(232,134,46,.08)}
.lr-cta svg{width:15px;height:15px}

/* confirmation */
.confirm-card{text-align:center}
.confirm-card .ok{width:64px;height:64px;margin:0 auto 18px;border-radius:50%;background:radial-gradient(circle at 50% 35%,rgba(232,134,46,.3),rgba(232,134,46,.08));border:1px solid var(--ember);display:flex;align-items:center;justify-content:center;color:var(--ember-2);animation:pop .5s var(--ease)}
.confirm-card .ok svg{width:32px;height:32px}
@keyframes pop{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.1)}100%{transform:scale(1);opacity:1}}
.confirm-card h3{font-size:1.7rem}
.confirm-card .cmsg{color:var(--cream-dim);margin-top:6px;font-size:.96rem}
.summary{margin-top:22px;text-align:left;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.summary .srow{display:flex;justify-content:space-between;gap:14px;padding:12px 16px;border-bottom:1px solid rgba(244,235,221,.07);font-size:.94rem}
.summary .srow:last-child{border-bottom:0}
.summary .srow .k{color:var(--cream-mute);font-family:"Oswald";text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;align-self:center}
.summary .srow .v{color:var(--cream);font-weight:500;text-align:right}
.status-pill{display:inline-flex;align-items:center;gap:8px;margin-top:18px;padding:.5em 1em;border-radius:40px;background:rgba(232,134,46,.1);border:1px solid rgba(232,134,46,.4);color:var(--ember-2);font-size:.82rem}
.status-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--ember);box-shadow:0 0 0 0 rgba(232,134,46,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(232,134,46,.5)}70%{box-shadow:0 0 0 8px rgba(232,134,46,0)}100%{box-shadow:0 0 0 0 rgba(232,134,46,0)}}
/* outcome variants */
.confirm-card .ok.full{background:radial-gradient(circle at 50% 35%,rgba(216,71,74,.3),rgba(216,71,74,.08));border-color:var(--red);color:var(--red)}
.confirm-card .ok.wait{border-color:var(--ember-2);color:var(--ember-2)}
.status-pill.full{background:rgba(216,71,74,.12);border-color:rgba(216,71,74,.45);color:#f0989a}
.status-pill.full .dot{background:var(--red);animation:none}
.confirm-loc{margin-top:20px;text-align:left}
.confirm-actions{display:flex;flex-direction:column;gap:10px;margin-top:22px}
.confirm-actions .btn{width:100%;justify-content:center;margin:0}
.confirm-actions .btn.sm{padding:.8em 1.2em;font-size:.8rem}

/* FLOATING ACTION BUTTON */
.fab{
  position:fixed;right:22px;bottom:22px;z-index:85;display:flex;align-items:center;gap:0;
  height:58px;padding:0;border-radius:30px;overflow:hidden;
  background:linear-gradient(135deg,var(--ember-2),var(--ember-deep));
  color:#1a1006;box-shadow:0 14px 34px -10px rgba(232,134,46,.7);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),padding .35s var(--ease);
  cursor:pointer;
}
.fab::before{content:"";position:absolute;inset:0;border-radius:30px;border:2px solid rgba(244,167,60,.5);animation:fabring 2.4s var(--ease) infinite}
@keyframes fabring{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.35);opacity:0}}
.fab .fic{width:58px;height:58px;display:flex;align-items:center;justify-content:center;flex:none}
.fab .fic svg{width:28px;height:28px}
.fab .flabel{font-family:"Oswald";font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.84rem;max-width:0;opacity:0;white-space:nowrap;transition:max-width .35s var(--ease),opacity .3s,padding .35s}
.fab:hover{transform:translateY(-3px);box-shadow:0 20px 40px -10px rgba(232,134,46,.8)}
.fab:hover .flabel{max-width:140px;opacity:1;padding-right:22px}
@media(max-width:640px){.fab{right:16px;bottom:16px;height:54px}.fab .fic{width:54px;height:54px}.fab .flabel{max-width:120px;opacity:1;padding-right:20px;font-size:.8rem}}
@media (prefers-reduced-motion:reduce){.fab::before{display:none}}

@media(max-width:860px){.reserva-grid{grid-template-columns:1fr}.reserva-copy{max-width:560px}}

/* ============================================================ LOCAL */
.local-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.local-info{padding:clamp(30px,4vw,52px);background:linear-gradient(165deg,var(--surface),var(--char-3))}
.local-info h2{font-family:"Oswald";text-transform:uppercase;letter-spacing:.02em;font-size:clamp(1.9rem,4vw,2.7rem);font-weight:600;line-height:1.04}
.info-block{margin-top:26px;display:flex;gap:14px}
.info-block .ic{width:42px;height:42px;flex:none;border:1px solid var(--ember);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--ember-2)}
.info-block .ic svg{width:20px;height:20px}
.info-block .t{font-family:"Oswald";text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--cream-mute);margin-bottom:3px}
.info-block .v{color:var(--cream);font-size:1rem;line-height:1.5}
.info-block .v a{color:var(--ember-2)}
.hours-list{margin-top:8px}
.hours-list .hrow{display:flex;justify-content:space-between;gap:16px;padding:6px 0;border-bottom:1px solid rgba(244,235,221,.07);font-size:.95rem}
.hours-list .hrow:last-child{border-bottom:0}
.hours-list .hrow .d{color:var(--cream-dim)}
.hours-list .hrow .h{font-family:"Oswald";color:var(--cream);letter-spacing:.04em}
.hours-list .hrow.today{color:var(--ember-2)}
.hours-list .hrow.today .d,.hours-list .hrow.today .h{color:var(--ember-2);font-weight:600}
.local-map{position:relative;min-height:380px}
.local-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.3) contrast(1.05) brightness(.92)}
@media(max-width:860px){.local-grid{grid-template-columns:1fr}.local-map{min-height:320px}}

/* ============================================================ FOOTER */
.footer{background:var(--char-3);border-top:1px solid var(--line);padding:64px 0 34px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;align-items:start}
.footer-logo img{height:96px;margin-bottom:18px}
.footer-logo p{color:var(--cream-mute);font-size:.92rem;max-width:34ch}
.footer-col h4{font-family:"Oswald";text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;color:var(--ember-2);margin-bottom:16px}
.footer-col a,.footer-col p{display:block;color:var(--cream-dim);font-size:.94rem;margin-bottom:10px;transition:color .2s}
.footer-col a:hover{color:var(--cream)}
.social{display:flex;gap:12px;margin-top:4px}
.social a{width:44px;height:44px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--cream-dim);transition:.25s}
.social a:hover{border-color:var(--ember);color:var(--ember-2);transform:translateY(-3px)}
.social a svg{width:20px;height:20px}
.footer-bottom{margin-top:48px;padding-top:22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:var(--cream-mute);font-size:.82rem}
@media(max-width:780px){.footer-grid{grid-template-columns:1fr;gap:32px}}

/* toast */
.toast{position:fixed;left:50%;bottom:30px;transform:translate(-50%,140%);z-index:120;background:var(--surface-2);border:1px solid var(--ember);color:var(--cream);padding:14px 22px;border-radius:8px;font-size:.92rem;box-shadow:0 20px 50px rgba(0,0,0,.5);transition:transform .45s var(--ease);max-width:90vw}
.toast.show{transform:translate(-50%,0)}
.toast b{color:var(--ember-2)}

/* ============================================================
   MOBILE PASS — proporção mantida, interface moderna
   ============================================================ */
@media(max-width:640px){
  .wrap{padding:0 18px}
  .nav{padding:14px 18px}
  .nav.scrolled{padding:9px 18px}
  .nav-logo img{height:74px}
  .nav.scrolled .nav-logo img{height:58px}

  /* HERO */
  .hero{min-height:88svh}
  .hero-bg img{object-position:center 42%;transform:scale(1.02)}
  .hero-inner{padding-top:80px;padding-bottom:40px}
  .hero-kicker{margin-bottom:16px}
  .eyebrow{font-size:.66rem;letter-spacing:.24em}
  .eyebrow::before{width:20px}
  .hero h1{font-size:clamp(2rem,8.4vw,2.7rem);line-height:.98}
  .hero p.tag{margin-top:16px;font-size:1rem;max-width:34ch}
  .hero-actions{margin-top:26px;gap:10px}
  .hero-actions .btn{flex:1 1 100%;justify-content:center;padding:1.05em 1.4em}

  /* SECTION rhythm */
  .section{padding:64px 0}
  .section.tight{padding:46px 0}
  .section-title{font-size:clamp(1.95rem,8.5vw,2.6rem)}
  .lead{font-size:1rem}

  /* STORY */
  .story-grid{gap:40px}
  .story-copy p.kick{font-size:1.08rem}
  .story-media{max-width:none;margin:0 auto;width:100%}
  .story-media .frame img{aspect-ratio:4/3.3}
  .story-badge{right:14px;bottom:-18px;left:auto;padding:14px 18px}
  .story-badge .y{font-size:2rem}
  .timeline{margin-top:32px;gap:10px}
  .tl-item{flex:1 1 100%;border-left:0;border-top:1px solid var(--line);padding:14px 0}
  .tl-item:first-child{border-top:0}

  /* MENU */
  .menu-tabs{gap:7px;margin:24px 0 4px}
  .menu-tab{font-size:.74rem;padding:.55em .9em}
  .menu-grid{gap:16px;margin-top:30px}
  .menu-card{padding:24px 20px 26px}
  .menu-card h3{font-size:1.32rem}
  .mtable.cols2 .thead,.mtable.cols2 .trow{grid-template-columns:1fr 54px 54px;gap:6px}
  .mtable.cols3 .thead,.mtable.cols3 .trow{grid-template-columns:1fr 46px 46px 46px;gap:6px}
  .mtable .thead{font-size:.6rem}
  .accomp{padding:14px 14px}
  .mrow .pr{font-size:.98rem}

  /* RODÍZIO */
  .rodizio .incl{font-size:1rem}

  /* GALLERY */
  .gallery{columns:2;column-gap:10px}
  .gallery .gitem{margin-bottom:10px}

  /* RESERVA */
  .reserva-grid{gap:34px}
  .form-card{padding:24px 20px 26px}
  .form-card h3{font-size:1.32rem}

  /* LOCAL */
  .local-info{padding:30px 22px}
  .local-info h2{font-size:1.8rem}
  .info-block{gap:12px}
  .hours-list .hrow{font-size:.9rem}
  .local-map{min-height:280px}

  /* FOOTER */
  .footer{padding:46px 0 26px}
  .footer-logo img{height:66px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:left}
}

/* prevent any unstyled-image blowout as a safety net */
img{height:auto}

/* very small phones */
@media(max-width:380px){
  .hero h1{font-size:1.95rem}
  .mtable.cols3 .thead,.mtable.cols3 .trow{grid-template-columns:1fr 42px 42px 42px}
  .menu-tab{font-size:.7rem;padding:.5em .8em}
}

/* landscape phones / avoid 100svh issues handled by svh */
@media(max-width:640px) and (max-height:520px){
  .hero{min-height:560px}
}
