/* =========================================================
   MAICOLA DOCES — estilo compartilhado por todas as páginas
   Mude uma cor ou fonte aqui e ela atualiza o site inteiro.
   ========================================================= */

/* ===== TOKENS ===== */
:root{
  --cacau: #3A2113;
  --cacau-2: #2A1709;
  --caramelo: #C8793A;
  --caramelo-2: #E0A868;
  --beijinho: #FFF6EA;
  --beijinho-2: #FFFCF6;
  --morango: #E8A0A0;
  --goiabada: #9C2E1C;
  --azul-real: #5271FF;
  --vermelho-coral: #FF5757;
  --tinta: #2A1A12;
  --tinta-suave: #6B4A38;
  --liner-a: #EDCB7E;
  --liner-b: #D2A24E;
  --radius: 20px;
  --container: 1120px;
}

/* ===== RESET / BASE ===== */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--beijinho);
  color:var(--tinta);
  font-family:'Nunito Sans', sans-serif;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3{ font-family:'Fredoka', sans-serif; font-weight:600; margin:0; color:var(--cacau); line-height:1.15; }
p{ margin:0; }
::selection{ background:var(--morango); color:var(--cacau); }
:focus-visible{ outline:3px solid var(--goiabada); outline-offset:3px; border-radius:4px; }

.container{ max-width:var(--container); margin:0 auto; padding:0 24px; }
.section{ padding:96px 0; }
section[id]{ scroll-margin-top:96px; }
@media (max-width:640px){ .section{ padding:64px 0; } }

.eyebrow{
  display:inline-block; position:relative; padding-left:18px; max-width:100%;
  font-family:'Nunito Sans', sans-serif; font-weight:800; font-size:13px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--goiabada);
  margin-bottom:14px;
}
.eyebrow::before{
  content:""; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:7px; height:7px; border-radius:50%; background:var(--goiabada);
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:'Fredoka', sans-serif; font-weight:600; font-size:16px;
  padding:14px 28px; border-radius:999px; border:2px solid transparent;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  cursor:pointer; white-space:nowrap;
}
.btn-primary{ background:var(--goiabada); color:var(--beijinho-2); box-shadow:0 6px 16px rgba(156,46,28,.35); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 10px 20px rgba(156,46,28,.4); }
.btn-ghost{ background:transparent; border-color:var(--cacau); color:var(--cacau); }
.btn-ghost:hover{ background:var(--cacau); color:var(--beijinho-2); }
.btn-on-dark{ border-color:var(--beijinho); color:var(--beijinho); }
.btn-on-dark:hover{ background:var(--beijinho); color:var(--cacau); }

/* ===== HEADER ===== */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--cacau);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 24px; position:relative; z-index:2;
}
.brand{ display:flex; align-items:center; gap:10px; font-family:'Fredoka',sans-serif; font-weight:700; font-size:20px; color:var(--beijinho-2); }
.brand span{ color:var(--caramelo-2); }
.logo-img{ height:120px; width:auto; }
.site-nav{ display:flex; gap:28px; align-items:center; }
.site-nav a{ font-family:'Fredoka',sans-serif; font-weight:500; color:var(--beijinho-2); opacity:.9; padding:6px 2px; }
.site-nav a:hover{ opacity:1; border-bottom:2px solid var(--caramelo-2); }
.nav-cta{ background:var(--caramelo); color:var(--cacau-2)!important; padding:10px 20px; border-radius:999px; font-weight:600; opacity:1!important; border-bottom:none!important; }
.nav-cta:hover{ background:var(--caramelo-2); }

.nav-toggle{ display:none; background:none; border:0; width:40px; height:36px; position:relative; cursor:pointer; padding:0; }
.nav-toggle span{ position:absolute; left:6px; right:6px; height:2px; background:var(--beijinho-2); transition:transform .25s, opacity .25s; }
.nav-toggle span:nth-child(1){ top:10px; }
.nav-toggle span:nth-child(2){ top:17px; }
.nav-toggle span:nth-child(3){ top:24px; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media (max-width:760px){
  .nav-toggle{ display:block; }
  .logo-img{ height:56px; }
  .site-nav{
    position:absolute; top:100%; left:0; right:0; z-index:1;
    background:var(--cacau); flex-direction:column; align-items:flex-start;
    padding:6px 24px 22px; gap:16px; display:none;
  }
  .site-nav.open{ display:flex; }
  .nav-cta{ margin-top:4px; }
}

/* scalloped bottom edge of header (forminha de papel) */
.site-header::after{
  content:""; position:absolute; left:0; right:0; bottom:-15px; height:15px; z-index:1;
  background-image: radial-gradient(circle at 15px 0, var(--cacau) 15px, transparent 15.5px);
  background-size:30px 15px; background-repeat:repeat-x;
}

/* ===== DOCINHO (forminha pleated liner + candy) — elemento de assinatura ===== */
.docinho{
  --c1:#6b4429; --c2:#2a1709;
  width:72px; height:72px; border-radius:50%;
  background: repeating-conic-gradient(from 0deg, var(--liner-a) 0deg 15deg, var(--liner-b) 15deg 30deg);
  display:grid; place-items:center; flex:none;
  box-shadow:0 6px 14px rgba(42,23,9,.18);
}
.docinho .miolo{
  width:62%; height:62%; border-radius:50%;
  background-image:
    radial-gradient(circle at 22% 24%, rgba(255,255,255,.4) 0 3px, transparent 4px),
    radial-gradient(circle at 62% 70%, rgba(0,0,0,.14) 0 2px, transparent 3px),
    radial-gradient(circle at 35% 30%, var(--c1), var(--c2));
}
.docinho.mini{ width:40px; height:40px; }
.docinho.brand-mark{ width:30px; height:30px; }

.pote{
  width:70px; height:82px; border-radius:8px 8px 30px 30px; position:relative; flex:none;
  background:linear-gradient(to bottom, #fffaf0 0 20%, #f6e3b8 20% 44%, #c98a3e 44% 62%, #d8b06a 62% 100%);
  box-shadow:0 6px 14px rgba(42,23,9,.18), inset 0 0 0 2px rgba(255,255,255,.5);
}
.pote::before{
  content:""; position:absolute; top:-5px; left:-5px; right:-5px; height:11px;
  background:var(--caramelo-2); border-radius:7px;
}

.mini-cluster{ display:flex; align-items:center; }
.mini-cluster .docinho{ margin-left:-14px; border:3px solid var(--beijinho-2); }
.mini-cluster .docinho:first-child{ margin-left:0; }

/* ===== HERO (página inicial) ===== */
.hero{ background:var(--beijinho); overflow:hidden; }
.hero-inner{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; }
.hero-inner > div{ min-width:0; }
.hero h1{ font-size:44px; margin-bottom:18px; }
.hero p.lead{ font-size:18px; color:var(--tinta-suave); max-width:520px; margin-bottom:30px; }
.hero-ctas{ display:flex; gap:14px; flex-wrap:wrap; }

.docinho-cluster{ position:relative; display:flex; justify-content:center; align-items:flex-end; gap:20px; padding:20px; }
.docinho-cluster .docinho:nth-child(1){ width:80px; height:80px; }
.docinho-cluster .docinho:nth-child(2){ width:112px; height:112px; }
.docinho-cluster .docinho:nth-child(3){ width:70px; height:70px; }
.docinho-cluster .docinho:nth-child(4){ width:56px; height:56px; }

@media (prefers-reduced-motion:no-preference){
  .docinho-cluster .docinho:nth-child(1){ animation:float1 5s ease-in-out infinite; }
  .docinho-cluster .docinho:nth-child(2){ animation:float2 6s ease-in-out infinite; }
  .docinho-cluster .docinho:nth-child(3){ animation:float3 5.5s ease-in-out infinite; }
  .docinho-cluster .docinho:nth-child(4){ animation:float4 4.5s ease-in-out infinite; }
}
@keyframes float1{ 0%,100%{ transform:translateY(8px) rotate(-4deg); } 50%{ transform:translateY(-2px) rotate(-4deg); } }
@keyframes float2{ 0%,100%{ transform:translateY(-10px); } 50%{ transform:translateY(-18px); } }
@keyframes float3{ 0%,100%{ transform:translateY(10px) rotate(5deg); } 50%{ transform:translateY(2px) rotate(5deg); } }
@keyframes float4{ 0%,100%{ transform:translateY(0) rotate(-8deg); } 50%{ transform:translateY(-10px) rotate(-8deg); } }

@media (max-width:860px){
  .hero-inner{ grid-template-columns:1fr; text-align:center; }
  .hero p.lead{ margin-inline:auto; }
  .hero-ctas{ justify-content:center; }
}

/* ===== TÍTULO DE PÁGINA (usado em páginas que não são a inicial) ===== */
.page-title{ background:var(--beijinho); padding:64px 0 48px; text-align:center; }
.page-title h1{ font-size:38px; margin-bottom:14px; }
.page-title p{ color:var(--tinta-suave); font-size:18px; max-width:560px; margin:0 auto 26px; }
.page-title .voltar{ display:inline-block; margin-bottom:18px; color:var(--goiabada); font-family:'Fredoka',sans-serif; font-weight:600; }
.page-title .voltar:hover{ text-decoration:underline; }

/* ===== CARDS / GRID ===== */
.grid{ display:grid; gap:28px; }
.cardapio-grid{ grid-template-columns:repeat(auto-fit, minmax(240px,1fr)); margin-top:48px; }

.card{
  background:var(--beijinho-2); border-radius:var(--radius); padding:28px;
  box-shadow:0 10px 24px rgba(58,33,19,.08); position:relative;
}
.doce-card .card-visual{ margin-bottom:18px; }
.doce-card h3{ font-size:20px; margin-bottom:6px; }
.doce-card p{ color:var(--tinta-suave); font-size:15px; margin-bottom:16px; }
.price{ font-family:'Fredoka',sans-serif; font-weight:600; color:var(--cacau); font-size:18px; }
.price small{ font-family:'Nunito Sans',sans-serif; font-weight:600; color:var(--tinta-suave); font-size:13px; }

.badge{
  position:absolute; top:18px; right:18px; font-size:12px; font-weight:800;
  letter-spacing:.04em; text-transform:uppercase; padding:6px 12px; border-radius:999px;
  background:var(--goiabada); color:var(--beijinho-2);
}

/* ===== SOBRE ===== */
.sobre{ background:var(--beijinho-2); }
.sobre-inner{ display:grid; grid-template-columns:.85fr 1.15fr; gap:56px; align-items:center; }
.foto-frame{
  width:230px; height:230px; border-radius:50%; margin:0 auto; position:relative;
  background:repeating-conic-gradient(from 0deg, var(--liner-a) 0deg 12deg, var(--liner-b) 12deg 24deg);
  display:grid; place-items:center; box-shadow:0 14px 30px rgba(42,23,9,.2);
}
.foto-frame .miolo{
  width:84%; height:84%; border-radius:50%;
  background:radial-gradient(circle at 35% 30%, var(--caramelo-2), var(--caramelo));
  display:grid; place-items:center;
  font-family:'Fredoka',sans-serif; font-weight:700; font-size:72px; color:var(--cacau-2);
}
.tag-pendurada{
  position:absolute; bottom:-6px; right:6px; background:var(--cacau); color:var(--beijinho-2);
  font-family:'Fredoka',sans-serif; font-size:13px; font-weight:600; padding:6px 14px;
  border-radius:8px; transform:rotate(-6deg); box-shadow:0 6px 12px rgba(0,0,0,.2);
}
.sobre h2{ font-size:32px; margin-bottom:16px; }
.sobre p{ color:var(--tinta-suave); margin-bottom:14px; }
.sobre .assinatura{ font-family:'Fredoka',sans-serif; color:var(--cacau); font-weight:600; margin-top:18px; }

@media (max-width:860px){
  .sobre-inner{ grid-template-columns:1fr; text-align:center; }
  .sobre p{ max-width:520px; margin-inline:auto; margin-bottom:14px; }
}

/* ===== COMO PEDIR ===== */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-top:48px; }
.step{ text-align:left; }
.step .num{ font-family:'Fredoka',sans-serif; font-size:40px; font-weight:700; color:var(--caramelo); margin-bottom:10px; }
.step h3{ font-size:19px; margin-bottom:8px; }
.step p{ color:var(--tinta-suave); font-size:15px; }
.pedidos-cta{ margin-top:48px; text-align:center; }

@media (max-width:760px){ .steps{ grid-template-columns:1fr; } }

/* ===== CARDÁPIO COMPLETO (categorias) ===== */
.menu-categoria.alt-bg{ background:var(--beijinho-2); }
.categoria-cabecalho{ display:flex; align-items:center; gap:20px; margin-bottom:32px; flex-wrap:wrap; }
.categoria-cabecalho h2{ font-size:28px; margin-bottom:6px; }
.categoria-cabecalho p{ color:var(--tinta-suave); max-width:520px; }
.tamanhos-grid{ display:flex; flex-wrap:wrap; gap:16px; margin-bottom:28px; }
.tamanho-card{
  background:var(--beijinho-2); border:2px solid var(--caramelo-2); border-radius:14px;
  padding:14px 22px; display:flex; flex-direction:column; gap:4px; min-width:150px;
}
.menu-categoria.alt-bg .tamanho-card{ background:var(--beijinho); }
.tamanho-label{ font-family:'Fredoka',sans-serif; font-weight:600; color:var(--cacau); font-size:17px; }
.tamanho-preco{ font-size:14px; color:var(--tinta-suave); }
.sabores{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.sabores-label{ font-family:'Fredoka',sans-serif; font-weight:600; color:var(--cacau); margin-right:4px; }
.sabor-chip{
  background:var(--morango); color:var(--cacau-2); font-size:14px; font-weight:600;
  padding:7px 16px; border-radius:999px;
}
.menu-cta{
  background:var(--cacau); border-radius:var(--radius); padding:40px; text-align:center; color:var(--beijinho-2);
}
.menu-cta h2{ color:var(--beijinho-2); font-size:26px; margin-bottom:10px; }
.menu-cta p{ color:#E6D2C2; margin-bottom:22px; max-width:480px; margin-inline:auto; }

@media (max-width:600px){
  .categoria-cabecalho{ text-align:center; justify-content:center; }
  .categoria-cabecalho p{ margin:0 auto; }
  .sabores{ justify-content:center; }
}

/* ===== FOOTER ===== */
.site-footer{ background:var(--cacau); color:var(--beijinho-2); padding-top:64px; position:relative; }
.site-footer::before{
  content:""; position:absolute; left:0; right:0; top:-15px; height:15px;
  background-image: radial-gradient(circle at 15px 15px, var(--cacau) 15px, transparent 15.5px);
  background-size:30px 15px; background-repeat:repeat-x;
}
.footer-grid{ display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:40px; padding-bottom:40px; }
.footer-brand{ display:flex; align-items:center; gap:10px; margin-left:40px; font-family:'Fredoka',sans-serif; font-weight:700; font-size:20px; margin-bottom:10px; }
.footer-brand span{ color:var(--caramelo-2); }
.logo-img-footer{ height:100px; width:auto; }
.footer-tagline{ color:#E6D2C2; font-size:15px; max-width:280px; margin-left:40px; }
.footer-col h4{ font-family:'Nunito Sans',sans-serif; font-weight:800; font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--caramelo-2); margin-bottom:14px; }
.footer-col a, .footer-col p{ display:block; color:#F3E6D8; font-size:15px; margin-bottom:10px; }
.footer-col a:hover{ color:var(--beijinho-2); text-decoration:underline; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); padding:20px 0; text-align:center; font-size:13px; color:#C9AE99; }

@media (max-width:760px){ .footer-grid{ grid-template-columns:1fr; gap:28px; text-align:center; } .footer-brand{ justify-content:center; margin-left:0; } .footer-tagline{ margin-inline:auto; } .logo-img-footer{ height:64px; } }

/* ===== WHATSAPP FLUTUANTE ===== */
.wa-float{
  position:fixed; bottom:22px; right:22px; z-index:60;
  width:58px; height:58px; border-radius:50%; background:var(--goiabada); color:var(--beijinho-2);
  display:grid; place-items:center; box-shadow:0 6px 16px rgba(0,0,0,.25);
}
@media (prefers-reduced-motion:no-preference){ .wa-float{ animation:pulse 2.6s ease-in-out infinite; } }
@keyframes pulse{ 0%,100%{ box-shadow:0 6px 16px rgba(0,0,0,.25); } 50%{ box-shadow:0 6px 24px rgba(156,46,28,.55); } }

/* ===== REVEAL ON SCROLL ===== */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in-view{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .docinho-cluster .docinho{ animation:none!important; }
  .wa-float{ animation:none!important; }
}
