/* ═══════════════════════════════════════════════════════════════
   SANTA PORCA — bold edition
   Collage · cutouts · neon · cópia de duplo sentido
   ═══════════════════════════════════════════════════════════════ */
:root{
  --bg:#EFEAE0;
  --bg-2:#E4DDD0;
  --ink:#0E0D0C;
  --ink-2:#5A544D;
  --neon:#FF2D8B;
  --neon-2:#FF7AB6;
  --teal:#0F2620;
  --line:rgba(14,13,12,.16);
  --display:'Archivo Black','Helvetica Neue',Helvetica,Arial,sans-serif;
  --serif:'Instrument Serif',Georgia,serif;
  --mono:'Space Mono',ui-monospace,monospace;
  --ui:'Inter',system-ui,-apple-system,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--ui);overflow-x:clip}
body{
  font-size:16px;line-height:1.5;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(14,13,12,.05) 1px, transparent 0);
  background-size:5px 5px;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
sup{font-size:.4em;vertical-align:super;letter-spacing:.05em}
em{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:-.01em}
::selection{background:var(--neon);color:#fff}

/* ─── tape / ticker ─── */
.tape{
  background:var(--ink);color:var(--bg);
  font-family:var(--mono);font-weight:700;text-transform:uppercase;
  font-size:13px;letter-spacing:.06em;
  border-block:1px solid var(--ink);
  overflow:hidden;
}
.tape__track{
  display:flex;gap:32px;white-space:nowrap;
  padding:10px 0;
  animation:tape 50s linear infinite;
  width:max-content;
}
/* Gap entre os 2 sets duplicados → texto entra sempre pelo lado direito da página
   e o loop continua a ser seamless porque set1 == set2. */
.tape__gap{flex-shrink:0;width:100vw}
.tape--neon{background:var(--neon);color:#fff;border-color:var(--neon)}
.tape--neon .tape__track{animation-duration:42s}
.tape--top{position:sticky;top:0;z-index:60}
@keyframes tape{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
@media (prefers-reduced-motion:reduce){.tape__track{animation:none}}

/* ─── nav ─── */
.nav{
  display:flex;align-items:center;gap:24px;
  padding:18px clamp(20px,4vw,48px);
  position:sticky;top:34px;z-index:50;
  background:transparent;
  mix-blend-mode:multiply;
}
.nav__logo{
  font-family:var(--display);
  font-size:22px;line-height:.85;
  letter-spacing:-.02em;
  display:flex;flex-direction:column;
  position:relative;z-index:2;       /* fica acima de qualquer cutout/sticker do hero */
}
.nav__logo span:first-child{display:flex;align-items:flex-start;gap:2px}
.nav__logo--img{display:block;line-height:0}
.nav__logo--img img{
  display:block;
  height:64px;width:auto;
  max-width:min(46vw,260px);
  object-fit:contain;object-position:left center;
}
@media (max-width:760px){
  .nav__logo--img img{height:48px}
}
.nav__links{display:flex;gap:10px;margin-left:auto;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em}
.nav__links a{
  position:relative;
  padding:9px 16px;
  border:1.5px solid currentColor;
  border-radius:999px;
  font-weight:700;
  transition:background .25s cubic-bezier(.2,.8,.2,1),color .25s,border-color .25s,transform .25s;
}
.nav__links a:hover{
  background:var(--ink);color:var(--bg);border-color:var(--ink);
  transform:translateY(-2px);
}
.nav__links a[aria-current="page"]{
  border-color:var(--neon);color:var(--neon);
}
@media (max-width:760px){.nav__links{display:none}}

/* ─── pills ─── */
.pill{
  --pad-y:10px;--pad-x:18px;
  display:inline-flex;align-items:center;gap:10px;
  padding:var(--pad-y) var(--pad-x);
  border:1.5px solid var(--ink);
  border-radius:999px;
  font-family:var(--mono);font-weight:700;font-size:12px;
  text-transform:uppercase;letter-spacing:.1em;
  background:transparent;
  transition:all .35s cubic-bezier(.2,.8,.2,1);
}
.pill:hover{transform:translateY(-2px) rotate(-1deg)}
.pill--neon{border-color:var(--neon);color:var(--neon)}
.pill--neon:hover{background:var(--neon);color:#fff;box-shadow:0 0 0 4px rgba(255,45,139,.18),0 14px 40px -14px rgba(255,45,139,.6)}
.pill--filled{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.pill--filled:hover{background:var(--neon);border-color:var(--neon);color:#fff}
.pill--ghost{background:transparent}
.pill--ghost:hover{background:var(--ink);color:var(--bg)}
.pill--ghost-light{background:transparent;border-color:#fff;color:#fff}
.pill--ghost-light:hover{background:#fff;color:var(--teal)}
.pill--big{--pad-y:14px;--pad-x:22px;font-size:13px}
.pill__flame{color:var(--neon);font-size:14px}
.pill--neon .pill__flame{color:inherit}

/* ═══════════ HERO ═══════════ */
.hero{
  position:relative;
  padding:clamp(40px,8vw,90px) clamp(20px,4vw,48px) clamp(60px,10vw,120px);
  overflow:clip;
  isolation:isolate;
}
.hero__title{
  font-family:var(--display);
  font-size:clamp(72px,18vw,280px);
  line-height:.82;
  letter-spacing:-.04em;
  text-transform:uppercase;
  position:relative;
  z-index:2;
}
.hero__title em{
  font-family:var(--serif);font-style:italic;
  font-weight:400;
  color:var(--neon);
  letter-spacing:-.03em;
  text-shadow:0 0 30px rgba(255,45,139,.3);
}
.line{display:block}
.line-1{padding-left:clamp(0px,2vw,30px)}
.line-2{padding-left:clamp(40px,12vw,180px)}
.line-3{padding-left:clamp(20px,5vw,80px)}

/* hero cutouts */
.cut{position:absolute;transition:transform .8s cubic-bezier(.2,.8,.2,1),filter .5s}
.cut img{width:100%;height:auto;display:block}
.cut-porca{
  top:2%;right:-2%;
  width:clamp(220px,28vw,460px);
  transform:rotate(8deg);z-index:3;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.35)) drop-shadow(0 0 60px rgba(255,45,139,.18));
}
.cut-porca:hover{transform:rotate(-2deg) scale(1.04)}
.cut-tomahawk{
  bottom:6%;right:14%;
  width:clamp(180px,22vw,360px);
  transform:rotate(-14deg);z-index:1;
  filter:drop-shadow(0 26px 40px rgba(0,0,0,.4));
}
.cut-tomahawk:hover{transform:rotate(-4deg) scale(1.05)}
@media (max-width:760px){
  .cut-porca{top:auto;bottom:24%;right:-6%;width:54vw}
  .cut-tomahawk{display:none}
}

/* sticker / manifesto — sempre flutuante (continuous subtle motion) */
.sticker{
  position:absolute;left:clamp(10px,3vw,52px);
  /* alinhado com a linha 2 "EM FORMA" — vive no espaço à esquerda do EM */
  top:clamp(320px,30vw,450px);
  z-index:4;transform:rotate(-8deg);
  transition:transform .6s cubic-bezier(.2,.8,.2,1);
  animation:stickerFloat 7s ease-in-out infinite;
}
.sticker:hover{
  animation-play-state:paused;
  transform:rotate(-2deg) scale(1.04);
}
@keyframes stickerFloat{
  0%,100%{transform:rotate(-8deg) translate3d(0,0,0)}
  25%    {transform:rotate(-7.2deg) translate3d(1.5px,-3px,0)}
  50%    {transform:rotate(-7.6deg) translate3d(0,-6px,0)}
  75%    {transform:rotate(-8.4deg) translate3d(-1.5px,-3px,0)}
}
@media (prefers-reduced-motion:reduce){
  .sticker{animation:none}
}
.sticker__body{
  background:#fff;border:1.5px solid var(--ink);
  padding:12px 13px 9px;width:178px;
  font-family:var(--mono);text-transform:uppercase;
  color:var(--ink);                       /* explícito: texto preto */
  box-shadow:6px 6px 0 var(--ink),0 24px 60px -28px rgba(0,0,0,.45);
}
.hero--dark .sticker__body{color:var(--ink)}  /* override de .hero--dark color:white */
.sticker__head{
  font-size:9.5px;font-weight:700;letter-spacing:.1em;
  line-height:1.3;margin-bottom:10px;text-align:center;
  padding-bottom:8px;border-bottom:1px solid var(--ink);
}
.sticker__head sup{color:var(--neon);font-size:.55em;vertical-align:super;margin-left:1px}
.sticker__list{
  list-style:none;counter-reset:m;
  display:grid;gap:3px;
  font-family:var(--mono);font-size:8.5px;line-height:1.35;
  letter-spacing:.03em;text-transform:none;
  margin-bottom:8px;
}
.sticker__list li{
  counter-increment:m;
  display:grid;grid-template-columns:22px 1fr;gap:6px;align-items:baseline;
}
.sticker__list li::before{
  content:counter(m, upper-roman) ".";
  font-weight:700;color:var(--neon);font-size:8px;letter-spacing:.05em;
}
.sticker__foot{
  font-size:8.5px;letter-spacing:.1em;text-align:center;
  border-top:1px solid var(--ink);padding-top:6px;
}
@media (max-width:760px){.sticker{display:none}}

/* hero floating pills — posicionadas em zonas vazias, longe do título */
.hero .pill[data-rot]{
  position:absolute;z-index:5;
  padding:14px 22px;
  font-size:13px;
}
/* "Mesa para dois?" — em baixo à esquerda (sob o título) */
.hero .pill[data-rot="-3"]{
  left:clamp(20px,5vw,80px);
  bottom:clamp(140px,18vh,210px);
  transform:rotate(-3deg);
}
/* "Tomahawk de 1KG" — à direita, no espaço entre a porca e o tomahawk */
.hero .pill[data-rot="4"]{
  right:clamp(20px,6vw,100px);
  bottom:clamp(180px,22vh,260px);
  transform:rotate(4deg);
}
@media (max-width:760px){
  .hero .pill[data-rot]{position:static;display:inline-flex;margin:8px 8px 0 0;transform:none}
  .hero .pill[data-rot="-3"]{transform:rotate(-3deg)}
  .hero .pill[data-rot="4"]{transform:rotate(4deg)}
}

.hero__foot{
  position:relative;z-index:2;
  margin-top:clamp(40px,6vw,80px);
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  line-height:1.5;
}
.kicker--right{text-align:right}
@media (max-width:540px){.hero__foot{grid-template-columns:1fr}.kicker--right{text-align:left}}

/* ═══════════ SOBRE NÓS — text-first, sem fotos ═══════════ */
.sobre{
  position:relative;
  padding:clamp(80px,10vw,120px) clamp(20px,4vw,48px);
  max-width:1320px;margin:0 auto;
}
.sobre__head{
  display:grid;gap:14px;margin-bottom:clamp(40px,6vw,72px);
}
.sobre__title{
  font-family:var(--display);
  font-size:clamp(48px,9vw,140px);line-height:.85;
  letter-spacing:-.035em;text-transform:uppercase;
}
.sobre__title em{
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:var(--neon);letter-spacing:-.02em;text-transform:none;
}

.sobre__grid{
  display:grid;gap:clamp(20px,2.5vw,32px);
  grid-template-columns:repeat(12,1fr);
  align-items:start;
}

/* Story card — papel branco com sombra dura, ligeira rotação */
.sobre__story{
  grid-column:1 / span 8;
  background:#fff;border:1.5px solid var(--ink);
  padding:clamp(24px,3vw,40px);
  box-shadow:10px 10px 0 var(--ink);
  font-size:16px;line-height:1.55;color:var(--ink-2);
  transform:rotate(-1.5deg);
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.sobre__story:hover{transform:rotate(0)}
.sobre__lead{
  font-family:var(--serif);font-size:clamp(22px,2.6vw,32px);
  line-height:1.18;letter-spacing:-.01em;color:var(--ink);
  margin-bottom:16px;
}
.sobre__lead em{color:var(--neon);font-style:italic}
.sobre__lead b{font-weight:600;color:var(--ink)}
.sobre__story p+p{margin-top:14px}
.sobre__story em{font-family:var(--serif);font-style:italic;color:var(--ink)}
.sobre__story b{font-weight:600;color:var(--ink)}
.sobre__story a{color:var(--neon);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
.sobre__story a:hover{color:var(--ink);background:var(--neon);color:#fff;padding:0 4px}
.sobre__signoff{
  margin-top:24px !important;font-family:var(--mono);font-size:11px;
  text-transform:uppercase;letter-spacing:.14em;color:var(--ink) !important;
}
.sobre__signoff em{font-family:var(--serif);text-transform:none;color:var(--neon)}

/* Stats column — 3 stats + 1 CTA */
.sobre__stats{
  grid-column:9 / span 4;
  display:grid;gap:12px;
}
.stat{
  border:1.5px solid var(--ink);background:#fff;
  padding:18px 20px;display:grid;gap:6px;
  transform:rotate(.6deg);
  transition:transform .35s cubic-bezier(.2,.8,.2,1),background .25s;
}
.stat:nth-child(2){transform:rotate(-.8deg)}
.stat:nth-child(3){transform:rotate(.4deg)}
.stat:hover{transform:rotate(0) translateY(-3px)}
.stat__n{
  font-family:var(--display);font-size:clamp(32px,3.4vw,44px);
  letter-spacing:-.025em;line-height:.9;color:var(--ink);
}
.stat__l{
  font-family:var(--mono);font-size:11px;
  text-transform:uppercase;letter-spacing:.1em;color:var(--ink-2);
  line-height:1.4;
}
.stat__l em{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--neon);text-transform:none;letter-spacing:0}
.stat--cta{background:var(--neon);color:#fff;text-decoration:none;border-color:var(--neon)}
.stat--cta .stat__n,.stat--cta .stat__l{color:#fff}
.stat--cta:hover{background:#fff;color:var(--neon);border-color:var(--ink)}
.stat--cta:hover .stat__n,.stat--cta:hover .stat__l{color:var(--neon)}

@media (max-width:880px){
  .sobre__grid{grid-template-columns:1fr}
  .sobre__story,.sobre__stats{grid-column:1 / -1}
  .sobre__stats{grid-template-columns:1fr 1fr}
}
@media (max-width:540px){
  .sobre__stats{grid-template-columns:1fr}
}

/* ═══════════ MENU ═══════════ */
.menu{padding:clamp(60px,10vw,120px) clamp(20px,4vw,48px);max-width:1320px;margin:0 auto}
.menu__head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:48px}
.eyebrow{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink)}
.eyebrow--inv{color:#fff;opacity:.7}
.menu__title{
  font-family:var(--display);font-size:clamp(40px,7vw,108px);line-height:.85;
  letter-spacing:-.03em;text-transform:uppercase;flex:1;min-width:280px;
}
.menu__title em{color:var(--neon)}

/* editorial preview stage */
.menu__stage{position:relative}
.menu__stage.is-active .menu__list{cursor:none}
.menu__stage.is-active .row{cursor:none}
.menu__list{border-top:1.5px solid var(--ink);position:relative;z-index:2}

/* groups of dishes (homepage destacados) */
.menu__group + .menu__group{margin-top:clamp(40px,5vw,72px)}
.menu__group-title{
  display:flex;align-items:baseline;gap:14px;
  font-family:var(--mono);font-weight:700;font-size:11px;
  text-transform:uppercase;letter-spacing:.14em;color:var(--ink);
  margin-bottom:18px;
}
.menu__group-title::before{content:'';width:18px;height:1.5px;background:var(--neon)}
.menu__group-title em{
  font-family:var(--serif);font-style:italic;font-weight:400;
  text-transform:none;letter-spacing:0;color:var(--ink-2);font-size:16px;
  margin-left:auto;
}
@media (max-width:680px){.menu__group-title em{display:none}}
.row{
  position:relative;
  display:grid;grid-template-columns:60px 1fr auto auto;
  gap:24px;align-items:baseline;
  padding:24px 8px;
  border-bottom:1.5px solid var(--ink);
  cursor:default;
  transition:background .35s,padding .35s,color .35s;
  outline:none;
}
.menu__stage.is-active .row{cursor:none}

/* floating preview card */
.menu__preview{
  position:fixed;
  left:0;top:0;
  width:clamp(240px,26vw,360px);
  pointer-events:none;
  z-index:60;
  margin:0;
  opacity:0;
  transform:translate3d(var(--px,0),var(--py,0),0) scale(.94) rotate(var(--rz,-2deg));
  transition:opacity .45s cubic-bezier(.2,.8,.2,1),transform .6s cubic-bezier(.2,.8,.2,1);
  will-change:transform,opacity;
  mix-blend-mode:normal;
}
.menu__stage.is-active .menu__preview{
  opacity:1;
  transform:translate3d(var(--px,0),var(--py,0),0) scale(1) rotate(var(--rz,-2deg));
}
.menu__preview-frame{
  position:relative;aspect-ratio:4/5;
  overflow:hidden;
  border:1.5px solid var(--ink);
  background:var(--bg-2);
  box-shadow:14px 14px 0 var(--ink),0 30px 80px -20px rgba(0,0,0,.45);
}
.menu__preview-frame img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;
  opacity:0;transform:scale(1.04);
  transition:opacity .22s cubic-bezier(.2,.8,.2,1),transform .65s cubic-bezier(.2,.8,.2,1);
}
.menu__preview-frame img.is-on{opacity:1;transform:scale(1)}
.menu__preview-cap{
  margin-top:10px;
  font-family:var(--mono);font-size:11px;
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--ink);
  display:flex;align-items:center;gap:8px;
}
.menu__preview-cap::before{
  content:'';display:inline-block;width:18px;height:1.5px;background:var(--neon);
}
@media (max-width:760px){
  .menu__preview{display:none}
  .menu__stage.is-active .menu__list,
  .menu__stage.is-active .row{cursor:default}
}
.row__no{font-family:var(--mono);font-size:13px;color:var(--ink-2);font-weight:700}
.row__name{font-family:var(--display);font-size:clamp(20px,2.4vw,30px);line-height:1;letter-spacing:-.01em;text-transform:uppercase}
.row__tag{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--ink-2)}
.row__price{font-family:var(--mono);font-size:18px;font-weight:700}
.row__hover{
  grid-column:2 / -1;
  font-family:var(--serif);font-style:italic;font-size:18px;
  color:var(--neon);
  max-height:0;opacity:0;overflow:hidden;
  transition:max-height .5s cubic-bezier(.2,.8,.2,1),opacity .35s,margin .35s;
}
.row:hover,.row:focus-visible{background:var(--ink);color:var(--bg);padding-left:24px}
.row:hover .row__no,.row:focus-visible .row__no{color:var(--neon)}
.row:hover .row__tag,.row:focus-visible .row__tag{color:var(--neon-2)}
.row:hover .row__hover,.row:focus-visible .row__hover{max-height:60px;opacity:1;margin-top:8px}
@media (max-width:680px){
  .row{grid-template-columns:40px 1fr auto;gap:14px}
  .row__tag{display:none}
}
.menu__cta{margin-top:36px}

/* ─── Accordion mobile: imagem que abre por baixo do item ─── */
.row__accordion{display:none}
@media (max-width:760px){
  .row__accordion{
    display:block;grid-column:1 / -1;
    max-height:0;opacity:0;overflow:hidden;
    transition:max-height .5s cubic-bezier(.2,.8,.2,1),opacity .4s,margin .4s;
  }
  .row.is-open .row__accordion{max-height:64vh;opacity:1;margin-top:14px}
  .row__accordion img{
    width:100%;height:auto;max-height:60vh;object-fit:cover;display:block;
    border:1.5px solid var(--ink);border-radius:8px;
  }
  /* cue visual: › roda para baixo quando aberto */
  .row[data-img] .row__price::after{
    content:' ›';color:var(--neon);display:inline-block;
    transition:transform .3s cubic-bezier(.2,.8,.2,1);
  }
  .row[data-img].is-open .row__price::after{transform:rotate(90deg)}
  /* no destaque escuro a moldura fica clara */
  .menu--dark .row__accordion img{border-color:rgba(251,248,242,.35)}
  /* desliga o highlight :hover sticky no touch (fica só o accordion) */
  .row:hover{background:transparent;color:inherit;padding-left:8px}
  .menu--dark .row:hover .row__name{color:#FBF8F2}
  .menu--dark .row:hover .row__price{color:#fff}
}

/* ═══════════ MENU --DARK (homepage destaques) ═══════════
   Secção full-bleed escura; conteúdo continua alinhado a 1320.
   Tudo invertido para funcionar sobre o verde-preto da marca. */
.menu--dark{
  max-width:none;margin:0;
  padding-left:0;padding-right:0;          /* padding lateral move para os filhos */
  background:#08110D;color:#FBF8F2;
  position:relative;overflow:hidden;isolation:isolate;
}
.menu--dark::before{
  content:'';position:absolute;inset:-20%;z-index:-1;
  background:
    radial-gradient(40% 50% at 85% 15%, rgba(255,45,139,.25), transparent 60%),
    radial-gradient(35% 45% at 10% 85%, rgba(124,58,237,.22), transparent 60%);
  filter:blur(50px);
}
.menu--dark > *{
  max-width:1320px;
  margin-left:auto;margin-right:auto;
  padding-left:clamp(20px,4vw,48px);
  padding-right:clamp(20px,4vw,48px);
  position:relative;
}
.menu--dark .eyebrow{color:rgba(251,248,242,.8)}
.menu--dark .menu__title{color:#FBF8F2}
.menu--dark .menu__title em{
  text-shadow:0 0 18px rgba(255,45,139,.5),0 0 50px rgba(255,45,139,.3);
}
.menu--dark .menu__group-title{color:#FBF8F2}
.menu--dark .menu__group-title em{color:rgba(255,180,210,.8)}
.menu--dark .menu__list{border-top-color:rgba(251,248,242,.3)}
.menu--dark .row{border-bottom-color:rgba(251,248,242,.18)}
.menu--dark .row__no{color:rgba(251,248,242,.45)}
.menu--dark .row__name{color:#FBF8F2}
.menu--dark .row__tag{color:rgba(251,248,242,.55)}
.menu--dark .row__price{color:#fff}
/* hover invertido: acende a cream com texto escuro */
.menu--dark .row:hover,.menu--dark .row:focus-visible{
  background:var(--bg);color:var(--ink);
}
.menu--dark .row:hover .row__name,.menu--dark .row:focus-visible .row__name{color:var(--ink)}
.menu--dark .row:hover .row__price,.menu--dark .row:focus-visible .row__price{color:var(--ink)}
.menu--dark .row:hover .row__no,.menu--dark .row:focus-visible .row__no{color:var(--neon)}
.menu--dark .row:hover .row__tag,.menu--dark .row:focus-visible .row__tag{color:var(--neon)}
/* CTA "Ver menu completo" sobre dark — centrado na banda */
.menu--dark .menu__cta{
  display:flex;width:max-content;
  margin:42px auto 0;
  padding:14px 22px;                       /* restaura padding do pill--big */
  background:#fff;color:var(--ink);border-color:#fff;
}
.menu--dark .menu__cta:hover{background:var(--neon);border-color:var(--neon);color:#fff}
/* caption do preview flutuante */
.menu--dark .menu__preview-cap{color:#FBF8F2}
.menu--dark .menu__preview-frame{border-color:rgba(251,248,242,.4)}

/* ═══════════ SALA / GALERIA ═══════════ */
.sala{
  padding:clamp(40px,6vw,80px) clamp(20px,3vw,40px) clamp(60px,10vw,100px);
}
.sala__head{
  max-width:1600px;margin:0 auto clamp(28px,4vw,52px);
  display:grid;gap:10px;
}
.sala__title{
  font-family:var(--display);
  font-size:clamp(40px,6.5vw,100px);line-height:.85;
  letter-spacing:-.03em;text-transform:uppercase;
}
.sala__title em{
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:var(--neon);text-transform:none;
}
.sala__hint{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-2);margin-top:4px;
}
.sala__hint b{color:var(--neon);font-weight:700}

/* Grid widescreen — 12 cols, denso */
.sala__grid{
  position:relative;
  display:grid;grid-template-columns:repeat(12,1fr);
  grid-auto-flow:dense;
  grid-auto-rows:90px;gap:10px;
  max-width:1600px;margin:0 auto;
  isolation:isolate;
}
.sala__cell{
  overflow:hidden;border:1.5px solid var(--ink);
  position:relative;background:var(--bg-2);
}
.sala__cell:not(.sala__quote) img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1s cubic-bezier(.2,.8,.2,1),filter .5s;
}
.sala__cell:not(.sala__quote):hover img{transform:scale(1.05);filter:saturate(1.15)}

/* Mosaic — layout explícito 12×12: fecha em retângulo perfeito */
.sala--1 {grid-column:1 / span 5; grid-row:1 / span 4}   /* hero top-left */
.sala--2 {grid-column:6 / span 3; grid-row:1 / span 2}
.sala--3 {grid-column:9 / span 4; grid-row:1 / span 2}
.sala--4 {grid-column:6 / span 4; grid-row:3 / span 2}
.sala--5 {grid-column:10 / span 3;grid-row:3 / span 2}
/* banda do meio: quote | STAR | 2 imagens empilhadas */
.sala__quote{grid-column:1 / span 3; grid-row:5 / span 4}
.sala--6 {grid-column:10 / span 3;grid-row:5 / span 2}
.sala--7 {grid-column:10 / span 3;grid-row:7 / span 2}
/* banda de baixo: 3 + 2 para fechar */
.sala--8 {grid-column:1 / span 4; grid-row:9 / span 2}
.sala--9 {grid-column:5 / span 4; grid-row:9 / span 2}
.sala--10{grid-column:9 / span 4; grid-row:9 / span 2}
.sala--11{grid-column:1 / span 6; grid-row:11 / span 2}
.sala--12{grid-column:7 / span 6; grid-row:11 / span 2}

/* HERO da carta na galeria — tábua de vaca 4pax centrada e GRANDE como sala--1 */
.sala--star{
  grid-column:4 / span 6;                          /* 6 colunas centradas (4→9 de 12) */
  grid-row:5 / span 4;                              /* 4 rows abaixo do hero sala--1 */
  border:1.5px solid var(--neon);
  box-shadow:8px 8px 0 var(--ink),0 0 40px rgba(255,45,139,.35);
  position:relative;
}
.sala--star::before{
  content:'★ Em destaque';
  position:absolute;top:12px;left:12px;z-index:2;
  background:var(--neon);color:#fff;
  padding:6px 12px;border-radius:999px;border:1.5px solid var(--ink);
  font-family:var(--mono);font-size:10px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  box-shadow:3px 3px 0 var(--ink);
}
.sala--star figcaption{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.85) 100%);
  color:#fff;
  padding:48px 22px 18px;
  font-family:var(--display);
  font-size:clamp(22px,2.4vw,36px);
  line-height:.95;letter-spacing:-.015em;text-transform:uppercase;
}
@media (max-width:880px){
  .sala--star{grid-column:1 / -1;grid-row:span 4}     /* mobile: full width */
}

.sala__quote{
  /* grid placement definido no bloco mosaic (linha ~577) */
  background:var(--neon);color:#fff;
  padding:24px;display:flex;flex-direction:column;justify-content:space-between;
  border:1.5px solid var(--ink);
  transform:rotate(-1.8deg);
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.sala__quote:hover{transform:rotate(0)}
.sala__quote p{font-family:var(--serif);font-size:clamp(22px,2.2vw,32px);line-height:1.1;letter-spacing:-.01em}
.sala__quote em{font-family:var(--serif)}
.sala__quote small{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;opacity:.85}

/* ─── Carrossel de reviews Google (dentro do quote rosa) ─── */
.reviews{display:flex;flex-direction:column;height:100%;gap:14px}
.reviews__head{display:flex;align-items:center;gap:8px;flex-shrink:0}
.reviews__g{
  width:22px;height:22px;border-radius:50%;background:#fff;color:var(--ink);
  font-family:var(--display);font-size:13px;display:grid;place-items:center;line-height:1;
}
.reviews__label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:#fff}
.reviews__viewport{flex:1;overflow:hidden;position:relative;display:flex;align-items:center}
.reviews__track{display:flex;width:100%;transition:transform .5s cubic-bezier(.2,.8,.2,1);touch-action:pan-y}
.review{
  flex:0 0 100%;min-width:100%;
  display:flex;flex-direction:column;gap:10px;
  padding-right:2px;
}
.review__stars{color:#fff;font-size:15px;letter-spacing:2px;line-height:1}
.review__text{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(15px,1.5vw,19px);line-height:1.25;letter-spacing:-.01em;color:#fff;
}
.review__author{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#fff;opacity:.85}
.review__author span{opacity:.7}
.reviews__dots{display:flex;gap:7px;flex-shrink:0;padding-top:2px}
.reviews__dots button{
  width:7px;height:7px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:rgba(255,255,255,.4);transition:background .25s,transform .25s;
}
.reviews__dots button.is-active{background:#fff;transform:scale(1.25)}

/* Cutouts arrastáveis */
.sala__cut{
  position:absolute;
  cursor:grab;
  touch-action:none;
  user-select:none;
  z-index:10;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),filter .35s;
  will-change:transform;
}
.sala__cut img{display:block;width:100%;height:auto;pointer-events:none;-webkit-user-drag:none}
.sala__cut:hover{filter:brightness(1.05)}
.sala__cut.is-dragging{cursor:grabbing;transition:none;z-index:30}
.sala__cut.is-dragging::after{
  content:'';position:absolute;inset:-20px;border-radius:50%;
  background:radial-gradient(circle, rgba(255,45,139,.18), transparent 70%);
  pointer-events:none;
}
.sala__cut::before{
  content:'';position:absolute;left:50%;top:-12px;
  width:30px;height:6px;background:rgba(0,0,0,.15);border-radius:50%;
  transform:translateX(-50%);filter:blur(3px);
  opacity:0;transition:opacity .35s;
}
.sala__cut.is-dragging::before{opacity:1}

.sala__cut--porca{
  width:clamp(160px,18vw,260px);top:6%;left:38%;
  transform:rotate(-9deg);
  filter:drop-shadow(0 24px 36px rgba(0,0,0,.45)) drop-shadow(0 0 36px rgba(255,45,139,.25));
}
.sala__cut--tomahawk{
  width:clamp(140px,16vw,220px);top:42%;left:55%;
  transform:rotate(14deg);
  filter:drop-shadow(0 22px 32px rgba(0,0,0,.5));
}
.sala__cut--polaroid{
  width:clamp(150px,15vw,200px);top:62%;left:8%;
  transform:rotate(4deg);
  background:#fff;border:1.5px solid var(--ink);
  padding:8px 8px 14px;
  box-shadow:8px 8px 0 var(--ink), 0 18px 40px -10px rgba(0,0,0,.35);
  filter:none;
}
.sala__cut--polaroid img{
  aspect-ratio:1;object-fit:cover;width:100%;height:auto;
}
.sala__cut--polaroid span{
  display:block;margin-top:8px;
  font-family:var(--mono);font-size:10px;
  text-transform:uppercase;letter-spacing:.12em;text-align:center;
  color:var(--ink);
}

/* Hint visual subtil nos cutouts */
.sala__cut:not(.is-dragging):hover{transform:rotate(0) scale(1.04)}

@media (max-width:880px){
  .sala__grid{grid-template-columns:repeat(6,1fr);grid-auto-rows:110px}
  .sala--1 {grid-column:span 6;grid-row:span 3}
  .sala--2 {grid-column:span 3;grid-row:span 2}
  .sala--3 {grid-column:span 3;grid-row:span 2}
  .sala--4 {grid-column:span 3;grid-row:span 2}
  .sala--5 {grid-column:span 3;grid-row:span 3}
  .sala--6 {grid-column:span 6;grid-row:span 2}
  .sala--7 {grid-column:span 6;grid-row:span 3}
  .sala--8 {grid-column:span 3;grid-row:span 2}
  .sala--9 {grid-column:span 3;grid-row:span 2}
  .sala--10{grid-column:span 3;grid-row:span 2}
  .sala--11{grid-column:span 6;grid-row:span 2}
  .sala--12{grid-column:span 3;grid-row:span 2}
  .sala__quote{grid-column:span 6;grid-row:span 2}
  /* mobile: cutouts mais pequenos, sem drag (touch+scroll conflito) */
  .sala__cut{display:none}
}

/* ═══════════ MESA-FORM — Reservas + Contacto numa só secção ═══════════ */
.mesa-form{
  position:relative;background:var(--teal);color:#fff;
  padding:clamp(70px,10vw,140px) clamp(20px,4vw,48px);
  overflow:hidden;isolation:isolate;
}
.mesa-form::before{
  content:'';position:absolute;inset:-20%;z-index:-1;
  background:
    radial-gradient(40% 40% at 80% 20%, rgba(255,45,139,.5), transparent 60%),
    radial-gradient(50% 40% at 10% 90%, rgba(255,45,139,.3), transparent 60%);
  filter:blur(40px);
}
.mesa-form__pig{
  position:absolute;right:-2vw;bottom:-4vw;font-size:clamp(180px,30vw,420px);
  filter:grayscale(1) brightness(.7) contrast(1.4);
  opacity:.06;z-index:0;line-height:1;user-select:none;
}
/* Cabeçalho full-width — título corre na horizontal, sem quebras */
.mesa-form__top{
  max-width:1320px;margin:0 auto clamp(36px,4vw,56px);
  position:relative;z-index:1;
  display:grid;gap:12px;
}
.mesa-form__inner{
  max-width:1320px;margin:0 auto;position:relative;z-index:1;
  display:grid;gap:clamp(40px,5vw,72px);
  grid-template-columns:1fr;
  align-items:stretch;                /* colunas com a mesma altura */
}
@media (min-width:1000px){
  .mesa-form__inner{grid-template-columns:5fr 6fr}
}

/* LEFT — pitch / reservas; widget cola ao fundo para alinhar com o form */
.mesa-form__pitch{display:flex;flex-direction:column;gap:14px}
.mesa-form__title{
  font-family:var(--display);
  font-size:clamp(34px,5.6vw,84px);line-height:.9;
  letter-spacing:-.03em;text-transform:uppercase;color:#fff;
  margin-top:6px;
  white-space:nowrap;                 /* uma linha corrida */
}
@media (max-width:760px){
  .mesa-form__title{white-space:normal;font-size:clamp(38px,9vw,64px)}
}
.mesa-form__title em{
  color:var(--neon-2);
  text-shadow:0 0 24px rgba(255,122,182,.6);
}
.mesa-form__body{
  font-size:17px;max-width:42ch;color:rgba(255,255,255,.78);
}
.mesa-form__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:14px}
.mesa-form__meta{
  margin-top:32px;padding-top:22px;border-top:1px solid rgba(255,255,255,.18);
  display:grid;gap:10px;
}
.mesa-form__meta li{font-family:var(--mono);font-size:13px;color:rgba(255,255,255,.7);display:flex;gap:12px;flex-wrap:wrap;align-items:baseline}
.mesa-form__meta b{color:#fff;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:11px;min-width:80px}
.mesa-form__meta a{color:var(--neon-2);transition:color .25s}
.mesa-form__meta a:hover{color:#fff}

/* RIGHT — formulário, colado ao fundo para alinhar com o widget à esquerda */
.mesa-form__form{
  display:flex;flex-direction:column;gap:20px;
  justify-content:flex-end;
}

/* Widget de reservas DISH — na coluna esquerda, sob o horário/email.
   margin-top:auto empurra-o para o fundo da coluna → alinha com o form */
.mesa-form__widget{display:grid;gap:12px;margin-top:auto;padding-top:26px}
.widget-card{
  background:#fff;
  border:1.5px solid var(--ink);
  box-shadow:8px 8px 0 var(--ink),0 0 40px rgba(255,45,139,.18);
  padding:12px;
  max-height:360px;                /* compacto, aproxima o fundo das 2 colunas */
  overflow-y:auto;
  overscroll-behavior:contain;     /* scroll interno não arrasta a página */
}
.widget-card::-webkit-scrollbar{width:8px}
.widget-card::-webkit-scrollbar-thumb{background:var(--neon);border-radius:99px}
.widget-card::-webkit-scrollbar-track{background:var(--bg-2)}
@media (max-width:760px){
  .widget-card{max-height:420px;padding:10px}
}
.mesa-form__form-head{display:grid;gap:6px;margin-left:4px}
.mesa-form__form-sub{font-family:var(--serif);font-style:italic;font-size:17px;color:rgba(255,255,255,.8);max-width:42ch}

/* O .cform mantém-se igual (caixa branca com sombra rosa) */
@media (max-width:999px){
  .mesa-form__pitch{position:static}
}

/* ═══════════ FORMULÁRIO — usado também na page contacto.html ═══════════ */
.form-block{
  position:relative;background:var(--ink);color:#fff;
  padding:clamp(80px,12vw,160px) clamp(20px,4vw,48px);
  overflow:hidden;isolation:isolate;
}
.form-block::before{
  content:'';position:absolute;inset:-20%;z-index:-1;
  background:
    radial-gradient(40% 40% at 12% 18%, rgba(255,45,139,.4), transparent 60%),
    radial-gradient(50% 40% at 90% 90%, rgba(15,38,32,.85), transparent 60%);
  filter:blur(40px);
}
.form-block__inner{
  max-width:1280px;margin:0 auto;
  display:grid;gap:clamp(40px,5vw,72px);
  grid-template-columns:1fr;
}
@media (min-width:900px){
  .form-block__inner{grid-template-columns:5fr 7fr}
}
.form-block__head{display:grid;gap:18px;align-content:start}
.form-block__title{
  font-family:var(--display);
  font-size:clamp(48px,7vw,108px);line-height:.85;
  letter-spacing:-.03em;text-transform:uppercase;color:#fff;
}
.form-block__title em{
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:var(--neon-2);text-transform:none;
  text-shadow:0 0 24px rgba(255,122,182,.5);
}
.form-block__body{
  font-size:17px;color:rgba(255,255,255,.78);max-width:42ch;
}
.form-block__meta{
  margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,.18);
  display:grid;gap:10px;
}
.form-block__meta li{
  font-family:var(--mono);font-size:13px;color:rgba(255,255,255,.75);
  display:flex;gap:12px;align-items:baseline;flex-wrap:wrap;
}
.form-block__meta b{
  color:#fff;font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  min-width:90px;
}
.form-block__meta a{color:var(--neon-2);transition:color .25s}
.form-block__meta a:hover{color:#fff}

/* Form fields */
.cform{
  background:#fff;color:var(--ink);
  border:1.5px solid var(--ink);
  padding:clamp(24px,3vw,40px);
  display:grid;gap:18px;
  box-shadow:12px 12px 0 var(--neon);
}
.cform__row{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width:640px){.cform__row{grid-template-columns:1fr 1fr}}
.cfield{display:grid;gap:6px}
.cfield label{
  font-family:var(--mono);font-size:11px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink);
}
.cfield label em{
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:var(--ink-2);text-transform:none;letter-spacing:0;font-size:13px;margin-left:4px;
}
.cfield input,.cfield select,.cfield textarea{
  font:inherit;color:inherit;
  background:transparent;
  border:0;border-bottom:1.5px solid var(--ink);
  padding:10px 0;border-radius:0;outline:none;
  -webkit-appearance:none;appearance:none;font-size:16px;
  font-family:var(--ui);
  transition:border-color .25s;
}
.cfield input:focus,.cfield select:focus,.cfield textarea:focus{
  border-color:var(--neon);
}
.cfield select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6'><path d='M1 1l4 4 4-4' fill='none' stroke='%230E0D0C' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 4px center;padding-right:22px;
}
.cfield textarea{resize:vertical;min-height:110px;padding-top:10px}
.cfield--err input,.cfield--err select,.cfield--err textarea{border-color:#c0392b}
.cfield__err{font-size:12px;color:#c0392b;min-height:14px}
.cform__check{
  display:flex;gap:10px;align-items:flex-start;
  font-family:var(--mono);font-size:12px;color:var(--ink-2);line-height:1.4;
}
.cform__check input{margin-top:3px}
.cform__foot{display:flex;gap:18px;align-items:center;flex-wrap:wrap;padding-top:6px}
.cform__status{font-family:var(--mono);font-size:12px;color:var(--ink-2);min-height:16px}
.cform__status[data-state="ok"]{color:#1f6b3d}
.cform__status[data-state="err"]{color:#c0392b}

/* Estado de sucesso */
.cform-ok{
  background:#fff;border:1.5px solid var(--ink);
  padding:clamp(28px,4vw,48px);text-align:center;
  box-shadow:12px 12px 0 var(--neon);
}
.cform-ok h3{
  font-family:var(--display);font-size:clamp(28px,3vw,40px);
  text-transform:uppercase;letter-spacing:-.02em;margin-bottom:8px;
}
.cform-ok h3 em{font-family:var(--serif);font-style:italic;color:var(--neon)}
.cform-ok p{color:var(--ink-2);max-width:42ch;margin:0 auto}

/* ═══════════ FOOTER ═══════════ */
.foot{background:var(--ink);color:var(--bg);padding:clamp(40px,6vw,72px) clamp(20px,4vw,48px) 24px}
/* Nariz da porca em rosa, centrado, no lugar do antigo wordmark */
.foot__nose{
  display:flex;justify-content:center;
  margin-bottom:48px;
}
.foot__nose img{
  width:clamp(90px,10vw,140px);height:auto;
  filter:drop-shadow(0 0 24px rgba(255,45,139,.45));
}
.foot__cols{
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
  padding-top:32px;border-top:1px solid rgba(255,255,255,.16);
}
.foot__cols h4{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--neon);margin-bottom:14px;font-weight:700}
.foot__cols a,.foot__cols p{display:block;padding:4px 0;font-size:14px;color:rgba(255,255,255,.78);transition:color .25s}
.foot__cols a:hover{color:var(--neon)}
@media (max-width:760px){.foot__cols{grid-template-columns:1fr 1fr}}

/* ═══════════════════════════════════════════════════════════════
   HERO — DARK MODE (preto esverdeado + neon cursor glow)
   ═══════════════════════════════════════════════════════════════ */
.hero--dark{
  --hero-bg: #08110D;              /* preto com tom de verde profundo */
  --hero-bg-2: #0E1A14;            /* highlight para gradientes ambient */
  --hero-fg: #FBF8F2;              /* off-white para texto */
  --hero-fg-mute: rgba(251,248,242,.62);
  --hero-line: rgba(251,248,242,.18);

  background:var(--hero-bg);
  color:var(--hero-fg);
  border-bottom:1.5px solid var(--ink);
  isolation:isolate;
  cursor:default;
}

/* Foto da sala como textura de fundo — opacidade baixa, fica DEBAIXO
   dos beams/dots (ordem no DOM: photo → glow → conteúdo) */
.hero__photo{
  position:absolute;inset:0;z-index:0;
  background:url('assets/img/espaco/hero-bg.jpg') center 35%/cover no-repeat;
  opacity:.18;
  pointer-events:none;
}

/* Glow layer: pinta o fundo com gradients ambient + um spot que segue o rato */
.hero__glow{
  position:absolute;inset:0;z-index:0;
  pointer-events:none;
  background:
    radial-gradient(820px 620px at 88% 8%, rgba(15,38,32,.85), transparent 60%),
    radial-gradient(700px 520px at 6% 92%, rgba(15,38,32,.55), transparent 60%),
    radial-gradient(440px 440px at var(--mx,50%) var(--my,50%), rgba(255,45,139,.32), transparent 65%),
    radial-gradient(900px 600px at var(--mx,50%) var(--my,50%), rgba(255,45,139,.08), transparent 70%);
  transition:background-position .2s linear;
  mix-blend-mode:screen;
}

/* ─── DISCO BEAMS ─────────────────────────────────────────────
   Manchas de cor que atravessam o hero em loop, fundem com
   mix-blend-mode: screen para acumular sem sobreposição plana.
   Performance: só `transform` é animado, GPU layer (will-change).
*/
.hero__beam{
  position:absolute;border-radius:50%;
  filter:blur(70px);
  mix-blend-mode:screen;
  pointer-events:none;
  will-change:transform;
}
.hero__beam--pink{
  width:380px;height:380px;top:10%;left:-30%;
  background:radial-gradient(circle, rgba(255,45,139,.85), transparent 70%);
  animation:beamRight 22s linear infinite;
  animation-delay:-3s;
}
.hero__beam--lilac{
  width:300px;height:300px;top:55%;left:130%;
  background:radial-gradient(circle, rgba(199,125,255,.78), transparent 70%);
  animation:beamLeft 28s linear infinite;
}
.hero__beam--purple{
  width:420px;height:420px;top:30%;left:-40%;
  background:radial-gradient(circle, rgba(124,58,237,.65), transparent 70%);
  animation:beamRight 34s linear infinite;
  animation-delay:-10s;
}
.hero__beam--red{
  width:260px;height:260px;top:70%;left:120%;
  background:radial-gradient(circle, rgba(239,68,68,.62), transparent 70%);
  animation:beamLeft 24s linear infinite;
  animation-delay:-6s;
}
.hero__beam--pink2{
  width:340px;height:340px;top:5%;left:120%;
  background:radial-gradient(circle, rgba(255,107,179,.72), transparent 70%);
  animation:beamLeft 30s linear infinite;
  animation-delay:-14s;
}
/* Amarelos: mais pequenos e menos opacos, conforme pediste */
.hero__beam--yellow{
  width:160px;height:160px;top:40%;left:-15%;
  background:radial-gradient(circle, rgba(255,224,102,.55), transparent 70%);
  filter:blur(50px);
  animation:beamRight 18s linear infinite;
  animation-delay:-2s;
}
.hero__beam--yellow2{
  width:120px;height:120px;top:80%;left:115%;
  background:radial-gradient(circle, rgba(255,210,80,.5), transparent 70%);
  filter:blur(45px);
  animation:beamLeft 26s linear infinite;
  animation-delay:-9s;
}

@keyframes beamRight{
  0%   {transform:translate3d(0,0,0)}
  100% {transform:translate3d(150vw,-8vh,0)}
}
@keyframes beamLeft{
  0%   {transform:translate3d(0,0,0)}
  100% {transform:translate3d(-150vw,6vh,0)}
}

@media (prefers-reduced-motion:reduce){
  .hero__beam{animation:none !important;opacity:.45}
}
@media (max-width:760px){
  /* mobile: menos beams, animações mais lentas e menores */
  .hero__beam--purple,.hero__beam--pink2,.hero__beam--yellow2{display:none}
  .hero__beam{filter:blur(50px)}
}
/* Campo de pontos — DUAS camadas:
   - Ambient (sempre visível, baixa opacidade) = textura constante
   - Bright (revelado por máscara à volta do cursor) = highlight neon */
.hero__glow-dots{
  position:absolute;inset:0;pointer-events:none;
  /* AMBIENT — sempre visível, pequeno e subtil */
  background-image:radial-gradient(circle at center, rgba(255,45,139,.22) 0.6px, transparent 1.2px);
  background-size:24px 24px;
  opacity:.7;
  mix-blend-mode:screen;
}
.hero__glow-dots::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  /* BRIGHT — só visível dentro de um raio à volta do rato */
  background-image:radial-gradient(circle at center, rgba(255,45,139,.95) 1px, transparent 1.7px);
  background-size:42px 42px;
  -webkit-mask-image:radial-gradient(circle 300px at var(--mx,50%) var(--my,50%), rgba(0,0,0,.9) 0%, transparent 70%);
          mask-image:radial-gradient(circle 300px at var(--mx,50%) var(--my,50%), rgba(0,0,0,.9) 0%, transparent 70%);
  mix-blend-mode:screen;
}
@media (prefers-reduced-motion:reduce){
  .hero__glow{transition:none}
  .hero__glow-dots::after{-webkit-mask-image:none;mask-image:none;opacity:.15}
}
@media (max-width:760px){
  /* mobile: ambient continua, cursor reveal desliga (touch) */
  .hero__glow-dots::after{display:none}
  .hero__glow-dots{opacity:.55}
  .hero__glow{
    background:
      radial-gradient(60% 60% at 92% 8%, rgba(15,38,32,.85), transparent 60%),
      radial-gradient(70% 50% at 6% 92%, rgba(255,45,139,.18), transparent 65%);
  }
}

/* Tipografia: tudo branco; "BIFE" mantém o rosa com glow mais forte */
.hero--dark .hero__title{color:var(--hero-fg)}
.hero--dark .hero__title em{
  color:var(--neon);
  text-shadow:
    0 0 18px rgba(255,45,139,.55),
    0 0 50px rgba(255,45,139,.35),
    0 0 90px rgba(255,45,139,.25);
}

/* Kickers do hero foot (DAILY DOSE / EST. 2024) */
.hero--dark .kicker{color:var(--hero-fg-mute)}

/* Cutouts (porca + tomahawk): sombras pretas trocadas por glow rosa */
.hero--dark .cut-porca{
  filter:
    drop-shadow(0 30px 50px rgba(0,0,0,.55))
    drop-shadow(0 0 80px rgba(255,45,139,.45));
}
.hero--dark .cut-tomahawk{
  filter:
    drop-shadow(0 26px 40px rgba(0,0,0,.55))
    drop-shadow(0 0 50px rgba(255,45,139,.3));
}

/* Sticker (QR) — fica em branco como está. Adicionar glow subtil. */
.hero--dark .sticker__body{
  box-shadow:6px 6px 0 #000, 0 0 32px rgba(255,45,139,.18);
}

/* Pills sobre o hero escuro */
.hero--dark .pill{border-color:rgba(251,248,242,.55);color:var(--hero-fg)}
.hero--dark .pill:hover{background:#fff;color:var(--ink);border-color:#fff}
.hero--dark .pill--ghost{background:transparent}
.hero--dark .pill--filled{
  background:#fff;color:var(--ink);border-color:#fff;
}
.hero--dark .pill--filled:hover{
  background:var(--neon);color:#fff;border-color:var(--neon);
  box-shadow:0 0 0 4px rgba(255,45,139,.22),0 14px 40px -14px rgba(255,45,139,.6);
}

/* ─── NAV adapta-se quando está sobre o hero escuro ─── */
.nav{
  /* sem mix-blend-mode: gerimos cor manualmente conforme a secção atual */
  mix-blend-mode:normal;
  transition:color .35s ease, background-color .35s ease;
}
.nav.is-on-dark{
  color:#FBF8F2;
  background:transparent;                  /* sem barra sólida: o hero estende-se por baixo */
}
.nav.is-on-dark .nav__links a{
  color:#FBF8F2;
  border-color:rgba(251,248,242,.55);
}
.nav.is-on-dark .nav__links a:hover{
  background:#fff;color:var(--ink);border-color:#fff;
}
.nav.is-on-dark .pill--neon{
  border-color:var(--neon);color:var(--neon);background:rgba(0,0,0,.25);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.nav.is-on-dark .pill--neon:hover{background:var(--neon);color:#fff}

/* Hero escuro estende-se por baixo do nav, eliminando a faixa creme do body.
   Negative margin puxa o hero até logo abaixo do tape; padding-top empurra o
   conteúdo (PECADO etc) para baixo do nav para não colidir. */
.hero--dark{
  background:var(--hero-bg);
  margin-top:-100px;
  padding-top:clamp(120px,18vw,200px);
}
@media (max-width:760px){
  .hero--dark{margin-top:-80px;padding-top:90px}
}

/* Logo: temos versão rosa carregada por defeito. Em fundo claro continua
   a funcionar; em fundo escuro destaca-se bem. */
.nav__logo-light{filter:drop-shadow(0 0 18px rgba(255,45,139,.0));transition:filter .35s ease}
.nav.is-on-dark .nav__logo-light{filter:drop-shadow(0 0 22px rgba(255,45,139,.4))}

/* ═══════════ MOTION ═══════════ */
[data-float]{will-change:transform}
@media (prefers-reduced-motion:reduce){[data-float]{transform:none !important}}

/* ═══════════════════════════════════════════════════════════════
   PÁGINA: CARTA (menu.html)
   ═══════════════════════════════════════════════════════════════ */
.page--carta{background:var(--bg)}
.nav__links a[aria-current="page"]{color:var(--neon)}
.nav__links a[aria-current="page"]::after{width:100%;background:var(--neon)}

/* ─── HEAD ─── (fundo verde escuro, texto branco, CONSEQUÊNCIAS rosa) */
.carta-head{
  background:#08110D;                                          /* dark verde igual ao hero */
  color:#FBF8F2;
  padding:clamp(120px,14vw,160px) 0 clamp(32px,4vw,56px);     /* sem padding horizontal aqui */
  margin:0;
  position:relative;overflow:hidden;isolation:isolate;
  /* "estender" cor por baixo do nav transparente */
  margin-top:-100px;
}
.carta-head::before{
  content:'';position:absolute;inset:-20%;z-index:-1;
  background:
    radial-gradient(40% 50% at 80% 30%, rgba(255,45,139,.32), transparent 60%),
    radial-gradient(35% 45% at 8% 92%, rgba(124,58,237,.28), transparent 60%),
    radial-gradient(30% 35% at 70% 80%, rgba(255,107,179,.18), transparent 60%);
  filter:blur(50px);
}
/* Filhos do head ficam alinhados com .menu (max-width 1320 + padding clamp ←→ igual) */
.carta-head > *{
  position:relative;
  max-width:1320px;margin-left:auto;margin-right:auto;
  width:100%;
  padding-left:clamp(20px,4vw,48px);
  padding-right:clamp(20px,4vw,48px);
  box-sizing:border-box;
}
.carta-head .eyebrow{color:rgba(251,248,242,.85)}
.carta-head__title{
  font-family:var(--display);
  font-size:clamp(50px,9.5vw,138px);
  line-height:.88;letter-spacing:-.035em;text-transform:uppercase;
  margin-top:6px;margin-bottom:14px;color:#FBF8F2;
  /* margin-left/right ficam :auto do .carta-head > * → centra-se com a max-width */
}
.carta-head__title em{
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:var(--neon);letter-spacing:-.025em;
  text-shadow:
    0 0 18px rgba(255,45,139,.55),
    0 0 50px rgba(255,45,139,.3),
    0 0 90px rgba(255,45,139,.25);
}
.carta-head__sub{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(17px,1.5vw,21px);line-height:1.4;
  color:rgba(255,180,210,.85);                                 /* tom rosa suave */
  max-width:58ch;
}
@media (max-width:760px){
  .carta-head{margin-top:-70px;padding-top:90px;padding-bottom:28px}
}

/* ─── JUMP NAV (sticky) ─── trava ABAIXO do nav (~134px), não sobre o logo */
.carta-jump{
  position:sticky;top:134px;z-index:30;             /* < nav z:50; abaixo do nav bottom */
  background:var(--bg);
  border-top:1.5px solid var(--ink);
  border-bottom:1.5px solid var(--ink);
}
.carta-jump__rail{
  max-width:1320px;margin:0 auto;                    /* alinha com o conteúdo .menu */
  padding:10px clamp(20px,4vw,48px);
  display:flex;gap:8px;overflow-x:auto;
  scrollbar-width:none;
}
.carta-jump__rail::-webkit-scrollbar,
.carta-jump::-webkit-scrollbar{display:none}
.carta-jump a{
  flex-shrink:0;
  padding:8px 14px;
  font-family:var(--mono);font-weight:700;font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;
  border:1.5px solid var(--ink);border-radius:999px;
  color:var(--ink);background:transparent;
  transition:background .25s,color .25s,border-color .25s;
}
.carta-jump a:hover{background:var(--ink);color:var(--bg)}
.carta-jump a.is-active{background:var(--neon);color:#fff;border-color:var(--neon)}
@media (max-width:760px){
  .carta-jump{top:108px}                            /* nav mobile ~84px + tape ~34 */
  .carta-jump a{font-size:10px;padding:7px 11px}
}

/* ─── NAV em modo escuro ── menu.html: nav está sempre sobre fundo escuro
   (carta-head dark green no topo, depois preto quando jump-nav fica stuck) */
.page--carta .nav{
  background:#08110D;
  color:#FBF8F2;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.page--carta .nav__links a{
  color:#FBF8F2;
  border-color:rgba(251,248,242,.55);
}
.page--carta .nav__links a:hover{
  background:#fff;color:var(--ink);border-color:#fff;
}
.page--carta .nav__links a[aria-current="page"]{
  border-color:var(--neon);color:var(--neon);
}
.page--carta .pill--neon{
  border-color:var(--neon);color:var(--neon);background:rgba(0,0,0,.25);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.page--carta .pill--neon:hover{background:var(--neon);color:#fff}
/* logo rosa ganha glow sobre o fundo escuro */
.page--carta .nav__logo-light{filter:drop-shadow(0 0 22px rgba(255,45,139,.4))}

/* ─── CATEGORIAS ─── */
.carta{padding-top:clamp(20px,3vw,40px)}
.carta-cat{
  padding-top:clamp(40px,6vw,72px);
  scroll-margin-top:200px;                          /* tape + nav + jump-nav fit */
}
@media (max-width:760px){
  .carta-cat{scroll-margin-top:160px}
}
.carta-cat:first-child{padding-top:clamp(20px,3vw,32px)}
.carta-cat__title{
  display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;
  margin-bottom:18px;
}
.carta-cat__name{
  font-family:var(--display);
  font-size:clamp(32px,5vw,72px);line-height:.9;
  letter-spacing:-.025em;text-transform:uppercase;
}
.carta-cat__tag{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(16px,1.4vw,20px);color:var(--neon);
  letter-spacing:0;
}

/* sem imagem: row keep no underline issue, but disable hover preview cue */
.row--no-img{cursor:default}

/* foot da carta */
.carta__foot{
  display:flex;gap:14px;flex-wrap:wrap;
  margin-top:clamp(48px,6vw,72px);
  padding-top:clamp(32px,4vw,48px);
  border-top:1.5px solid var(--ink);
}
.carta__note{
  margin-top:24px;
  font-family:var(--mono);font-size:11px;
  letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-2);max-width:60ch;
}

/* na carta o stage é maior — coloca o preview mais à direita por defeito */
.menu__stage--carta{padding-bottom:24px}
.menu__stage--carta .row__tag{font-size:16px;line-height:1.3}
@media (max-width:680px){
  .menu__stage--carta .row__tag{display:block;grid-column:2 / -1;margin-top:4px;font-size:14px}
}
