/* ================================================================
   LA CASA DA PIZZA & BURGER
   CSS — VERMELHO DOMINANTE | La Casa de Papel
   ================================================================ */

:root {
  --red:          #ff1a00;
  --red-bright:   #ff3d00;
  --red-dark:     #cc1500;
  --red-deeper:   #660a00;
  --red-blood:    #330500;
  --red-glow:     rgba(255,61,0,.75);
  --red-glow2:    rgba(255,26,0,.5);

  /* amarelo La Casa de Papel */
  --yellow:       #ffd700;
  --yellow-bright:#ffe135;
  --yellow-dark:  #cc9900;
  --yellow-glow:  rgba(255,215,0,.6);

  /* fundos — preto puro para contraste máximo */
  --bg:           #050000;
  --bg2:          #0a0000;
  --bg3:          #100000;
  --bg4:          #160000;
  --bg5:          #1c0000;

  /* acentos */
  --cream:        #ffffff;
  --cream-dim:    rgba(255,255,255,.7);
  --gray:         #999;
  --gray-lt:      #ccc;

  --ff-title:     'Bebas Neue', sans-serif;
  --ff-head:      'Oswald', sans-serif;
  --ff-type:      'Special Elite', cursive;
  --ff-body:      'Rajdhani', sans-serif;

  --border-red:   1px solid rgba(255,61,0,.6);
  --border-red2:  1px solid rgba(255,61,0,.35);
  --border-dim:   1px solid rgba(255,61,0,.2);
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--ff-body);
  background: var(--bg);
  color: var(--cream);
  overflow-x: hidden;
  line-height: 1.6;
}
img    { display: block; max-width: 100%; }
a      { text-decoration: none; color: inherit; }
ul     { list-style: none; }
button { cursor: pointer; }

/* ================================================================
   SCAN LINES & NOISE
   ================================================================ */
.scanlines {
  position: fixed; inset: 0; z-index: 9998; pointer-events: none;
  background: repeating-linear-gradient(
    to bottom,
    transparent 0px, transparent 3px,
    rgba(150,0,0,.06) 3px, rgba(150,0,0,.06) 4px
  );
  mix-blend-mode: screen;
}
.noise {
  position: fixed; inset: 0; z-index: 9997; pointer-events: none; opacity: .03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px;
  animation: noiseAnim .15s steps(1) infinite;
}
@keyframes noiseAnim {
  0%  { background-position: 0 0; }
  25% { background-position: -20px 10px; }
  50% { background-position: 10px -15px; }
  75% { background-position: -5px 20px; }
}

/* ================================================================
   INTRO SCREEN
   ================================================================ */
.intro-screen {
  position: fixed; inset: 0; z-index: 9999;
  background: radial-gradient(ellipse at center, #1a0404 0%, #000 100%);
  display: flex; align-items: center; justify-content: center;
  transition: opacity .7s ease, visibility .7s ease;
}
.intro-screen.hide { opacity: 0; visibility: hidden; pointer-events: none; }

.intro-inner {
  display: flex; flex-direction: column; align-items: center;
  gap: 22px; padding: 40px 20px; text-align: center;
  max-width: 500px; width: 100%;
}

.intro-top-bar {
  font-family: var(--ff-body); font-size: .68rem; letter-spacing: 5px;
  color: rgba(255,61,0,.95); text-transform: uppercase;
  border: 1px solid rgba(255,61,0,.4); padding: 6px 18px;
  background: rgba(255,26,0,.1);
  animation: blink 1.2s infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.25} }

.intro-mask {
  width: 160px; height: 176px;
  filter: drop-shadow(0 0 30px rgba(255,61,0,.9)) drop-shadow(0 0 60px rgba(255,215,0,.3));
}

/* intro title escondido — usamos intro-sub-brand agora */
.intro-title { display: none; }

.intro-sub {
  font-family: var(--ff-head); font-size: .82rem; letter-spacing: 6px;
  color: rgba(255,215,0,.55); text-transform: uppercase;
  margin-top: 4px;
}

.intro-loading { width: 100%; max-width: 340px; }
.loading-bar {
  height: 3px; background: rgba(255,61,0,.2);
  margin-bottom: 10px; overflow: hidden;
}
.loading-fill {
  height: 100%; width: 0;
  background: linear-gradient(90deg, var(--red-dark), var(--red-bright), var(--yellow));
  transition: width .05s linear;
  box-shadow: 0 0 16px var(--red-glow);
}
.loading-text {
  font-family: var(--ff-body); font-size: .72rem; letter-spacing: 4px;
  color: rgba(255,215,0,.8); display: block; text-align: center;
}

/* ================================================================
   GLITCH
   ================================================================ */
.glitch-text { position: relative; }
.glitch-text::before,
.glitch-text::after {
  content: attr(data-text);
  position: absolute; top: 0; left: 0; width: 100%; overflow: hidden;
}
.glitch-text::before {
  color: #ff3d00;
  animation: glitch1 4s infinite;
  clip-path: polygon(0 0, 100% 0, 100% 38%, 0 38%);
}
.glitch-text::after {
  color: #ffd700;
  animation: glitch2 4s infinite;
  clip-path: polygon(0 62%, 100% 62%, 100% 100%, 0 100%);
}
@keyframes glitch1 {
  0%,94%,100%  { transform: none; opacity: 0; }
  95%          { transform: translateX(-5px) skewX(-6deg); opacity: .8; }
  97%          { transform: translateX(5px); opacity: 0; }
  98%          { transform: translateX(-2px); opacity: .5; }
}
@keyframes glitch2 {
  0%,91%,100%  { transform: none; opacity: 0; }
  92%          { transform: translateX(5px) skewX(6deg); opacity: .7; }
  94%          { transform: translateX(-4px); opacity: 0; }
  95%          { transform: translateX(2px); opacity: .4; }
}

/* ================================================================
   NAVBAR
   ================================================================ */
.navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 48px;
  transition: all .35s ease;
}
.navbar.scrolled {
  background: rgba(10,2,2,.97);
  backdrop-filter: blur(14px);
  padding: 13px 48px;
  border-bottom: 1px solid rgba(255,61,0,.5);
  box-shadow: 0 2px 40px rgba(255,26,0,.3);
}

.nav-logo { display: flex; align-items: center; gap: 12px; cursor: pointer; }
.nav-mask-svg {
  flex-shrink: 0;
  filter: drop-shadow(0 0 8px rgba(255,61,0,1)) drop-shadow(0 0 16px rgba(255,215,0,.4));
}
.logo-words { display: flex; flex-direction: column; line-height: 1.1; }
.logo-main {
  font-family: var(--ff-title); font-size: 1.5rem; letter-spacing: 3px;
  display: flex; align-items: baseline; gap: 0;
}
.logo-bella { color: #009246; text-shadow: 0 0 14px rgba(0,146,70,.7); }
.logo-ciao  { color: #ce2b37; text-shadow: 0 0 14px rgba(206,43,55,.8); }
.logo-sub {
  font-family: var(--ff-head); font-size: .55rem; letter-spacing: 4px;
  color: rgba(255,215,0,.55); text-transform: uppercase;
}

/* ── Bandeira italiana — classes reutilizáveis ── */
:root {
  --it-green: #009246;  /* verde bandeira italiana */
  --it-white: #f5f5f5;
  --it-red:   #ce2b37;  /* vermelho bandeira italiana */
}

/* Intro brand */
.intro-sub-brand {
  display: flex; align-items: baseline; gap: 0; margin-top: -8px;
}
.brand-bella {
  font-family: var(--ff-title); font-size: clamp(2.8rem,10vw,5.5rem);
  color: #009246; letter-spacing: 3px; line-height: 1;
  text-shadow: 0 0 20px rgba(0,146,70,.7), 0 0 40px rgba(0,146,70,.4);
}
.brand-ciao {
  font-family: var(--ff-title); font-size: clamp(2.8rem,10vw,5.5rem);
  color: #ce2b37; letter-spacing: 3px; line-height: 1;
  text-shadow: 0 0 20px rgba(206,43,55,.8), 0 0 40px rgba(206,43,55,.4);
}

/* Hero title — bandeira italiana */
.brand-flag-bella {
  color: #009246;
  text-shadow: 3px 4px 0 rgba(0,0,0,.9), 0 0 40px rgba(0,146,70,.6);
}
.brand-flag-ciao {
  color: #ce2b37;
  text-shadow: 3px 4px 0 rgba(0,0,0,.9), 0 0 40px rgba(206,43,55,.7);
}

/* Footer brand */
.footer-brand-name {
  font-family: var(--ff-title); font-size: 1.5rem; letter-spacing: 4px;
  display: flex; align-items: baseline; gap: 0; margin-bottom: 6px;
}
.footer-bella { color: #009246; text-shadow: 0 0 10px rgba(0,146,70,.5); }
.footer-ciao  { color: #ce2b37; text-shadow: 0 0 10px rgba(206,43,55,.6); }

/* Faixa tricolor da bandeira italiana — hero */
.hero::after {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg,
    var(--yellow-bright) 0%,
    var(--red-bright)    50%,
    var(--yellow-dark)   100%
  );
  z-index: 10;
  box-shadow: 0 0 14px rgba(255,61,0,.5);
}

.nav-links { display: flex; gap: 36px; }
.nav-links a {
  font-family: var(--ff-head); font-size: .76rem; font-weight: 500;
  letter-spacing: 3px; text-transform: uppercase; color: rgba(255,215,0,.45);
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  transition: color .25s;
}
.nav-num {
  font-family: var(--ff-body); font-size: .52rem;
  color: rgba(255,215,0,.7); letter-spacing: 1px;
}
.nav-links a:hover,
.nav-links a.active { color: var(--cream); }
.nav-links a.active { color: var(--red-bright); }
.nav-links a.active .nav-num { color: var(--red-bright); }

.hamburger { display: none; flex-direction: column; gap: 6px; z-index: 1001; }
.hamburger span {
  display: block; width: 26px; height: 2px;
  background: var(--red-bright); transition: all .3s;
}
.hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(5px,6px); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(5px,-6px); }

/* ================================================================
   FILE STRIP / SHARED
   ================================================================ */
.file-strip {
  background: linear-gradient(90deg, var(--red-dark), var(--red), var(--red-dark));
  padding: 8px 0; overflow: hidden; white-space: nowrap;
  border-top: 1px solid rgba(255,61,0,.6);
  border-bottom: 1px solid rgba(255,215,0,.35);
}
.file-strip span {
  display: inline-block;
  font-family: var(--ff-body); font-size: .68rem; letter-spacing: 5px;
  text-transform: uppercase; color: rgba(255,255,255,.9);
  animation: marquee 20s linear infinite;
  padding-right: 80px;
}
.file-strip-alt {
  background: linear-gradient(90deg, var(--bg), var(--bg4), var(--bg));
  border-top: 2px solid var(--red-dark);
  border-bottom: 2px solid var(--red-dark);
}
.file-strip-alt span { color: var(--red-bright); }
@keyframes marquee { from{transform:translateX(100vw)} to{transform:translateX(-100%)} }

.container { max-width: 1200px; margin: 0 auto; padding: 0 28px; }

.sec-header {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  column-gap: 28px;
  margin-bottom: 70px;
  align-items: start;
  max-width: 640px;
}
.sec-number {
  grid-row: 1 / 3;
  font-family: var(--ff-title); font-size: clamp(4rem,8vw,7rem);
  color: rgba(255,61,0,.18); line-height: 1; align-self: center;
}
.sec-title {
  font-family: var(--ff-title); font-size: clamp(2.2rem,5vw,4rem);
  line-height: 1; color: var(--cream); letter-spacing: 3px;
}
.sec-title em {
  font-style: normal; color: var(--red-bright);
  text-shadow: 0 0 28px var(--red-glow);
}
.sec-desc {
  font-family: var(--ff-body); font-size: .93rem; color: var(--gray-lt);
  line-height: 1.8; margin-top: 12px;
}

/* Botões */
.cta-primary {
  position: relative; display: inline-flex; align-items: center;
  gap: 10px; padding: 15px 34px;
  background: linear-gradient(135deg, var(--red), var(--red-dark));
  color: #fff;
  font-family: var(--ff-head); font-size: .88rem; font-weight: 600;
  letter-spacing: 3px; text-transform: uppercase;
  border: none; overflow: hidden;
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
  transition: background .25s, box-shadow .3s;
  cursor: pointer;
  box-shadow: 0 4px 24px rgba(255,61,0,.5), 0 0 40px rgba(255,61,0,.2);
}
.cta-primary:hover {
  background: linear-gradient(135deg, var(--red-bright), var(--red));
  box-shadow: 0 0 40px var(--red-glow), 0 0 80px rgba(255,215,0,.15);
}
.cta-glow {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.1), transparent);
  pointer-events: none;
}
.cta-block { width: 100%; justify-content: center; }

.cta-secondary {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 13px 32px; background: transparent;
  border: 1px solid rgba(255,61,0,.65); color: rgba(255,215,0,.85);
  font-family: var(--ff-head); font-size: .88rem; font-weight: 600;
  letter-spacing: 3px; text-transform: uppercase;
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
  transition: all .25s; cursor: pointer;
}
.cta-secondary:hover {
  background: rgba(255,61,0,.15);
  border-color: var(--yellow);
  color: var(--yellow-bright);
  box-shadow: 0 0 22px rgba(255,61,0,.35);
}

/* ================================================================
   HERO
   ================================================================ */
.hero {
  position: relative; min-height: 100vh;
  display: flex; flex-direction: column; align-items: stretch; justify-content: flex-end;
  overflow: hidden;
}

.hero-bg { position: absolute; inset: 0; z-index: 0; }
.hero-bg-img {
  position: absolute; inset: 0;
  background: url('../images/banner-hero.jpg') center top / cover no-repeat;
  transform: scale(1.04);
  animation: slowZoom 22s ease-in-out infinite alternate;
}
@keyframes slowZoom { from{transform:scale(1.04)} to{transform:scale(1.10)} }

.hero-vignette {
  position: absolute; inset: 0;
  background:
    linear-gradient(to bottom,
      rgba(10,1,1,.7)   0%,
      rgba(10,1,1,.15)  25%,
      rgba(10,1,1,.2)   60%,
      rgba(10,1,1,.92)  100%
    ),
    radial-gradient(ellipse at center, transparent 20%, rgba(10,1,1,.7) 100%);
}
.hero-red-smoke {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 5%  80%, rgba(255,61,0,.35)  0%, transparent 45%),
    radial-gradient(ellipse at 95% 15%, rgba(255,215,0,.12) 0%, transparent 40%),
    radial-gradient(ellipse at 50% 100%, rgba(255,61,0,.22) 0%, transparent 50%);
}

/* fitas vermelhas */
.red-tape {
  position: absolute; left: -5%; top: 20%;
  width: 110%; height: 2px;
  background: linear-gradient(90deg,
    transparent, rgba(255,61,0,.5), rgba(255,80,0,.9),
    rgba(255,61,0,.5), transparent);
  transform: rotate(-7deg); z-index: 1;
  box-shadow: 0 0 14px rgba(255,61,0,.5);
}
.red-tape-2 { top: 75%; transform: rotate(5deg); opacity: .5; }

/* contador */
.countdown-bar {
  position: absolute; top: 84px; right: 48px; z-index: 2;
  display: flex; align-items: center; gap: 16px;
  background: rgba(10,1,1,.85);
  border: 1px solid rgba(255,61,0,.6);
  backdrop-filter: blur(10px);
  padding: 10px 20px;
  clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));
  box-shadow: 0 0 22px rgba(255,61,0,.3);
}
.cd-label {
  font-family: var(--ff-body); font-size: .58rem; letter-spacing: 3px;
  color: rgba(255,215,0,.9); text-transform: uppercase;
}
.cd-timer { display: flex; align-items: center; gap: 6px; }
.cd-unit  { display: flex; flex-direction: column; align-items: center; min-width: 36px; }
.cd-unit span {
  font-family: var(--ff-title); font-size: 1.6rem; color: var(--red-bright);
  line-height: 1; text-shadow: 0 0 14px var(--red-glow);
}
.cd-unit em {
  font-style: normal; font-size: .48rem; letter-spacing: 2px;
  color: var(--gray); font-family: var(--ff-body);
}
.cd-sep {
  font-family: var(--ff-title); font-size: 1.4rem;
  color: var(--red-bright); animation: blink 1s infinite;
}

/* hero content */
.hero-content {
  position: relative; z-index: 2;
  width: 100%; max-width: 1200px; margin: 0 auto;
  display: flex; flex-direction: column; align-items: flex-start;
  padding: 0 48px 80px;
}

.classified-stamp {
  font-family: var(--ff-body); font-size: .6rem; letter-spacing: 5px;
  color: rgba(255,61,0,.95); border: 1px solid rgba(255,61,0,.55);
  background: rgba(10,1,1,.7); backdrop-filter: blur(4px);
  padding: 5px 16px; margin-bottom: 22px;
  transform: rotate(-1deg); text-transform: uppercase;
  box-shadow: 0 0 14px rgba(255,61,0,.2);
}

.hero-title {
  display: flex; flex-direction: column; align-items: flex-start;
  margin-bottom: 18px; gap: 0;
}
.ht-line { display: block; line-height: 1; }
.ht-sm {
  font-family: var(--ff-head); font-size: clamp(1rem,2.5vw,1.5rem);
  letter-spacing: 10px; color: rgba(255,215,0,.8); font-weight: 300;
  text-shadow: 0 2px 10px rgba(0,0,0,.95);
}
.ht-big {
  font-family: var(--ff-title); font-size: clamp(3.5rem,10vw,8.5rem);
  letter-spacing: 2px; line-height: .95;
  display: flex; align-items: baseline; gap: 0;
}
.ht-med {
  font-family: var(--ff-title); font-size: clamp(1.8rem,5vw,4.2rem);
  color: var(--red-bright); letter-spacing: 5px;
  text-shadow: 2px 3px 0 rgba(0,0,0,.95), 0 0 30px var(--red-glow);
}

.hero-divider {
  display: flex; align-items: center; gap: 14px; margin-bottom: 16px;
}
.hd-line {
  width: 55px; height: 1px;
  background: linear-gradient(to right, transparent, rgba(255,61,0,.9));
}
.hd-line:last-child { background: linear-gradient(to left, transparent, rgba(255,215,0,.7)); }
.hd-icon { color: var(--red-bright); font-size: .85rem; }

.hero-tagline {
  font-family: var(--ff-type); font-size: clamp(.85rem,1.8vw,1.05rem);
  color: rgba(255,255,255,.85); line-height: 1.9; margin-bottom: 6px;
  text-shadow: 0 1px 8px rgba(0,0,0,.95);
  background: rgba(10,1,1,.5); backdrop-filter: blur(3px);
  padding: 6px 14px; display: inline-block;
  border-left: 2px solid rgba(255,61,0,.6);
}
.hero-sig {
  font-family: var(--ff-type); font-size: .82rem;
  color: rgba(255,61,0,.9);
  margin-bottom: 36px; letter-spacing: 2px;
  text-shadow: 0 1px 6px rgba(0,0,0,.9);
}
.hero-ctas { display: flex; gap: 16px; flex-wrap: wrap; align-items: flex-start; }

.hero-scroll-hint {
  position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 8px; z-index: 2;
}
.scroll-line {
  width: 1px; height: 48px;
  background: linear-gradient(to bottom, var(--red-bright), transparent);
  animation: scrollPulse 1.8s ease-in-out infinite;
  box-shadow: 0 0 8px var(--red-glow);
}
@keyframes scrollPulse { 0%,100%{opacity:1;transform:scaleY(1)} 50%{opacity:.3;transform:scaleY(.6)} }
.hero-scroll-hint span {
  font-family: var(--ff-body); font-size: .58rem; letter-spacing: 4px;
  color: rgba(255,61,0,.6);
}

/* ================================================================
   SOBRE
   ================================================================ */
.sobre {
  padding: 90px 0 100px;
  background: linear-gradient(180deg, var(--bg2) 0%, var(--bg3) 100%);
  position: relative;
}
.sobre::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(255,61,0,.08) 0%, transparent 60%);
  pointer-events: none;
}

.plano-grid {
  display: grid; grid-template-columns: 1fr 280px 1fr;
  gap: 28px; align-items: start;
}

.plano-card {
  background: var(--bg4);
  border: var(--border-dim);
  position: relative; overflow: hidden;
  transition: border-color .35s, transform .35s, box-shadow .35s;
}
.plano-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--red-dark), transparent);
  transition: background .35s;
}
.plano-card:hover {
  border-color: rgba(255,61,0,.6);
  transform: translateY(-6px);
  box-shadow: 0 20px 50px rgba(0,0,0,.6), 0 0 40px rgba(255,61,0,.15);
}
.plano-card:hover::before {
  background: linear-gradient(90deg, transparent, var(--red-bright), transparent);
}

.plano-card-num {
  position: absolute; top: 14px; right: 16px;
  font-family: var(--ff-title); font-size: 4rem;
  color: rgba(255,61,0,.12); line-height: 1; z-index: 0;
}

.plano-card-img { position: relative; overflow: hidden; aspect-ratio: 16/9; }
.plano-card-img img {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(.75) brightness(.85);
  transition: transform .5s ease, filter .5s ease;
}
.plano-card:hover .plano-card-img img { transform: scale(1.06); filter: saturate(1) brightness(1); }

.card-img-overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(10,1,1,.9));
  padding: 16px 18px 10px;
}
.card-img-overlay span {
  font-family: var(--ff-body); font-size: .62rem; letter-spacing: 4px;
  color: var(--red-bright); text-transform: uppercase;
}

.plano-card-body { padding: 22px 22px 26px; position: relative; z-index: 1; }
.plano-card-tag {
  display: inline-block;
  font-family: var(--ff-body); font-size: .58rem; letter-spacing: 3px;
  background: rgba(255,61,0,.18); color: var(--red-bright);
  border: 1px solid rgba(255,61,0,.4); padding: 3px 10px;
  text-transform: uppercase; margin-bottom: 12px;
}
.plano-card-body h3 {
  font-family: var(--ff-title); font-size: 1.8rem; letter-spacing: 3px;
  color: var(--cream); margin-bottom: 10px;
}
.plano-card-body p {
  font-family: var(--ff-body); font-size: .88rem;
  color: var(--gray-lt); line-height: 1.75; margin-bottom: 18px;
}
.plano-stat { display: flex; flex-wrap: wrap; gap: 14px; }
.plano-stat span {
  font-family: var(--ff-body); font-size: .7rem; letter-spacing: 1px;
  color: rgba(255,215,0,.55); display: flex; align-items: center; gap: 6px;
}
.plano-stat i { color: var(--red-bright); }

/* card central */
.plano-card-center {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 28px 16px;
  border: 1px solid rgba(255,61,0,.4);
  background: linear-gradient(180deg, var(--bg4), var(--bg5));
}
.big-mask-svg {
  width: 155px; margin-bottom: 20px;
  filter: drop-shadow(0 0 20px rgba(255,61,0,.6)) drop-shadow(0 0 40px rgba(255,61,0,.2));
  animation: maskFloat 5s ease-in-out infinite;
}
@keyframes maskFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
.center-quote {
  font-family: var(--ff-type); font-size: .93rem;
  color: rgba(255,255,255,.8); line-height: 1.9;
  margin-bottom: 12px; font-style: normal;
  border-left: 2px solid rgba(255,61,0,.5);
  padding-left: 12px; text-align: left;
}
.plano-card-center cite {
  font-family: var(--ff-type); font-size: .82rem; color: var(--red-bright);
  margin-bottom: 22px; display: block;
}
.center-code {
  font-family: var(--ff-title); font-size: 1.3rem; letter-spacing: 8px;
  color: rgba(255,61,0,.3);
}

/* ================================================================
   GALERIA
   ================================================================ */
.galeria {
  padding: 90px 0 100px;
  background: linear-gradient(180deg, var(--bg) 0%, var(--bg2) 100%);
  position: relative;
}
.galeria::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 50%, rgba(255,61,0,.05) 0%, transparent 70%);
  pointer-events: none;
}

.galeria-filtros {
  display: flex; gap: 12px; justify-content: center;
  flex-wrap: wrap; margin-bottom: 52px;
}
.filtro-btn {
  font-family: var(--ff-head); font-size: .7rem; font-weight: 600;
  letter-spacing: 3px; text-transform: uppercase;
  padding: 10px 26px; background: transparent;
  border: 1px solid rgba(255,61,0,.3); color: var(--gray-lt);
  display: flex; align-items: center; gap: 8px;
  clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));
  transition: all .25s;
}
.filtro-btn .fb-num {
  font-family: var(--ff-title); font-size: 1rem; color: var(--red);
}
.filtro-btn.active, .filtro-btn:hover {
  background: linear-gradient(135deg, var(--red), var(--red-dark));
  color: #fff; border-color: var(--red);
  box-shadow: 0 0 22px var(--red-glow2);
}
.filtro-btn.active .fb-num, .filtro-btn:hover .fb-num { color: #fff; }

.galeria-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 24px; margin-bottom: 60px;
}

.gal-item {
  background: var(--bg3); border: var(--border-dim);
  position: relative; cursor: pointer;
  transition: transform .35s, border-color .35s, box-shadow .35s;
}
.gal-item:hover {
  transform: rotate(0deg) scale(1.03);
  border-color: rgba(255,61,0,.55);
  box-shadow: 0 16px 50px rgba(0,0,0,.6), 0 0 30px rgba(255,61,0,.15);
}
.gal-item:nth-child(odd)  { transform: rotate(-0.5deg); }
.gal-item:nth-child(even) { transform: rotate(0.4deg); }

.gal-tape {
  position: absolute; z-index: 3; width: 50px; height: 13px;
  background: rgba(255,61,0,.7);
  box-shadow: 0 2px 6px rgba(0,0,0,.4);
}
.gal-tape-tl { top: -6px; left: 18px; transform: rotate(-7deg); }
.gal-tape-tr { top: -6px; right: 18px; transform: rotate(7deg); }

.gal-photo { position: relative; overflow: hidden; aspect-ratio: 4/3; }
.gal-photo img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(.8) saturate(.65);
  transition: filter .45s;
}
.gal-item:hover .gal-photo img { filter: brightness(1) saturate(.9); }

.gal-stamp {
  position: absolute; top: 10px; left: 10px;
  font-family: var(--ff-head); font-size: .52rem; letter-spacing: 3px;
  color: var(--red-bright); background: rgba(10,1,1,.8);
  border: 1px solid rgba(255,61,0,.5); padding: 3px 8px;
  text-transform: uppercase;
}

.gal-label {
  padding: 14px 16px 18px;
  background: linear-gradient(180deg, var(--bg3), var(--bg4));
}
.gal-code {
  font-family: var(--ff-body); font-size: .56rem; letter-spacing: 3px;
  color: rgba(255,61,0,.7); margin-bottom: 5px; text-transform: uppercase;
}
.gal-label h4 {
  font-family: var(--ff-head); font-size: 1rem; font-weight: 600;
  color: var(--cream); margin-bottom: 4px; letter-spacing: 1px;
}
.gal-label p {
  font-family: var(--ff-body); font-size: .76rem; color: var(--gray); margin-bottom: 10px;
}
.gal-price {
  font-family: var(--ff-title); font-size: 1.3rem;
  color: var(--red-bright); letter-spacing: 1px;
  text-shadow: 0 0 10px rgba(255,80,0,.4);
}

.upload-zone {
  border: 1px dashed rgba(255,61,0,.4);
  background: rgba(255,61,0,.04);
  padding: 50px 30px; text-align: center;
  transition: border-color .25s, background .25s;
}
.upload-zone:hover { border-color: var(--red-bright); background: rgba(255,61,0,.08); }
.upload-zone-inner { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.upload-icon-wrap {
  width: 70px; height: 70px;
  background: rgba(255,61,0,.15); border: 1px solid rgba(255,61,0,.5);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem; color: var(--red-bright);
  clip-path: polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));
  box-shadow: 0 0 20px rgba(255,61,0,.2);
}
.upload-zone h3 {
  font-family: var(--ff-title); font-size: 1.6rem; letter-spacing: 4px; color: var(--cream);
}
.upload-zone p { font-family: var(--ff-body); font-size: .85rem; color: var(--gray); }

.uploaded-preview {
  display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; margin-top: 30px;
}
.preview-item {
  position: relative; width: 140px; height: 110px;
  border: 1px solid rgba(255,61,0,.6); overflow: hidden;
  animation: revealIn .4s ease;
  box-shadow: 0 4px 16px rgba(0,0,0,.5);
}
@keyframes revealIn { from{opacity:0;transform:scale(.8)} to{opacity:1;transform:scale(1)} }
.preview-item img { width: 100%; height: 100%; object-fit: cover; }
.remove-btn {
  position: absolute; top: 4px; right: 4px;
  background: var(--red); border: none; color: #fff;
  width: 20px; height: 20px; border-radius: 50%;
  font-size: .62rem; display: flex; align-items: center; justify-content: center;
  transition: background .2s;
}
.remove-btn:hover { background: var(--red-dark); }
.gal-item.hidden { display: none; }

/* ================================================================
   CARDÁPIO
   ================================================================ */
.cardapio-section {
  padding: 90px 0 100px;
  background: linear-gradient(180deg, var(--bg2) 0%, var(--bg3) 100%);
  position: relative;
}
.cardapio-section::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 80% 50%, rgba(255,61,0,.07) 0%, transparent 55%);
  pointer-events: none;
}

.cardapio-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }

.cardapio-briefing {
  background: var(--bg4); border: var(--border-dim); padding: 32px;
  position: relative; overflow: hidden;
}
.cardapio-briefing::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,61,0,.4), transparent);
}
.briefing-header { border-bottom: var(--border-red); padding-bottom: 14px; margin-bottom: 24px; }
.briefing-tag {
  font-family: var(--ff-body); font-size: .63rem; letter-spacing: 4px;
  color: var(--red-bright); text-transform: uppercase;
}
.briefing-list { display: flex; flex-direction: column; gap: 14px; margin-bottom: 28px; }
.briefing-list li {
  font-family: var(--ff-body); font-size: .9rem; color: var(--gray-lt);
  display: flex; align-items: center; gap: 12px;
}
.briefing-list li i { color: var(--red-bright); flex-shrink: 0; }

.horario-box {
  background: rgba(255,61,0,.08); border: 1px solid rgba(255,61,0,.35);
  padding: 18px 20px; display: flex; align-items: flex-start; gap: 16px;
}
.horario-box > i { color: var(--red-bright); margin-top: 3px; font-size: 1.1rem; }
.horario-box > div { display: flex; flex-direction: column; gap: 4px; }
.horario-box strong {
  font-family: var(--ff-head); font-size: .68rem; letter-spacing: 3px;
  color: var(--red-bright); text-transform: uppercase;
}
.horario-box span { font-family: var(--ff-body); font-size: .86rem; color: var(--gray-lt); }

.cardapio-access-card {
  background: var(--bg4); border: 1px solid rgba(255,61,0,.5);
  padding: 36px 30px; position: relative; overflow: hidden;
  box-shadow: 0 0 40px rgba(255,61,0,.08), inset 0 0 60px rgba(255,61,0,.03);
}
.cardapio-access-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--red-dark), var(--red-bright), var(--red-dark));
  box-shadow: 0 0 12px var(--red-glow);
}
.access-top { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.access-icon {
  width: 44px; height: 44px; background: rgba(255,61,0,.2);
  border: 1px solid rgba(255,61,0,.5);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; color: var(--red-bright);
  box-shadow: 0 0 12px rgba(255,61,0,.2);
}
.access-level {
  font-family: var(--ff-body); font-size: .62rem; letter-spacing: 3px;
  color: var(--red-bright); text-transform: uppercase;
}
.cardapio-access-card h3 {
  font-family: var(--ff-title); font-size: 2rem; letter-spacing: 4px;
  color: var(--cream); margin-bottom: 10px;
}
.cardapio-access-card > p {
  font-family: var(--ff-body); font-size: .88rem; color: var(--gray-lt);
  margin-bottom: 24px; line-height: 1.7;
}
.qr-block {
  border: var(--border-dim); padding: 20px;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  margin-bottom: 22px; background: rgba(255,61,0,.04);
}
.qr-frame { font-size: 5.5rem; color: rgba(255,61,0,.5); line-height: 1; }
.qr-block span {
  font-family: var(--ff-body); font-size: .72rem; color: var(--gray); letter-spacing: 1px;
}
.btn-cfg {
  background: none; border: none; color: var(--gray);
  font-family: var(--ff-body); font-size: .76rem; letter-spacing: 1px;
  display: flex; align-items: center; gap: 6px;
  margin-top: 14px; padding: 8px 0; transition: color .2s;
}
.btn-cfg:hover { color: var(--red-bright); }
.config-panel {
  background: var(--bg5); border: 1px solid rgba(255,61,0,.4);
  padding: 22px 24px; margin-top: 14px; animation: revealIn .3s ease;
}
.cfg-label {
  font-family: var(--ff-body); font-size: .68rem; letter-spacing: 3px;
  color: var(--red-bright); text-transform: uppercase; margin-bottom: 12px;
  display: flex; align-items: center; gap: 6px;
}
.cfg-input {
  width: 100%; padding: 12px 16px; margin-bottom: 12px;
  background: var(--bg4); border: 1px solid rgba(255,61,0,.4);
  color: var(--cream); font-family: var(--ff-body); font-size: .9rem;
  outline: none; transition: border-color .25s;
}
.cfg-input:focus { border-color: var(--red-bright); box-shadow: 0 0 0 2px rgba(255,61,0,.15); }
.cfg-input::placeholder { color: rgba(255,61,0,.3); }

/* ================================================================
   DEPOIMENTOS
   ================================================================ */
.depoimentos {
  padding: 90px 0 100px;
  background:
    linear-gradient(rgba(14,4,4,.94), rgba(14,4,4,.94)),
    url('https://images.pexels.com/photos/4773766/pexels-photo-4773766.jpeg?auto=compress&cs=tinysrgb&w=1600') center/cover;
  position: relative;
}
.depoimentos::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 50%, rgba(255,61,0,.1) 0%, transparent 65%);
  pointer-events: none;
}
.dep-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
.dep-card {
  background: rgba(26,8,8,.9); border: var(--border-dim);
  padding: 28px 24px; backdrop-filter: blur(8px);
  transition: border-color .3s, transform .3s, box-shadow .3s;
  position: relative; overflow: hidden;
}
.dep-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255,61,0,.5), transparent);
}
.dep-card:hover {
  border-color: rgba(255,61,0,.5);
  transform: translateY(-5px);
  box-shadow: 0 18px 50px rgba(0,0,0,.6), 0 0 30px rgba(255,61,0,.1);
}
.dep-header { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.dep-avatar {
  width: 42px; height: 42px;
  background: linear-gradient(135deg, var(--red), var(--red-dark));
  color: #fff; flex-shrink: 0;
  font-family: var(--ff-title); font-size: 1.3rem;
  display: flex; align-items: center; justify-content: center;
  clip-path: polygon(0 0,calc(100% - 6px) 0,100% 6px,100% 100%,6px 100%,0 calc(100% - 6px));
  box-shadow: 0 0 14px rgba(255,61,0,.4);
}
.dep-meta { flex: 1; }
.dep-meta strong {
  font-family: var(--ff-head); font-size: .83rem; letter-spacing: 3px;
  color: var(--cream); display: block;
}
.dep-stars { font-size: .72rem; color: var(--red-bright); letter-spacing: 3px; }
.dep-stamp-small {
  font-family: var(--ff-body); font-size: .48rem; letter-spacing: 2px;
  color: rgba(255,61,0,.7); border: 1px solid rgba(255,61,0,.35);
  padding: 2px 6px; text-transform: uppercase; background: rgba(255,61,0,.06);
}
.dep-card > p {
  font-family: var(--ff-type); font-size: .88rem;
  color: rgba(255,255,255,.7); line-height: 1.8;
}

/* ================================================================
   CONTATO
   ================================================================ */
.contato {
  padding: 90px 0 100px;
  background: linear-gradient(180deg, var(--bg3) 0%, var(--bg2) 100%);
  position: relative;
}
.contato::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 20% 50%, rgba(255,61,0,.07) 0%, transparent 50%);
  pointer-events: none;
}
.contato-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 50px; align-items: start; }

.info-file { background: var(--bg4); border: var(--border-dim); overflow: hidden; }
.info-file-header {
  background: linear-gradient(90deg, var(--red-dark), var(--red));
  padding: 12px 22px;
  font-family: var(--ff-body); font-size: .63rem; letter-spacing: 4px;
  color: #fff; text-transform: uppercase;
  box-shadow: 0 2px 12px rgba(255,61,0,.3);
}
.info-row {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 20px 22px; border-bottom: var(--border-dim);
  transition: background .2s;
}
.info-row:last-child { border-bottom: none; }
.info-row:hover { background: rgba(255,61,0,.06); }
.info-row > i { color: var(--red-bright); font-size: 1.1rem; margin-top: 2px; flex-shrink: 0; }
.info-row strong {
  font-family: var(--ff-body); font-size: .6rem; letter-spacing: 3px;
  color: var(--red-bright); text-transform: uppercase; display: block; margin-bottom: 4px;
}
.info-row span { font-family: var(--ff-body); font-size: .86rem; color: var(--gray-lt); }

.form-file-header {
  font-family: var(--ff-body); font-size: .68rem; letter-spacing: 3px;
  color: var(--red-bright); text-transform: uppercase;
  border-bottom: 1px solid rgba(255,61,0,.4);
  padding-bottom: 14px; margin-bottom: 24px;
  display: flex; align-items: center; gap: 8px;
}
.contato-form { display: flex; flex-direction: column; gap: 16px; }
.field-group  { display: flex; flex-direction: column; gap: 6px; }
.field-label {
  font-family: var(--ff-body); font-size: .58rem; letter-spacing: 3px;
  color: rgba(255,61,0,.8); text-transform: uppercase;
}
.field-input {
  background: var(--bg4); border: var(--border-dim);
  color: var(--cream); font-family: var(--ff-body); font-size: .9rem;
  padding: 13px 16px; outline: none; transition: border-color .25s, box-shadow .25s;
  resize: vertical;
}
.field-input:focus {
  border-color: rgba(255,61,0,.6);
  box-shadow: 0 0 0 3px rgba(255,61,0,.1);
}
.field-input::placeholder { color: rgba(255,61,0,.25); }
.field-textarea { min-height: 110px; }

/* ================================================================
   FOOTER
   ================================================================ */
.footer {
  background: linear-gradient(180deg, var(--bg2), var(--bg));
  border-top: 1px solid rgba(255,61,0,.4);
  position: relative;
}
.footer::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--red), transparent);
  box-shadow: 0 0 14px var(--red-glow);
}
.footer-inner {
  max-width: 1200px; margin: 0 auto; padding: 70px 28px 50px;
  display: grid; grid-template-columns: 100px 1fr auto auto;
  gap: 40px; align-items: center;
}
.footer-brand h3 {
  font-family: var(--ff-title); font-size: 1.3rem; letter-spacing: 4px;
  color: var(--red-bright); margin-bottom: 6px;
  text-shadow: 0 0 14px rgba(255,61,0,.4);
}
.footer-motto {
  font-family: var(--ff-type); font-size: .8rem;
  color: rgba(255,61,0,.6); letter-spacing: 3px;
}
.footer-nav { display: flex; flex-direction: column; gap: 10px; }
.footer-nav a {
  font-family: var(--ff-head); font-size: .7rem; letter-spacing: 3px;
  color: var(--gray); text-transform: uppercase; transition: color .2s;
}
.footer-nav a:hover { color: var(--red-bright); }
.footer-social { display: flex; gap: 10px; }
.soc-btn {
  width: 40px; height: 40px; border: 1px solid rgba(255,61,0,.4);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,61,0,.6); font-size: 1rem; transition: all .25s;
  clip-path: polygon(0 0,calc(100% - 6px) 0,100% 6px,100% 100%,6px 100%,0 calc(100% - 6px));
  background: rgba(255,61,0,.06);
}
.soc-btn:hover {
  background: var(--red); border-color: var(--red); color: #fff;
  box-shadow: 0 0 20px var(--red-glow);
}
.footer-bottom {
  border-top: 1px solid rgba(255,61,0,.15); padding: 16px 28px;
  display: flex; justify-content: center; gap: 16px; flex-wrap: wrap;
  background: rgba(255,61,0,.02);
}
.footer-bottom span {
  font-family: var(--ff-body); font-size: .62rem; letter-spacing: 3px;
  color: rgba(255,61,0,.3); text-transform: uppercase;
}

/* ================================================================
   WHATSAPP FLOAT
   ================================================================ */
.wa-float {
  position: fixed; bottom: 32px; right: 32px; z-index: 900;
  width: 58px; height: 58px; background: #25D366;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.7rem; color: #fff;
  clip-path: polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));
  transition: transform .25s, box-shadow .25s;
}
.wa-float:hover { transform: scale(1.1); box-shadow: 0 0 30px rgba(37,211,102,.6); }
.wa-pulse {
  position: absolute; inset: -4px; border-radius: 50%;
  border: 2px solid rgba(37,211,102,.5);
  animation: waPulse 2s infinite;
}
@keyframes waPulse { 0%{transform:scale(1);opacity:1} 100%{transform:scale(1.8);opacity:0} }

/* ================================================================
   MODAL
   ================================================================ */
.modal-overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(5,0,0,.94); backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center; padding: 20px;
  opacity: 0; pointer-events: none; transition: opacity .3s;
}
.modal-overlay.active { opacity: 1; pointer-events: all; }

.modal-box {
  background: var(--bg4); border: 1px solid rgba(255,61,0,.5);
  max-width: 580px; width: 100%; overflow: hidden; position: relative;
  clip-path: polygon(0 0, calc(100% - 16px) 0, 100% 16px, 100% 100%, 16px 100%, 0 calc(100% - 16px));
  transform: scale(.92); transition: transform .3s;
  box-shadow: 0 0 60px rgba(255,61,0,.15);
}
.modal-overlay.active .modal-box { transform: scale(1); }

.modal-close {
  position: absolute; top: 12px; right: 12px; z-index: 5;
  background: var(--red); border: none; color: #fff;
  width: 32px; height: 32px; font-size: .8rem;
  display: flex; align-items: center; justify-content: center;
  clip-path: polygon(0 0,calc(100% - 5px) 0,100% 5px,100% 100%,5px 100%,0 calc(100% - 5px));
  transition: background .2s;
}
.modal-close:hover { background: var(--red-dark); }

.modal-img-wrap { position: relative; }
.modal-img-wrap img { width: 100%; max-height: 360px; object-fit: cover; filter: brightness(.9); }
.modal-ref {
  position: absolute; bottom: 12px; left: 12px;
  font-family: var(--ff-body); font-size: .58rem; letter-spacing: 4px;
  color: var(--red-bright); background: rgba(5,0,0,.8);
  padding: 3px 8px; text-transform: uppercase;
}
.modal-body { padding: 22px 26px 28px; }
.modal-tag {
  font-family: var(--ff-body); font-size: .58rem; letter-spacing: 4px;
  color: var(--red-bright); text-transform: uppercase; margin-bottom: 8px;
}
.modal-body h3 {
  font-family: var(--ff-title); font-size: 1.8rem; letter-spacing: 3px;
  color: var(--cream); margin-bottom: 6px;
}
.modal-body p { font-family: var(--ff-body); font-size: .86rem; color: var(--gray); margin-bottom: 12px; }
.modal-preco {
  font-family: var(--ff-title); font-size: 1.5rem;
  color: var(--red-bright); letter-spacing: 2px;
  text-shadow: 0 0 12px rgba(255,80,0,.4);
}

/* ================================================================
   TOAST
   ================================================================ */
.toast {
  position: fixed; bottom: 110px; right: 32px; z-index: 3000;
  background: var(--bg4); border-left: 3px solid var(--red-bright);
  padding: 13px 20px; font-family: var(--ff-body); font-size: .86rem; color: var(--cream);
  box-shadow: 0 8px 30px rgba(0,0,0,.6), 0 0 20px rgba(255,61,0,.1);
  animation: toastIn .4s ease, toastOut .4s 2.8s forwards;
  max-width: 320px;
}
@keyframes toastIn  { from{transform:translateX(110%);opacity:0} to{transform:translateX(0);opacity:1} }
@keyframes toastOut { from{opacity:1} to{opacity:0} }

/* ================================================================
   RESPONSIVO
   ================================================================ */
@media(max-width:1024px){
  .plano-grid { grid-template-columns: 1fr; max-width: 520px; margin: 0 auto; }
  .plano-card-center { order: -1; }
  .cardapio-wrap { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 80px 1fr; }
  .footer-nav, .footer-social { grid-column: span 2; flex-direction: row; flex-wrap: wrap; }
}
@media(max-width:768px){
  .navbar { padding: 16px 20px; }
  .navbar.scrolled { padding: 10px 20px; }
  .nav-links {
    position: fixed; top: 0; right: -100%; width: 72%; height: 100vh;
    background: rgba(8,1,1,.98); backdrop-filter: blur(14px);
    flex-direction: column; justify-content: center; align-items: center;
    gap: 40px; border-left: 1px solid rgba(255,61,0,.5); z-index: 999;
    transition: right .35s ease;
  }
  .nav-links.open { right: 0; }
  .nav-links a { font-size: 1rem; }
  .hamburger { display: flex; }
  .countdown-bar { right: 16px; top: 72px; gap: 8px; padding: 8px 12px; }
  .cd-label { display: none; }
  .hero-content { padding: 0 20px 60px; }
  .galeria-grid { grid-template-columns: repeat(2,1fr); }
  .dep-grid { grid-template-columns: 1fr; max-width: 440px; margin: 0 auto; }
  .contato-grid { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; text-align: center; justify-items: center; }
  .hero-ctas { flex-direction: column; align-items: flex-start; }
  .sec-header { grid-template-columns: 1fr; }
  .sec-number { display: none; }
}
@media(max-width:480px){
  .galeria-grid { grid-template-columns: 1fr; max-width: 360px; margin: 0 auto; }
  .hero-title .ht-big { font-size: clamp(3rem,15vw,5rem); }
  .cardapio-access-card { padding: 24px 18px; }
}
