﻿/* =========================================================
   VARIÁVEIS & RESET
========================================================= */
:root {
  --vermelho: #B83227;
  --laranja: #D4651A;
  --dourado: #E8A020;
  --creme: #FBF3E8;
  --creme-escuro: #F0E4D0;
  --cafe: #1E1008;
  --cafe-medio: #3A1F0D;
  --marrom: #6B4226;
  --texto: #2D1A0A;
  --texto-claro: #7A5535;
  --borda: #DDD0BB;
  --branco: #FFFFFF;

  --f-titulo: 'Playfair Display', Georgia, serif;
  --f-cursivo: 'Dancing Script', cursive;
  --f-corpo: 'Lato', sans-serif;

  --sombra: 0 6px 30px rgba(30, 16, 8, .14);
  --sombra-lg: 0 16px 60px rgba(30, 16, 8, .22);
  --r: 14px;
  --r-lg: 24px;
  --ease: cubic-bezier(.4, 0, .2, 1);
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0
}

html {
  scroll-behavior: smooth;
  font-size: 16px
}

body {
  font-family: var(--f-corpo);
  color: var(--texto);
  background: var(--creme);
  overflow-x: hidden;
  line-height: 1.7
}

img {
  max-width: 100%;
  height: auto;
  display: block
}

a {
  color: var(--vermelho);
  text-decoration: none;
  transition: color .25s var(--ease)
}

ul {
  list-style: none
}

button {
  font-family: var(--f-corpo);
  cursor: pointer
}

/* =========================================================
   TIPOGRAFIA
========================================================= */
h1,
h2,
h3,
h4 {
  font-family: var(--f-titulo);
  line-height: 1.2;
  color: var(--cafe)
}

h1 {
  font-size: clamp(2.2rem, 5.5vw, 4rem)
}

h2 {
  font-size: clamp(1.9rem, 3.8vw, 3rem)
}

h3 {
  font-size: clamp(1.25rem, 2.2vw, 1.7rem)
}

h4 {
  font-size: 1.15rem
}

p {
  margin-bottom: 1rem
}

.cursivo {
  font-family: var(--f-cursivo);
  font-weight: 700
}

.label-secao {
  font-family: var(--f-cursivo);
  color: var(--vermelho);
  font-size: 1.35rem;
  display: block;
  margin-bottom: 6px
}

/* =========================================================
   LAYOUT
========================================================= */
.container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 28px
}

section {
  padding: 83px 0
}

/* =========================================================
   BOTÕES
========================================================= */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 14px 30px;
  border-radius: 50px;
  font-weight: 700;
  font-size: .92rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  border: 2px solid transparent;
  transition: all .28s var(--ease);
  white-space: nowrap
}

.btn-vermelho {
  background: var(--vermelho);
  color: #fff;
  border-color: var(--vermelho)
}

.btn-vermelho:hover {
  background: var(--cafe-medio);
  border-color: var(--cafe-medio);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: var(--sombra)
}

.btn-contorno {
  background: transparent;
  color: #fff;
  border-color: rgba(255, 255, 255, .7)
}

.btn-contorno:hover {
  background: #fff;
  color: var(--vermelho)
}

.btn-laranja {
  background: var(--laranja);
  color: #fff;
  border-color: var(--laranja)
}

.btn-laranja:hover {
  background: var(--cafe-medio);
  border-color: var(--cafe-medio);
  color: #fff;
  transform: translateY(-2px)
}

.btn-wpp {
  background: #25D366;
  color: #fff;
  border-color: #25D366
}

.btn-wpp:hover {
  background: #1daa54;
  border-color: #1daa54;
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(37, 211, 102, .4)
}

/* =========================================================
   TÍTULO DE SEÇÃO
========================================================= */
.titulo-secao {
  text-align: center;
  margin-bottom: 60px
}

.titulo-secao h2 {
  margin-bottom: 14px
}

.titulo-secao p {
  color: var(--texto-claro);
  max-width: 520px;
  margin: 0 auto;
  font-size: 1.05rem
}

.linha {
  width: 56px;
  height: 4px;
  background: linear-gradient(90deg, var(--vermelho), var(--dourado));
  border-radius: 2px;
  margin: 18px auto 0
}

/* =========================================================
   WHATSAPP FLUTUANTE
========================================================= */
#wpp-float {
  position: fixed;
  bottom: 26px;
  right: 26px;
  z-index: 900;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: #25D366;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  box-shadow: 0 4px 20px rgba(37, 211, 102, .5);
  animation: pulseWpp 2.8s infinite;
  transition: transform .25s var(--ease)
}

#wpp-float:hover {
  transform: scale(1.12);
  color: #fff
}

@keyframes pulseWpp {

  0%,
  100% {
    box-shadow: 0 4px 20px rgba(37, 211, 102, .5)
  }

  50% {
    box-shadow: 0 4px 44px rgba(37, 211, 102, .85)
  }
}

/* =========================================================
   HEADER
========================================================= */
#header {
  background: var(--cafe);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 800;
  padding: 18px 0;
  transition: all .35s var(--ease)
}

#header.solid {
  background: var(--cafe);
  padding: 10px 0;
  box-shadow: 0 2px 24px rgba(0, 0, 0, .35)
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 26px
}

.banner-inicio {
  display: flex;
  align-items: flex-start;
  gap: 13px;
  text-decoration: none
}

.logo {
  display: flex;
  align-items: center;
  gap: 13px;
  text-decoration: none
}

.logo-icone {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: var(--vermelho);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.55rem;
  flex-shrink: 0;
  box-shadow: 0 3px 14px rgba(184, 50, 39, .45)
}

.logo-nome {
  font-family: var(--f-titulo);
  font-size: 1.35rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.1;
  display: block
}

.logo-sub {
  font-family: var(--f-cursivo);
  font-size: .82rem;
  color: var(--dourado);
  display: block
}

nav ul {
  display: flex;
  align-items: center;
  gap: 30px
}

nav a {
  color: rgba(255, 255, 255, .82);
  font-weight: 700;
  font-size: .88rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 4px 0;
  border-bottom: 2px solid transparent;
  transition: all .25s var(--ease)
}

nav a:hover,
nav a.ativo {
  color: var(--dourado);
  border-bottom-color: var(--dourado)
}

.header-acoes {
  display: flex;
  align-items: center;
  gap: 14px
}

.btn-pedir {
  background: var(--vermelho);
  color: #fff;
  padding: 10px 22px;
  border-radius: 50px;
  font-weight: 700;
  font-size: .84rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  transition: all .25s var(--ease);
  border: 2px solid var(--vermelho)
}

.btn-pedir:hover {
  background: var(--dourado);
  border-color: var(--dourado);
  color: var(--cafe);
  transform: translateY(-1px)
}

.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  padding: 5px;
}

.hamburger span {
  display: block;
  width: 26px;
  height: 2px;
  background: #fff;
  border-radius: 2px;
  transition: all .3s var(--ease)
}

.hamburger.open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg)
}

.hamburger.open span:nth-child(2) {
  opacity: 0
}

.hamburger.open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg)
}

/* =========================================================
   HERO
========================================================= */
#hero {
  min-height: 100vh;
  background: var(--cafe);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center
}

/* Textura de pontos */
#hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1.5px 1.5px, rgba(255, 255, 255, .055) 1px, transparent 0);
  background-size: 30px 30px;
  z-index: 0
}

/* Gradiente diagonal quente */
#hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 80% at 70% 50%, rgba(184, 50, 39, .28) 0%, transparent 70%),
    radial-gradient(ellipse 50% 60% at 10% 80%, rgba(232, 160, 32, .15) 0%, transparent 60%);
  z-index: 0
}

.hero-conteudo {
  position: relative;
  z-index: 2;
  max-width: 700px;
  padding: 140px 0 80px
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(184, 50, 39, .22);
  border: 1px solid rgba(184, 50, 39, .5);
  color: var(--dourado);
  padding: 8px 20px;
  border-radius: 50px;
  font-size: .82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 26px;
  backdrop-filter: blur(8px)
}

#hero h1 {
  color: #fff;
  margin-bottom: 14px
}

#hero h1 .sub {
  font-family: var(--f-cursivo);
  color: var(--dourado);
  font-size: .68em;
  display: block;
  font-weight: 700;
  margin-bottom: 4px
}

.hero-desc {
  color: rgba(255, 255, 255, .78);
  font-size: 1.12rem;
  max-width: 530px;
  margin-bottom: 42px
}

.hero-btns {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}

.hero-stats {
  display: flex;
  gap: 44px;
  margin-top: 64px;
  flex-wrap: wrap;
  padding-top: 40px;
  border-top: 1px solid rgba(255, 255, 255, .1)
}

.stat span {
  font-family: var(--f-titulo);
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--dourado);
  display: block;
  line-height: 1
}

.stat small {
  font-size: .76rem;
  color: rgba(255, 255, 255, .5);
  text-transform: uppercase;
  letter-spacing: .08em;
  display: block;
  margin-top: 5px
}

/* Onda separadora */
.hero-wave {
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  z-index: 2
}

.hero-wave svg {
  display: block;
  width: 100%
}

/* =========================================================
   DIFERENCIAIS (faixa escura)
========================================================= */
#diferenciais {
  background: var(--cafe-medio);
  padding: 56px 0
}

.dif-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px
}

.dif-card {
  text-align: center;
  padding: 34px 22px;
  border-radius: var(--r);
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(255, 255, 255, .07);
  transition: all .3s var(--ease)
}

.dif-card:hover {
  background: rgba(184, 50, 39, .16);
  border-color: rgba(184, 50, 39, .4);
  transform: translateY(-5px)
}

.dif-icone {
  font-size: 2.8rem;
  display: block;
  margin-bottom: 16px
}

.dif-card h4 {
  color: #fff;
  margin-bottom: 8px;
  font-size: 1.05rem
}

.dif-card p {
  color: rgba(255, 255, 255, .5);
  font-size: .88rem;
  margin: 0;
  line-height: 1.6
}

/* =========================================================
   SOBRE
========================================================= */
#sobre {
  background: var(--creme)
}

.sobre-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center
}

.sobre-visual {
  position: relative
}

.sobre-foto {
  width: 100%;
  aspect-ratio: 4/5;
  border-radius: var(--r-lg);
  background: linear-gradient(145deg, #d4956a 0%, #a0522d 40%, var(--cafe-medio) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 7rem;
  box-shadow: var(--sombra-lg);
  overflow: hidden;
  position: relative
}

.sobre-foto::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(30, 16, 8, .6) 0%, transparent 50%)
}

.sobre-chip {
  position: absolute;
  bottom: -18px;
  right: -18px;
  background: var(--vermelho);
  color: #fff;
  padding: 9px;
  border-radius: var(--r);
  text-align: center;
  box-shadow: var(--sombra-lg)
}

.sobre-chip b {
  font-family: var(--f-titulo);
  font-size: 2.6rem;
  line-height: 1;
  display: block
}

.sobre-chip small {
  font-size: .72rem;
  opacity: .85;
  text-transform: uppercase;
  letter-spacing: .05em;
  display: block;
  margin-top: 3px
}

.sobre-texto .label-secao {
  margin-bottom: 10px
}

.sobre-texto h2 {
  margin-bottom: 20px
}

.sobre-texto p {
  color: var(--texto-claro)
}

.checks {
  display: flex;
  flex-direction: column;
  gap: 13px;
  margin: 28px 0
}

.checks li {
  display: flex;
  align-items: center;
  gap: 13px;
  font-weight: 700;
  color: var(--texto);
  font-size: .95rem
}

.checks li::before {
  content: '✓';
  width: 28px;
  height: 28px;
  border-radius: 50%;
  flex-shrink: 0;
  background: rgba(184, 50, 39, .12);
  color: var(--vermelho);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .82rem;
  font-weight: 900
}

/* =========================================================
   CARDÁPIO
========================================================= */
#cardapio {
  background: var(--creme-escuro)
}

.filtros {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 50px
}

.filtro {
  padding: 10px 24px;
  border-radius: 50px;
  border: 2px solid var(--borda);
  background: transparent;
  color: var(--texto-claro);
  font-weight: 700;
  font-size: .88rem;
  cursor: pointer;
  transition: all .25s var(--ease)
}

.filtro:hover,
.filtro.ativo {
  background: var(--vermelho);
  border-color: var(--vermelho);
  color: #fff
}

.pratos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
  gap: 28px
}

.prato {
  background: #fff;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--sombra);
  transition: all .32s var(--ease);
  border: 1px solid var(--borda)
}

.prato:hover {
  transform: translateY(-7px);
  box-shadow: var(--sombra-lg)
}

.prato-img {
  height: 210px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 5.5rem;
  overflow: hidden
}

.prato-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block
}

.prato-img.bg1 {
  background: linear-gradient(135deg, #f5deb3, #deb887)
}

.prato-img.bg2 {
  background: linear-gradient(135deg, #ffe4c4, #f4a460)
}

.prato-img.bg3 {
  background: linear-gradient(135deg, #d4edda, #a8d5b0)
}

.prato-img.bg4 {
  background: linear-gradient(135deg, #fff3cd, #ffc107)
}

.prato-img.bg5 {
  background: linear-gradient(135deg, #f8d7da, #f1a0a7)
}

.prato-img.bg6 {
  background: linear-gradient(135deg, #cce5ff, #9ec5fe)
}

.tag {
  position: absolute;
  top: 14px;
  left: 14px;
  padding: 4px 13px;
  border-radius: 50px;
  font-size: .72rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #fff
}

.tag-popular {
  background: var(--vermelho)
}

.tag-novo {
  background: var(--laranja)
}

.tag-vegano {
  background: #27AE60
}

.tag-fit {
  background: #2980B9
}

.prato-corpo {
  padding: 22px 24px
}

.prato-nome {
  font-family: var(--f-titulo);
  font-size: 1.18rem;
  margin-bottom: 8px;
  color: var(--cafe)
}

.prato-desc {
  color: var(--texto-claro);
  font-size: .87rem;
  line-height: 1.6;
  margin-bottom: 18px
}

.prato-rodape {
  display: flex;
  align-items: center;
  justify-content: space-between
}

.prato-preco {
  font-family: var(--f-titulo);
  font-size: 1.55rem;
  font-weight: 700;
  color: var(--vermelho);
  line-height: 1
}

.prato-preco small {
  font-size: .7rem;
  color: var(--texto-claro);
  font-family: var(--f-corpo);
  font-weight: 400;
  display: block
}

.btn-add {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--vermelho);
  color: #fff;
  border: none;
  font-size: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .25s var(--ease);
  flex-shrink: 0
}

.btn-add:hover {
  background: var(--cafe-medio);
  transform: scale(1.12)
}

/* =========================================================
   COMO FUNCIONA
========================================================= */
#como-funciona {
  background: #fff
}

.passos {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  position: relative
}

.passos::before {
  content: '';
  position: absolute;
  top: 44px;
  left: calc(12.5% + 10px);
  right: calc(12.5% + 10px);
  height: 2px;
  background: linear-gradient(90deg, var(--vermelho), var(--laranja), var(--dourado));
  z-index: 0
}

.passo {
  text-align: center;
  position: relative;
  z-index: 1
}

.passo-num {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  background: var(--creme);
  border: 3px solid var(--vermelho);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-family: var(--f-titulo);
  font-size: 2rem;
  font-weight: 700;
  color: var(--vermelho)
}

.passo-emoji {
  font-size: 2.1rem;
  display: block;
  margin-bottom: 12px
}

.passo h4 {
  margin-bottom: 8px
}

.passo p {
  color: var(--texto-claro);
  font-size: .88rem;
  margin: 0;
  line-height: 1.6
}

/* =========================================================
   CTA BANNER
========================================================= */
#cta {
  background: linear-gradient(135deg, var(--vermelho) 0%, #8B1A10 100%);
  position: relative;
  overflow: hidden
}

#cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 2px 2px, rgba(255, 255, 255, .07) 1px, transparent 0);
  background-size: 26px 26px
}

.cta-inner {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap
}

.cta-txt h2 {
  color: #fff;
  margin-bottom: 10px
}

.cta-txt p {
  color: rgba(255, 255, 255, .8);
  font-size: 1.05rem;
  margin: 0
}

.cta-btns {
  display: flex;
  gap: 14px;
  flex-wrap: wrap
}

/* =========================================================
   DEPOIMENTOS
========================================================= */
#depoimentos {
  background: var(--cafe)
}

#depoimentos .titulo-secao h2 {
  color: #fff
}

#depoimentos .titulo-secao p {
  color: rgba(255, 255, 255, .55)
}

#depoimentos .linha {
  background: linear-gradient(90deg, var(--vermelho), var(--dourado))
}

.deps-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px
}

.dep {
  background: rgba(255, 255, 255, .055);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: var(--r-lg);
  padding: 32px;
  transition: all .3s var(--ease)
}

.dep:hover {
  background: rgba(255, 255, 255, .09);
  transform: translateY(-5px)
}

.dep-estrelas {
  color: var(--dourado);
  font-size: 1.05rem;
  display: block;
  margin-bottom: 14px
}

.dep-txt {
  color: rgba(255, 255, 255, .78);
  font-size: .94rem;
  font-style: italic;
  line-height: 1.75;
  margin-bottom: 24px
}

.dep-autor {
  display: flex;
  align-items: center;
  gap: 14px
}

.dep-avatar {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  flex-shrink: 0;
  background: linear-gradient(135deg, var(--vermelho), var(--laranja));
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  color: #fff;
  font-size: .95rem
}

.dep-info b {
  color: #fff;
  display: block;
  font-size: .92rem
}

.dep-info small {
  color: rgba(255, 255, 255, .4);
  font-size: .78rem
}

/* =========================================================
   HORÁRIOS & LOCALIZAÇÃO
========================================================= */
#contato {
  background: var(--creme)
}

.contato-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items: start
}

.bloco-titulo {
  font-family: var(--f-titulo);
  font-size: 1.55rem;
  color: var(--cafe);
  margin-bottom: 28px;
  padding-bottom: 14px;
  border-bottom: 3px solid var(--vermelho);
  display: inline-block
}

.horarios {
  display: flex;
  flex-direction: column;
  gap: 12px
}

.horario {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px;
  background: #fff;
  border-radius: var(--r);
  border: 1px solid var(--borda)
}

.horario-dia {
  font-weight: 700
}

.horario-hora {
  font-weight: 700;
  color: var(--vermelho)
}

.horario-fechado {
  color: #c0392b;
  font-weight: 700
}

.local-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 24px
}

.local-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 18px;
  background: #fff;
  border-radius: var(--r);
  border: 1px solid var(--borda)
}

.local-icone {
  font-size: 1.6rem;
  flex-shrink: 0;
  width: 42px;
  text-align: center
}

.local-txt b {
  display: block;
  font-weight: 700;
  color: var(--cafe);
  margin-bottom: 3px
}

.local-txt span {
  color: var(--texto-claro);
  font-size: .9rem;
  line-height: 1.5
}

.mapa-box {
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--sombra);
  height: 230px;
  border: 1px solid var(--borda)
}

.mapa-box iframe {
  width: 100%;
  height: 100%;
  border: none;
  display: block
}

/* =========================================================
   RODAPÉ
========================================================= */
footer {
  background: var(--cafe-medio);
  padding: 64px 0 0
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1.2fr;
  gap: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255, 255, 255, .08)
}

.footer-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  text-decoration: none
}

.footer-sobre p {
  color: rgba(255, 255, 255, .5);
  font-size: .88rem;
  line-height: 1.75;
  margin-bottom: 22px
}

.social {
  display: flex;
  gap: 11px
}

.social a {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .07);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: rgba(255, 255, 255, .65);
  text-decoration: none;
  transition: all .25s var(--ease)
}

.social a:hover {
  background: var(--vermelho);
  color: #fff;
  transform: translateY(-2px)
}

.footer-col h5 {
  font-family: var(--f-titulo);
  font-size: 1.08rem;
  color: #fff;
  margin-bottom: 18px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--vermelho);
  display: inline-block
}

.footer-col ul {
  display: flex;
  flex-direction: column;
  gap: 10px
}

.footer-col ul a {
  color: rgba(255, 255, 255, .5);
  font-size: .88rem;
  transition: all .25s var(--ease)
}

.footer-col ul a:hover {
  color: var(--dourado);
  padding-left: 6px
}

.footer-contato li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: rgba(255, 255, 255, .5);
  font-size: .88rem;
  margin-bottom: 12px
}

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  padding: 20px 0
}

.footer-bottom p {
  color: rgba(255, 255, 255, .3);
  font-size: .8rem;
  margin: 0
}

.footer-bottom a {
  color: var(--dourado)
}

/* =========================================================
   ANIMAÇÕES DE ENTRADA
========================================================= */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .6s var(--ease), transform .6s var(--ease)
}

.reveal.visivel {
  opacity: 1;
  transform: translateY(0)
}

/* =========================================================
   RESPONSIVO
========================================================= */
@media(max-width:1024px) {
  .dif-grid {
    grid-template-columns: repeat(2, 1fr)
  }

  .sobre-grid {
    grid-template-columns: 1fr;
    gap: 50px
  }

  .passos {
    grid-template-columns: repeat(2, 1fr)
  }

  .passos::before {
    display: none
  }

  .deps-grid {
    grid-template-columns: 1fr 1fr
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr
  }

  .contato-grid {
    grid-template-columns: 1fr
  }
}

@media(max-width:768px) {

  nav,
  .header-acoes .btn-pedir {
    display: none
  }

  .hamburger {
    display: flex
  }

  nav.aberta {
    display: flex;
    position: fixed;
    inset: 0;
    background: var(--cafe);
    z-index: 799;
    align-items: center;
    justify-content: center
  }

  nav.aberta ul {
    flex-direction: column;
    gap: 28px;
    text-align: center
  }

  nav.aberta a {
    font-size: 1.35rem
  }

  .pratos-grid {
    grid-template-columns: 1fr
  }

  .passos {
    grid-template-columns: 1fr
  }

  .deps-grid {
    grid-template-columns: 1fr
  }

  .footer-grid {
    grid-template-columns: 1fr
  }

  .hero-stats {
    gap: 24px
  }

  .cta-inner {
    flex-direction: column;
    text-align: center
  }

  section {
    padding: 64px 0
  }

  .sobre-chip {
    right: 0;
    bottom: -14px
  }
}

@media(max-width:480px) {

  .hero-btns,
  .cta-btns {
    flex-direction: column;
    width: 100%
  }

  .btn {
    justify-content: center;
    width: 100%
  }

  .filtros {
    gap: 8px
  }

  .filtro {
    padding: 9px 18px;
    font-size: .82rem
  }

  .dif-grid {
    grid-template-columns: 1fr
  }
}

/* =========================================================
   BOOTSTRAP ICONS
========================================================= */
.bi {
  line-height: 1;
  vertical-align: -0.12em
}

.btn .bi {
  font-size: 1.05em
}

.hero-badge .bi {
  font-size: 1.05em
}

.prato-img .bi {
  font-size: 1.5rem
}

.passo-emoji .bi,
.dif-icone .bi {
  font-size: 1em
}