:root{
  --page-max: 1080px;
  --page-gutter: clamp(16px, 3vw, 24px);
  --gutter: var(--page-gutter);  /* evita calc() inválido */
  --header-shift: 0px;           /* neutro */
  --bg:#0b1220; --panel:#0f172a; --elev:#111827; --text:#e5e7eb; --muted:#9aa6b2;
  --accent:#ef4444; --accent-2:#f59e0b; --ok:#10b981; --border:#1f2937;
  --shadow: 0 10px 30px rgba(0,0,0,.25), 0 2px 10px rgba(0,0,0,.15);
  --radius:16px;
  --step--1: clamp(.88rem, .86rem + .1vw, .95rem);
  --step-0: clamp(1rem, .98rem + .2vw, 1.125rem);
  --step-1: clamp(1.2rem, 1.1rem + .6vw, 1.5rem);
  --step-2: clamp(1.6rem, 1.35rem + 1.2vw, 2rem);
  --step-3: clamp(2rem, 1.6rem + 2vw, 2.6rem);
}
@media (prefers-color-scheme: light){
  :root{ --bg:#f8fafc; --panel:#fff; --elev:#f1f5f9; --text:#0b1220; --muted:#536174; --border:#e2e8f0;
    --shadow: 0 10px 30px rgba(0,0,0,.08), 0 2px 10px rgba(0,0,0,.05); }
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--text);
  background: url('/assets/images/bg-embers.png') center/cover repeat fixed, #0b0b0b;
  line-height: 1.7;
  letter-spacing: .2px;
}
::selection{background:rgba(239,68,68,.25)}
img{max-width:100%;height:auto;border-radius:14px}
a{color:inherit;text-decoration:none}
.container{max-width:1080px;margin:0 auto;padding:24px}
@media (min-width:1200px){.container{padding:28px}}
.site-header{position:sticky;top:0;z-index:40;background:color-mix(in hsl, var(--panel) 80%, transparent);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{font-weight:800;letter-spacing:.3px}
.nav{display:flex;gap:14px;flex-wrap:wrap}
.nav a{color:var(--muted);padding:10px 12px;border-radius:10px;transition:color .2s, background .2s, transform .1s}
.nav a:hover{color:#fff;background:rgba(255,255,255,.06)}
@media (prefers-color-scheme: light){.nav a:hover{color:#0b1220;background:rgba(0,0,0,.04)}}
.hero{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;align-items:center;padding:28px 0}
.hero h1{font-size:var(--step-3);line-height:1.1;margin:0 0 10px;text-wrap:balance}
.hero p{font-size:var(--step-0);color:var(--muted);margin:0}
/* o segundo <p> dentro do .hero (onde está o botão) */
.hero p + p {
  margin-top: 16px;   /* teste 20px ou 24px se quiser mais espaço */
}

.hero .btn {
  margin-top: 16px; /* pode testar 20px ou 24px se quiser mais espaço */
}
.hero img{box-shadow:var(--shadow)}
@media (max-width:900px){.hero{grid-template-columns:1fr}}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}
.card{background:linear-gradient(180deg, var(--panel), var(--elev));padding:18px;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 1px 0 rgba(255,255,255,.03) inset;transition:transform .18s ease, box-shadow .18s ease, border-color .18s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:color-mix(in hsl, var(--accent) 35%, var(--border))}
.card h2{margin:.2rem 0 .35rem;font-size:var(--step-1);}
.card p{margin:0;color:var(--muted)}
.post{max-width:820px}
.post h1{font-size:var(--step-2);margin:8px 0 6px}
.post h2{margin:24px 0 10px;font-size:clamp(1.25rem,1.1rem + .6vw,1.6rem)}
.post p,.post li{font-size:var(--step-0)}
.post figure{margin:18px 0}
.post figcaption{color:var(--muted);font-size:var(--step--1);margin-top:6px}
.post ul, .post ol{padding-left:20px}
.btn, .form button{
  display:inline-block; /* permite margin-top funcionar no <a> */
  background:linear-gradient(180deg, var(--accent), color-mix(in hsl, var(--accent) 80%, #000 20%));
  border:none;color:#fff;padding:12px 18px;border-radius:14px;cursor:pointer;
  font-weight:800;letter-spacing:.2px;box-shadow:0 6px 18px rgba(239,68,68,.25);
  transition:transform .08s ease, filter .18s;
}
.newsletter{margin:44px 0;background:linear-gradient(180deg, color-mix(in hsl, var(--panel) 80%, transparent), color-mix(in hsl, var(--elev) 85%, transparent));padding:22px;border-radius:16px;border:1px solid var(--border);box-shadow:0 20px 60px rgba(0,0,0,.15)}
.form{display:flex;gap:12px;flex-wrap:wrap}
.form input,.form textarea{flex:1;min-width:240px;background:#0b1323;border:1px solid #22324a;color:#fff;border-radius:12px;padding:12px;outline:none;transition:border .15s, box-shadow .15s}
.form input:focus,.form textarea:focus{border-color:color-mix(in hsl, var(--accent) 40%, #22324a);box-shadow:0 0 0 4px color-mix(in hsl, var(--accent) 15%, transparent)}
@media (prefers-color-scheme: light){.form input,.form textarea{background:#ffffff;border:1px solid var(--border);color:#0b1220}}
.ads, .post ins.adsbygoogle{margin:16px 0;padding:8px;border:1px dashed color-mix(in hsl, var(--accent-2) 40%, var(--border));border-radius:12px}
.ads::before, .post ins.adsbygoogle::before{content:"Publicidade";display:inline-block;font-size:.72rem;color:var(--muted);margin-bottom:6px}
.site-footer{background:var(--panel);border-top:1px solid var(--border);margin-top:28px}
.site-footer .container{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-nav{display:flex;gap:14px}
.footer-nav a{color:var(--muted)}
.footer-nav a:hover{color:#fff}
@media (prefers-color-scheme: light){.footer-nav a:hover{color:#0b1220}}
.cookie-banner{position:fixed;inset:auto 16px 16px 16px;background:linear-gradient(180deg, var(--panel), var(--elev));color:var(--text);border:1px solid var(--border);padding:16px;border-radius:14px;display:none;gap:12px;align-items:center;box-shadow:var(--shadow)}
.cookie-banner a{color:var(--accent-2)}
.cookie-banner button{background:linear-gradient(180deg, var(--ok), color-mix(in hsl, var(--ok) 80%, #000 20%));border:none;color:#001b0d;padding:10px 14px;border-radius:12px;font-weight:800}
hr{border:none;border-top:1px solid var(--border);margin:20px 0}
blockquote{margin:12px 0;padding:8px 14px;border-left:4px solid var(--accent-2);background:color-mix(in hsl, var(--elev) 88%, transparent);border-radius:8px}
.read-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));z-index:60}
:focus-visible{outline:3px solid color-mix(in hsl, var(--accent) 45%, transparent);outline-offset:2px;border-radius:10px}
@media (max-width:520px){ .nav{gap:8px} .hero{padding:16px 0} .newsletter{padding:16px} }
/* === Ajustes extras === */

/* Menu visível no fundo escuro */
.nav a { color: #ccc; }
.nav a:hover { color: #fff; }

/* Logo destacado */
.brand { color: #fff; }

/* Placeholder de publicidade mais neutro */
.ads { border: 1px dashed rgba(255,255,255,0.2); }

/* Hero: imagem ou bloco lateral */
.hero img { border-radius: 14px; box-shadow: var(--shadow); }

/* === Ajustes robustos para o tema de carnes === */

/* Header escuro */
.site-header {
  background: rgba(15, 10, 8, 0.9);
  border-bottom: 1px solid #2a1a14;
  backdrop-filter: blur(6px);
}

/* Texto hero */
.hero h1 { color: #fff; }
.hero p { color: #ddd; }

/* Botão brasa */
.hero .btn {
  margin-top: 18px;
  box-shadow: 0 0 15px rgba(239, 68, 68, 0.5);
}

/* Cards */
.card {
  background: rgba(20, 15, 12, 0.9);
  border: 1px solid #2d1a12;
  box-shadow: 0 4px 12px rgba(0,0,0,0.6);
}
.card h2, .card p { color: #eee; }

/* Footer */
.site-footer {
  background: rgba(15, 10, 8, 0.95);
  border-top: 1px solid #2a1a14;
}
.footer-nav a { color: #bbb; }
.footer-nav a:hover { color: #fff; }

/* === Upgrade do HERO: padding maior + gradiente suave + moldura === */
.hero{
  /* reforça o espaçamento; sobrescreve o antigo */
  padding: clamp(32px, 4vw, 64px) 0;
}

.hero-featured{
  background:
    radial-gradient(900px 300px at 15% 10%, color-mix(in hsl, var(--accent) 12%, transparent), transparent 60%),
    linear-gradient(180deg, color-mix(in hsl, var(--panel) 85%, transparent), color-mix(in hsl, var(--elev) 88%, transparent));
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: clamp(24px, 3.5vw, 40px);
  box-shadow: var(--shadow);
}

.hero-featured img{ border-radius: 18px }

.hero-featured .btn{ margin-top: 18px; box-shadow: 0 14px 26px rgba(239,68,68,.30) }
/* Painel para páginas institucionais (Sobre, Contato etc.) */
.page-panel{
  background: rgba(15,10,8,.88);
  border: 1px solid #2a1a14;
  border-radius: 16px;
  padding: 24px;
  box-shadow: 0 12px 40px rgba(0,0,0,.45);
  backdrop-filter: blur(2px);
}

/* Cores/legibilidade dentro do painel */
.page-panel h1{ color:#fff; margin-top: 0; }
.page-panel h2{ color:#fff; }
.page-panel p,.page-panel li, .page-panel small{ color:#ddd; }

/* Espaçamento extra abaixo do header fixo */
.page-spaced{ margin-top: 12px; }

@media (min-width: 900px){
  .page-panel{ padding: 28px; }
}
/* Opcional: escurece um pouco o fundo global */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.25);
  pointer-events: none;
  z-index: 0;
}
.site-header, main, footer{ position: relative; z-index: 1; }
/* ==== Força a paleta escura em todas as páginas ==== */
:root{
  color-scheme: dark;
}
@media (prefers-color-scheme: light){
  /* mantém os valores de dark mesmo que o SO esteja no modo claro */
  :root{
    --bg:#0b1220; --panel:#0f172a; --elev:#111827; --text:#e5e7eb; --muted:#9aa6b2; --border:#1f2937;
  }
}

/* ==== Garantir contraste nos títulos e textos do topo das páginas ==== */
.container > h1,
.container > p,
.page-title,
.page-intro {
  color: #fff;                 /* texto claro */
  text-shadow: 0 1px 2px rgba(0,0,0,.45); /* leve sombra pra legibilidade no fundo de carvão */
}

/* Caso algum card/herói esteja herdando cor escura por engano */
.card h2,
.card p {
  color: var(--text);
}

/* Se tiver algum link quase invisível sobre o fundo */
.nav a { color: var(--muted); }
.nav a:hover { color: #fff; }
.related { margin-block: 2.5rem 3rem; }
.related h2 { font-size: 1.25rem; margin-bottom: .75rem; }
.related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: .75rem;
}
.related-card {
  display: block; text-decoration: none; color: inherit;
  border-radius: 12px; overflow: hidden; background: #fff;
  box-shadow: 0 4px 16px rgba(0,0,0,.06); transition: transform .18s ease, box-shadow .18s ease;
}
.related-card:hover { transform: translateY(-2px); box-shadow: 0 6px 22px rgba(0,0,0,.10); }
.related-card figure { margin: 0; }
.related-card img { width: 100%; height: auto; display: block; aspect-ratio: 16/9; object-fit: cover; }
.related-card figcaption { padding: .75rem .9rem; font-weight: 600; line-height: 1.3; }

.comments { margin-block: 2.5rem 3.5rem; }
.comments h2 { font-size: 1.25rem; margin-bottom: .75rem; }
.brand { display:inline-flex; align-items:center; gap:.5rem; }
.brand img { height:32px; width:auto; display:block; }
@media (max-width: 480px) { .brand img { height:28px; } }

/* opcional: utilitário para texto apenas para leitores de tela */
.sr-only {
  position:absolute!important; height:1px;width:1px;overflow:hidden;
  clip:rect(1px,1px,1px,1px); white-space:nowrap;
}
/* Header alinhado e com respiro */
/* Header: garante altura e evita corte */
.site-header {
  /* se tiver overflow:hidden em algum lugar, remova/override: */
  overflow: visible;
}

.site-header .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 24px;

  /* dá respiro vertical e altura mínima maior que a logo */
  padding-block: 10px;          /* ↑ pode subir para 12–14px se quiser */
  min-height: 72px;             /* ajuste se usar logo maior */
}

/* Marca (ícone redondo + texto) */
.brand{
  display:inline-flex;
  align-items:center;
  gap:.1rem;
  text-decoration:none;
}

.brand img{
  height: 44px;                 /* 44–52px funciona bem */
  width:auto;
  border-radius:50%;
  display:block;                /* remove “descender gap” de img inline */
}

.brand-text{
  color:#fff;
  font-weight:800;
  font-size: clamp(18px, 2.1vw, 24px);
  line-height: 1;               /* evita empurrar a altura do header */
}
/* ===== HEADER: nunca corta a logo ===== */
:root{
  --logo-size: 48px;     /* ajuste fino: 44–52px */
  --header-pad: 5px;    /* respiro vertical */
}

.site-header{
  padding-block: var(--header-pad);
  overflow: visible;     /* garante que nada seja cortado */
}

.site-header .container{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;

  /* altura mínima = logo + paddings do header */
  min-height: calc(var(--logo-size) + 2 * var(--header-pad));
}

.brand{
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  text-decoration: none;
}

.brand img{
  height: var(--logo-size);
  width: auto;
  border-radius: 50%;
  display: block;        /* remove gap de baseline */
  margin: 0;             /* evita qualquer recuo estranho */
}

.brand-text{
  color: #fff;
  font-weight: 800;
  font-size: clamp(18px, 2.1vw, 24px);
  line-height: 1;       /* não empurra a barra */
}

/* o mesmo container em TODAS as áreas */
.container{
  width: min(100% - 2*var(--page-gutter), var(--page-max));
  margin-inline: auto;
  padding-inline: var(--page-gutter);
}

/* garante que o header use os mesmos gutters */
.site-header .container{ padding-inline: var(--page-gutter); }

/* remove qualquer “desalinhador” acidental */
.hero{ margin: 0; }
/* ===== Alinhamento fino do header com o conteúdo ===== */
:root{
  --header-nudge: -12px;  /* valor negativo = move para a ESQUERDA (teste -8, -12, -16…) */
}

.site-header .container{
  padding-left: calc(var(--page-gutter) + var(--header-nudge));
}

/* opcional: dar um passinho extra só no selo redondo */
.brand img{
  margin-left: -2px;      /* ajuste delicado no ícone (remova se não precisar) */
}

/* no mobile, volta ao normal para não colar demais nas bordas */
@media (max-width: 640px){
  :root{ --header-nudge: 0px; }
}

.site-header .container{
  /* garante que esta regra vença as anteriores */
  padding-left: calc(var(--gutter) + var(--header-shift)) !important;
  padding-right: var(--gutter) !important;
}

/* opcional: microajuste no logo/menu juntos (se quiser 2px extras) */
.site-header .container > .brand,
.site-header .container > .nav{
  transform: translateX(-2px);
}

/* no mobile não empurra pra não colar nas bordas */
@media (max-width: 640px){
  :root{ --header-shift: 0px; }
  .site-header .container > .brand,
  .site-header .container > .nav{ transform: none; }
}
/* === POST: largura, tipografia e respiros consistentes === */
.post{
  max-width: 900px;                 /* mesma “largura útil” dos posts */
  margin-inline: auto;              /* centraliza dentro do .container */
  padding-top: clamp(8px, 1.5vw, 16px);
}

.post > h1{
  font-size: clamp(1.8rem, 1.2rem + 1.8vw, 2.4rem);
  line-height: 1.15;
  margin: clamp(14px, 2vw, 24px) 0 10px;
  text-wrap: balance;               /* títulos longos quebram bonito */
}

.post figure{
  margin: 14px 0 18px;
}

.post figure img{
  display:block;
  width:100%;
  height:auto;
  border-radius: 16px;
  box-shadow: var(--shadow);
}

.post figcaption{
  color: var(--muted);
  font-size: var(--step--1);
  margin-top: 6px;
}
/* Redes sociais (footer/header) */
.social {
  display:flex; gap:12px; align-items:center; flex-wrap:wrap;
}
.social a {
  color:#bbb; background:rgba(255,255,255,.06);
  border:1px solid #2a1a14; border-radius:12px;
  padding:8px; display:inline-flex; align-items:center; justify-content:center;
  transition:transform .15s ease, background .2s, color .2s, border-color .2s;
}
.social a:hover {
  transform: translateY(-2px);
  color:#fff; background:rgba(255,255,255,.12); border-color:#3a281f;
}

.site-footer .copyright { justify-self: start; margin: 0; }
.site-footer .social    { justify-self: center; margin: 0; } /* centraliza as redes */
.site-footer .footer-nav{ justify-self: end; display:flex; gap:14px; }

/* empilha no mobile */
@media (max-width: 640px){
  .site-footer .container.footerbar{
    grid-template-columns: 1fr;
    text-align: center;
    gap: 10px;
  }
  .site-footer .footer-nav{ justify-content: center; }
}

/* --- Footer social: garantir que os SVGs apareçam --- */
.site-footer .social a { color: #e5e7eb; }              /* cor clara para currentColor */
.site-footer .social svg { width:22px; height:22px; display:block; }

/* Se o SVG tem stroke="currentColor", força o traço a aparecer */
.site-footer .social svg [stroke] { stroke: currentColor !important; }

/* Se o SVG usa fill="currentColor", garante o preenchimento */
.site-footer .social svg [fill="currentColor"] { fill: currentColor !important; }

/* (opcional) deixa o botão/área visível também */
.site-footer .social a {
  background: rgba(255,255,255,.06);
  border: 1px solid #2a1a14;
  border-radius: 12px;
  padding: 8px;
}
/* Barra do footer toda em uma linha */
.site-footer .container.footerbar{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}

/* empurra redes pro meio, links à direita */
.site-footer .copyright{ margin-right:auto; }
.site-footer .footer-nav{ margin-left:auto; display:flex; gap:16px; }

/* Redes sociais */
.social{ display:flex; gap:12px; align-items:center; }
.social a{
  color:#bbb;
  background:rgba(255,255,255,.06);
  border:1px solid #2a1a14;
  border-radius:12px;
  padding:8px;
  display:inline-flex; align-items:center; justify-content:center;
  transition:transform .15s, background .2s, color .2s, border-color .2s;
}
.social a:hover{
  transform: translateY(-2px);
  color:#fff; background:rgba(255,255,255,.12); border-color:#3a281f;
}

/* Torna os traços visíveis no fundo escuro */
.social svg{ width:22px; height:22px; stroke:currentColor; stroke-width:1.6; fill:none; }
.social svg .icon-fill{ fill:currentColor; }

/* Responsivo */
@media (max-width:640px){
  .site-footer .container.footerbar{ justify-content:center; }
  .site-footer .copyright{ order:3; width:100%; text-align:center; margin:0; }
  .social{ order:1; }
  .footer-nav{ order:2; }
}

/* texto da esquerda SEM quebra */
.site-footer .copyright{
  margin: 0;
  white-space: nowrap;   /* <<< mantém "© … — Conteúdo original." numa linha */
  flex: 0 0 auto;
}

/* Links do rodapé, encostados à direita */
.site-footer .footer-nav{
  display: flex;
  gap: 14px;
  margin-left: 16px;      /* pequeno respiro em relação às redes */
}

/* ícones um pouco mais compactos para caber melhor */
.site-footer .social a{
  padding: 6px;                  /* era 8px */
  border-radius: 10px;           /* era 12px */
}
.site-footer .social svg{
  width: 20px; height: 20px;     /* era 22px */
}

/* ===== Mobile: pode quebrar em linhas separadas ===== */
@media (max-width: 800px){
  .site-footer .container.footerbar{
    flex-wrap: wrap;             /* volta a permitir quebra */
    justify-content: center;
    row-gap: 8px;
  }
  .site-footer .copyright,
  .site-footer .footer-nav{
    width: 200%;
    text-align: center;
  }
}
/* ===== Responsividade geral ===== */

/* Evita overflow lateral por conteúdos compridos */
html, body { overflow-x: hidden; }
img, video { max-width: 100%; height: auto; }

/* Fundo "fixed" dá bug em mobile → desliga em telas menores */
@media (max-width: 900px){
  body { background-attachment: scroll; }
}

/* ===== Header / Menu ===== */
.nav-toggle{
  display: none;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: 10px;
  padding: 8px 10px;
  font: inherit;
  cursor: pointer;
}
@media (max-width: 900px){
  .site-header .container{
    gap: 10px;
  }
  .nav-toggle{ display: inline-block; }
  /* nav vira “drop-down” sob o header */
  .nav{
    display: none;
    position: absolute;
    left: 0; right: 0;
    top: 100%;
    margin-top: 8px;
    background: color-mix(in hsl, var(--panel) 92%, transparent);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    padding: 10px 16px;
    z-index: 39;
  }
  .nav.is-open{ display: block; }
  .nav a{
    display: block;
    padding: 12px;
    border-radius: 10px;
  }
  .site-header{ position: sticky; }
}

/* Garante que o container alinhe com o conteúdo em todas as páginas */
.container{ max-width: 1080px; margin: 0 auto; padding-inline: 16px; }
@media (min-width: 1200px){ .container{ padding-inline: 24px; } }

/* ===== HERO ===== */
@media (max-width: 900px){
  .hero{
    grid-template-columns: 1fr !important;
    gap: 16px;
  }
  .hero > div{ order: 1; }
  .hero img{ order: 2; width: 100%; height: auto; }
  .hero h1{ font-size: clamp(1.6rem, 5vw, 2.2rem); }
}

/* ===== Cards (grids) ===== */
.grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 18px;
}
@media (max-width: 720px){
  .grid{ grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
}
@media (max-width: 480px){
  .grid{ grid-template-columns: 1fr; }
  .card img{ height: 160px !important; }
}

/* ===== Post page ===== */
.post{ max-width: 820px; margin-inline: auto; }
@media (max-width: 720px){
  .post{ padding-inline: 4px; }
  .post figure{ margin: 12px 0; }
}

/* ===== Related (3 cards rotativos) ===== */
.related-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px,1fr));
  gap: .75rem;
}
@media (max-width: 520px){
  .related-grid{ grid-template-columns: 1fr; }
}

/* ===== Footer ===== */
.footerbar{
  display:flex; align-items:center; gap:18px;
  justify-content:space-between; flex-wrap:wrap;
}
.site-footer .social{ display:flex; gap:10px; flex-wrap:nowrap; }
@media (max-width: 720px){
  .footerbar{ justify-content: center; text-align:center; gap:12px; }
  .footer-nav{ width:100%; display:flex; gap:14px; justify-content:center; }
}
/* ====== MENU MOBILE ====== */
.nav-toggle{
  display: none;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: 10px;
  padding: 8px 10px;
  font: inherit;
  cursor: pointer;
  line-height: 1;
}

@media (max-width: 900px) {
    /* botão aparece no mobile */
    .nav-toggle {
        display: inline-block;
    }

    /* o container precisa ser referência pro dropdown absoluto */
    .site-header .container {
        position: relative;
    }

    /* nav vira dropdown abaixo do header */
    .nav {
        display: none;
        position: absolute;
        left: 0;
        right: 0;
        top: 100%;
        margin-top: 8px;
        background: color-mix(in hsl, var(--panel) 92%, transparent);
        border-top: 1px solid var(--border);
        border-bottom: 1px solid var(--border);
        padding: 10px 16px;
        z-index: 39;
    }

    .nav.is-open {
        display: block;
    }

    .nav a {
        display: block;
        padding: 12px;
        border-radius: 10px;
    }

    /* fundo “fixed” dá bug em mobile; deixa rolar */
    body {
        background-attachment: scroll;
    }

    /* Header base */
    .site-header {
        position: sticky;
        top: 0;
        z-index: 40;
        background: rgba(15, 10, 8, .9);
        border-bottom: 1px solid #2a1a14;
        padding-top: env(safe-area-inset-top); /* evita notch cobrir no iOS */
    }

    .headerbar {
        position: relative;
    }

    .site-header .container {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 16px;
    }

    /* Marca */
    .brand {
        display: flex;
        align-items: center;
        gap: .6rem;
        min-width: 0;
    }

    .brand img {
        height: 44px;
        width: auto;
        border-radius: 50%;
        display: block;
    }

    .brand-text {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        font-weight: 800;
    }

    /* Navegação (desktop) */
    .nav {
        display: flex;
        gap: 1px;
    }

    .nav a {
        color: var(--muted);
        padding: 10px 12px;
        border-radius: 10px;
    }

    .nav a:hover {
        color: #fff;
        background: rgba(255, 255, 255, .06);
    }

    /* Botão hambúrguer (esconde no desktop) */
    .nav-toggle {
        display: none;
        border: 0;
        background: transparent;
        width: 40px;
        height: 40px;
        border-radius: 10px;
        position: relative;
        cursor: pointer;
    }

    .nav-toggle .bar {
        position: absolute;
        left: 9px;
        right: 9px;
        height: 2px;
        background: #fff;
        border-radius: 1px;
        transition: transform .2s, opacity .2s, top .2s;
    }

    .nav-toggle .bar:nth-child(1) {
        top: 12px;
    }

    .nav-toggle .bar:nth-child(2) {
        top: 19px;
    }

    .nav-toggle .bar:nth-child(3) {
        top: 26px;
    }

    .nav-toggle[aria-expanded="true"] .bar:nth-child(1) {
        top: 19px;
        transform: rotate(45deg);
    }

    .nav-toggle[aria-expanded="true"] .bar:nth-child(2) {
        opacity: 0;
    }

    .nav-toggle[aria-expanded="true"] .bar:nth-child(3) {
        top: 19px;
        transform: rotate(-45deg);
    }

    /* Mobile: menu drop-down */
    @media (max-width: 900px) {
        .nav-toggle {
            display: block;
        }

        .nav {
            position: absolute;
            left: 16px;
            right: 16px;
            top: calc(100% + 6px);
            display: none;
            flex-direction: column;
            gap: 6px;
            background: rgba(15, 10, 8, .95);
            border: 1px solid #2a1a14;
            border-radius: 12px;
            padding: 8px;
            box-shadow: 0 10px 30px rgba(0, 0, 0, .45);
        }

        .nav.is-open {
            display: flex;
        }

        .nav a {
            padding: 12px;
            background: transparent;
        }

        .brand img {
            height: 36px;
        }

        /* logo um pouco menor no mobile */
    }

    /* Footer: ícones menores no mobile */
    .site-footer .social a {
        padding: 6px;
    }

    .site-footer .social svg {
        width: 18px;
        height: 18px;
    }

    @media (max-width: 520px) {
        .footerbar {
            gap: 12px;
        }

        .footer-nav a {
            padding: 6px 8px;
        }
    }
    /* ===== Header responsivo (mobile fix) ===== */
    .site-header {
        position: sticky;
        top: 0;
        z-index: 100;
    }

    .headerbar {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        padding-block: 10px;
        min-height: 64px;
    }

    .brand {
        display: inline-flex;
        align-items: center;
        gap: .6rem;
        min-width: 0;
    }

    .brand img {
        height: 40px;
        width: 40px;
        border-radius: 50%;
        flex: 0 0 auto;
    }

    .brand-text {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        max-width: 60vw;
    }

    /* botão hambúrguer */
    .nav-toggle {
        display: none;
        width: 40px;
        height: 40px;
        border: 0;
        background: rgba(255, 255, 255, .06);
        border-radius: 12px;
        align-items: center;
        justify-content: center;
    }

    .nav-toggle .bar {
        display: block;
        width: 18px;
        height: 2px;
        margin: 2px 0;
        border-radius: 2px;
        background: #fff;
    }

    /* menu drop-down */
    @media (max-width: 900px) {
        .nav-toggle {
            display: inline-flex;
            order: 2;
        }

        #primary-nav {
            position: absolute;
            top: 100%;
            left: 0;
            right: 0;
            display: none;
            background: rgba(15, 10, 8, .98);
            border-top: 1px solid #2a1a14;
            padding: 10px 16px;
        }

        #primary-nav.is-open {
            display: block;
        }

        #primary-nav a {
            display: block;
            padding: 12px 2px;
        }

        /* evita o texto da marca colidir com o botão */
        .brand-text {
            max-width: 48vw;
        }
    }

    /* telas bem pequenas: mostra só o ícone para não quebrar o layout */
    @media (max-width: 420px) {
        .brand-text {
            display: none;
        }
    }

    /* ===== Cookie banner acima do rodapé ===== */
    .cookie-banner {
        z-index: 9999;
    }

    /* garante ficar por cima do footer */
    body.has-cookie-banner {
        padding-bottom: 96px;
    }


    /* ===== Rodapé central, 3 linhas (links • redes • copyright) ===== */
.site-footer .footerbar {
    display: flex;
    flex-direction: column;      /* empilha tudo em coluna */
    align-items: center;          /* centraliza na horizontal */
    justify-content: center;
    gap: 10px;
    text-align: center;
    padding-block: 16px;
}

    /* 1ª linha: Termos • Privacidade • Sitemap (sempre no topo) */
    .site-footer .footerbar .footer-nav {
        order: 1;
        display: flex;
        gap: 15px;
        flex-wrap: wrap;
        justify-content: center;
    }

    /* 2ª linha: redes sociais no meio */
    .site-footer .footerbar .social {
        order: 2;
        display: flex;
        gap: 10px;
        flex-wrap: wrap;
        justify-content: center;
        margin: 0 !important; /* override de regras antigas */
    }

    /* 3ª linha: copyright */
    .site-footer .footerbar .copyright {
        order: 3;
        margin: 0;
        opacity: .9;
    }

    /* se existir esta regra antiga, garantimos que não empurre as redes p/ direita */
    .site-footer .social {
        margin-left: 0 !important;
    }

    /* opcional: no mobile pode ser um pouco menos */
    @media (max-width: 480px) {
        .site-footer .footerbar .footer-nav {
            transform: translateX(-6px);
        }
    }
    /* Copyright menor apenas no mobile */
    @media (max-width: 600px) {
        .site-footer .copyright {
            font-size: 0.60rem; /* ajuste fino: 0.80–0.90rem */
            line-height: 1.3;
            text-align: center; /* garante alinhamento ao centro */
            letter-spacing: .1px; /* opcional, melhora a leitura */
        }
    }

    /* Se quiser ainda menor em telas muito pequenas */
    @media (max-width: 380px) {
        .site-footer .copyright {
            font-size: 0.50rem;
        }
    }

    .comment-list {
        list-style: none;
        padding: 0;
        margin: 14px 0 0;
        display: grid;
        gap: 10px
    }

    .comment-list li {
        background: rgba(255, 255, 255, .04);
        border: 1px solid #2a1a14;
        border-radius: 12px;
        padding: 12px
    }

    .comment-meta {
        color: var(--muted);
        font-size: .9rem;
        margin-bottom: 6px
    }

    .utensilios-page main {
        font-size: var(--step-0);
        line-height: 1.7;
    }

    .utensilios-page h1 {
        font-size: var(--step-2);
        line-height: 1.15;
        margin: 10px 0 8px;
    }

    .utensilios-page h2 {
        font-size: clamp(1.25rem, 1.1rem + .6vw, 1.6rem);
    }

    .utensilios-page h3 {
        font-size: var(--step-0);
        line-height: 1.35;
    }

    .utensilios-page .card h3 {
        font-size: var(--step-0);
        line-height: 1.35;
    }

    .utensilios-page .card p {
        font-size: var(--step-0);
        line-height: 1.7;
    }

    .utensilios-page .btn {
        font-size: var(--step-0);
    }

    .utensilios-page .disclaimer {
        font-size: var(--step--1);
        color: var(--muted);
    }
}

/* força 1 linha no desktop */
.site-header .container{ flex-wrap: nowrap !important; }
.nav{ flex-wrap: nowrap; white-space: nowrap; }

/* --- BRAND: nunca quebrar em duas linhas --- */
.brand{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  white-space: nowrap;           /* impede quebra dentro do bloco */
}

.brand-text{
  white-space: nowrap;           /* impede quebra do texto */
  font-weight: 800;
  font-size: clamp(18px, 1.8vw, 22px);
  line-height: 1;
}

/* mobile muito estreito: corta com reticências em vez de quebrar */
@media (max-width: 420px){
  .brand-text{
    max-width: 52vw;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}
/* ===== Utensílios: header mais baixo (apenas nesta página) ===== */
.utensilios-page{
  /* sobrescreve variáveis só nesta página */
  --logo-size: 50px;   /* altura do selo */
  --header-pad: 4px;   /* respiro vertical do header */
}

.utensilios-page .site-header{
  padding-block: var(--header-pad);
}

.utensilios-page .site-header .container{
  /* altura mínima = logo + paddings do header */
  min-height: calc(var(--logo-size) + 2 * var(--header-pad));
  gap: 12px;
}

.utensilios-page .brand img{
  height: var(--logo-size);
}

.utensilios-page .brand-text{
  font-size: clamp(16px, 1.7vw, 20px);
  line-height: 1;
  white-space: nowrap;
}

.utensilios-page .nav a{
  padding: 8px 10px;            /* compacta os links do menu */
}

/* Mobile: mantém tudo confortável */
@media (max-width: 900px){
  .utensilios-page{
    --logo-size: 32px;
    --header-pad: 4px;
  }
  .utensilios-page .nav a{ padding: 10px 12px; }
}
/* ===== Footer global: copyright alinhado à esquerda ===== */
.site-footer .container.footerbar{
  display: flex;
  flex-direction: row;          /* desktop em linha */
  align-items: center;
  justify-content: flex-start;  /* começa à esquerda */
  gap: 14px;
  flex-wrap: nowrap;
}

.site-footer .copyright{
  margin: 0;
  margin-right: auto;           /* empurra o resto pro lado direito */
  text-align: left;
  white-space: nowrap;          /* evita quebrar em 2 linhas */
}

.site-footer .social{
  margin: 0 18px 0 24px;        /* respiro entre copyright e redes */
  flex-wrap: nowrap;
}

.site-footer .footer-nav{
  margin: 0;                    /* encosta nos chips de redes */
  display: flex;
  gap: 14px;
}

/* Mobile: empilha e centraliza pra caber bem */
@media (max-width: 720px){
  .site-footer .container.footerbar{
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
  }
  .site-footer .copyright{
    order: 3;
    width: 100%;
    text-align: center;
    margin: 0;
  }
  .site-footer .social{ order: 1; margin: 0; }
  .site-footer .footer-nav{ order: 2; }
}

/* TODO .container usa o mesmo cálculo */
.container{
  width: min(100% - 2*var(--page-gutter), var(--page-max));
  margin-inline: auto;
  padding-inline: var(--page-gutter) !important; /* vence variações antigas */
}

/* ===== FOOTER ALINHADO À ESQUERDA ===== */
.site-footer .container.footerbar{
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: nowrap;
  padding-inline: var(--page-gutter) !important; /* garante o mesmo gutter */
}

.site-footer .copyright{
  margin: 0;
  margin-right: auto;         /* empurra redes/links para a direita */
  text-align: left;
  white-space: nowrap;        /* evita quebrar em 2 linhas */
}

.site-footer .social{
  margin: 0 18px 0 24px;      /* respiro entre copyright e redes */
  flex-wrap: nowrap;
}

.site-footer .footer-nav{
  margin: 0;
  display: flex;
  gap: 14px;
}

/* Mobile: empilha sem desalinhamento */
@media (max-width: 720px){
  .site-footer .container.footerbar{
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
  }
  .site-footer .copyright{
    order: 3;
    width: 100%;
    text-align: center;
    margin: 0;
  }
  .site-footer .social{ order: 1; margin: 0; }
  .site-footer .footer-nav{ order: 2; }
}
/* ===== CONTAINER GLOBAL (único padrão) ===== */
:root{
  --page-max: 1080px;
  --page-gutter: 16px;          /* gutter base */
}
@media (min-width: 1200px){
  :root{ --page-gutter: 24px; } /* gutter desktop */
}

.container{
  width: min(100% - 2*var(--page-gutter), var(--page-max));
  margin-inline: auto !important;
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;
}

/* ===== FOOTER ALINHADO AO CONTAINER ===== */
.site-footer .container.footerbar{
  width: min(100% - 2*var(--page-gutter), var(--page-max));
  margin-inline: auto !important;
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;

  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: nowrap;
}

.site-footer .copyright{
  margin: 0;
  margin-right: auto;     /* empurra redes/links para a direita */
  white-space: nowrap;
}
.site-footer .social{
  margin: 0 16px 0 24px;  /* respiro entre copyright e redes */
  flex-wrap: nowrap;
}
.site-footer .footer-nav{
  margin: 0;
  display: flex;
  gap: 14px;
}

/* Mobile: empilha sem desalinho */
@media (max-width: 720px){
  .site-footer .container.footerbar{
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
  }
  .site-footer .copyright{
    order: 3; width: 100%; text-align: center; margin: 0;
  }
  .site-footer .social{ order: 1; margin: 0; }
  .site-footer .footer-nav{ order: 2; }
}
/* ===== FIX GLOBAL DE ALINHAMENTO (cole no FINAL do styles.css) ===== */
:root{
  --page-max: 1080px;
  --page-gutter: 16px;         /* mobile / base */
}
@media (min-width: 1200px){
  :root{ --page-gutter: 24px; }/* desktop */
}

/* 1) Um único padrão de container (força ganhar a cascata) */
html body .container{
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;
}

/* 2) Footer alinhado ao mesmo container */
html body .site-footer .container.footerbar{
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;

  display: flex !important;
  align-items: center;
  gap: 14px;
  flex-wrap: nowrap;
}

/* 3) Remove “empurrões” que desalinham */
html body .site-footer .social{
  margin: 0 !important;        /* zera qualquer margem herdada */
  flex-wrap: nowrap;
}
html body .site-footer .footer-nav{
  margin: 0 !important;
  display: flex;
  gap: 14px;
}
html body .site-footer .copyright{
  margin: 0 !important;
  margin-right: auto !important; /* mantém os links à direita */
  white-space: nowrap;
}

/* 4) Mobile: pode empilhar sem perder o alinhamento lateral */
@media (max-width: 720px){
  html body .site-footer .container.footerbar{
    flex-wrap: wrap;
    justify-content: center;
    row-gap: 8px;
  }
  html body .site-footer .copyright{
    order: 3; width: 100%; text-align: center; margin: 0 !important;
  }
  html body .site-footer .social{ order: 1; }
  html body .site-footer .footer-nav{ order: 2; }
}
/* ===== PADRÃO ÚNICO DE LARGURA/GUTTER ===== */
:root{
  --page-max: 1080px;
  --page-gutter: 16px;               /* mobile/base */
}
@media (min-width: 1200px){
  :root{ --page-gutter: 24px; }      /* desktop */
}

/* 1) Container único para todas as seções */
html body .container{
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;
}

/* 2) Footer usando o MESMO container */
html body .site-footer .container.footerbar{
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;

  display: flex !important;
  align-items: center;
  gap: 14px;
  flex-wrap: nowrap;
  justify-content: flex-start !important;
}

html body .site-footer .copyright{
  margin: 0 !important;
  margin-right: auto !important;      /* empurra redes/links p/ direita */
  white-space: nowrap !important;
  text-align: left !important;
}

html body .site-footer .social,
html body .site-footer .footer-nav{
  margin: 0 !important;
  display: flex !important;
  gap: 14px !important;
  flex-wrap: nowrap !important;
}

/* 3) Mobile: empilha mantendo o mesmo gutter */
@media (max-width: 720px){
  html body .site-footer .container.footerbar{
    flex-wrap: wrap !important;
    justify-content: center !important;
    row-gap: 8px !important;
  }
  html body .site-footer .copyright{
    order: 3; width: 100%; text-align: center !important; margin: 0 !important;
  }
  html body .site-footer .social{ order: 1; }
  html body .site-footer .footer-nav{ order: 2; }
}
/* ===== FIX DEFINITIVO: footer alinhado ao container global ===== */

/* Mesmos parâmetros usados no site todo */
:root{
  --page-max: 1080px;
  --page-gutter: 16px;           /* mobile/base */
}
@media (min-width: 1200px){
  :root{ --page-gutter: 24px; }  /* desktop */
}

/* 1) Força o mesmo container no footer (com e sem .footerbar) */
.site-footer > .container,
.site-footer > .container.footerbar{
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;

  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: nowrap !important;
  justify-content: flex-start !important;   /* texto começa à esquerda */
}

/* 2) Zera empurrões que desalinham */
.site-footer .copyright{
  margin: 0 !important;
  margin-right: auto !important;           /* redes/links vão para a direita */
  white-space: nowrap !important;
  text-align: left !important;
}
.site-footer .social,
.site-footer .footer-nav{
  margin: 0 !important;
  display: flex !important;
  gap: 14px !important;
  flex-wrap: nowrap !important;
}

/* 3) Garante que o próprio footer não tenha paddings laterais extras */
.site-footer{
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* 4) Mobile: pode empilhar mantendo o mesmo gutter */
@media (max-width: 720px){
  .site-footer > .container,
  .site-footer > .container.footerbar{
    flex-wrap: wrap !important;
    justify-content: center !important;
    row-gap: 8px !important;
  }
  .site-footer .copyright{
    order: 3; width: 100%; text-align: center !important; margin: 0 !important;
  }
  .site-footer .social{ order: 1; }
  .site-footer .footer-nav{ order: 2; }
}
/* === FIX: footer alinhado ao container global (colar NO FINAL) === */
:root{
  --page-max: 1080px;
  --page-gutter: 16px;           /* base/mobile */
}
@media (min-width: 1200px){
  :root{ --page-gutter: 24px; }  /* desktop */
}

.site-footer > .container,
.site-footer > .container.footerbar{
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;

  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: nowrap !important;
  justify-content: flex-start !important;  /* começa alinhado à esquerda */
}

/* elementos internos sem “empurrões” */
.site-footer .copyright{
  margin: 0 !important;
  margin-right: auto !important;           /* redes/links vão para a direita */
  white-space: nowrap !important;
  text-align: left !important;
}
.site-footer .social,
.site-footer .footer-nav{
  margin: 0 !important;
  display: flex !important;
  gap: 14px !important;
  flex-wrap: nowrap !important;
}

/* mobile: pode empilhar, mantendo os mesmos gutters */
@media (max-width: 720px){
  .site-footer > .container,
  .site-footer > .container.footerbar{
    flex-wrap: wrap !important;
    justify-content: center !important;
    row-gap: 8px !important;
  }
  .site-footer .copyright{
    order: 3; width: 100%; text-align: center !important; margin: 0 !important;
  }
  .site-footer .social{ order: 1; }
  .site-footer .footer-nav{ order: 2; }
}
/* === FOOTER ALINHADO: copy à ESQ • redes no MEIO • links à DIR === */
html body .site-footer .container.footerbar{
  display: grid !important;
  grid-template-columns: 1fr auto 1fr;
  grid-template-areas: "copy social links";
  align-items: center;
  gap: 14px;
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-inline: auto !important;
  padding-inline: var(--page-gutter) !important;
}

/* Áreas */
html body .site-footer .copyright{
  grid-area: copy;
  justify-self: start;
  margin: 0 !important;
  white-space: nowrap;
}
html body .site-footer .social{
  grid-area: social;
  justify-self: center;
  margin: 0 !important;
  display: flex; gap: 10px; flex-wrap: wrap;
}
html body .site-footer .footer-nav{
  grid-area: links;
  justify-self: end;
  margin: 0 !important;
  display: flex; gap: 14px; flex-wrap: wrap;
}

/* Mobile: empilha centralizado (redes • links • copy) */
@media (max-width: 720px){
  html body .site-footer .container.footerbar{
    grid-template-columns: 1fr;
    grid-template-areas:
      "social"
      "links"
      "copy";
    row-gap: 8px;
    text-align: center;
  }
  html body .site-footer .copyright,
  html body .site-footer .social,
  html body .site-footer .footer-nav{
    justify-self: center;
  }
}
/* === FOOTER ALINHADO: copy à ESQ • redes no MEIO • links à DIR === */
html body .site-footer .container.footerbar{
  display: grid !important;
  grid-template-columns: 1fr auto 1fr;
  grid-template-areas: "copy social links";
  align-items: center;
  gap: 14px;
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-inline: auto !important;
  padding-inline: var(--page-gutter) !important;
}

/* Áreas */
html body .site-footer .copyright{
  grid-area: copy;
  justify-self: start;
  margin: 0 !important;
  white-space: nowrap;
}
html body .site-footer .social{
  grid-area: social;
  justify-self: center;
  margin: 0 !important;
  display: flex; gap: 10px; flex-wrap: wrap;
}
html body .site-footer .footer-nav{
  grid-area: links;
  justify-self: end;
  margin: 0 !important;
  display: flex; gap: 14px; flex-wrap: wrap;
}

/* Mobile: empilha centralizado (redes • links • copy) */
@media (max-width: 720px){
  html body .site-footer .container.footerbar{
    grid-template-columns: 1fr;
    grid-template-areas:
      "social"
      "links"
      "copy";
    row-gap: 8px;
    text-align: center;
  }
  html body .site-footer .copyright,
  html body .site-footer .social,
  html body .site-footer .footer-nav{
    justify-self: center;
  }
}
/* ===== FOOTER: alinhamento definitivo ao container ===== */
html body .site-footer{ padding-left:0 !important; padding-right:0 !important; }

html body .site-footer > .container.footerbar{
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-inline: auto !important;
  padding-inline: var(--page-gutter) !important;

  display: grid !important;
  grid-template-columns: 1fr auto auto; /* 3 colunas: esq • meio • dir */
  align-items: center !important;
  gap: 12px !important;
}

html body .site-footer .copyright{
  margin: 0 !important;
  white-space: nowrap !important;
  justify-self: start !important;   /* cola na borda esquerda do container */
}

html body .site-footer .social{
  margin: 0 !important;
  justify-self: center !important;  /* fica exatamente no meio */
  display: flex !important;
  gap: 40px !important;
}

html body .site-footer .footer-nav{
  margin: 0 !important;
  justify-self: end !important;     /* alinha pela borda direita do container */
  display: flex !important;
  gap: 14px !important;
  width: auto !important;           /* evita larguras herdadas estranhas */
}
html body .site-footer .footer-nav a{ white-space: nowrap; }

/* Mobile: empilha mantendo os mesmos gutters */
@media (max-width: 720px){
  html body .site-footer > .container.footerbar{
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    row-gap: 8px !important;
  }
  html body .site-footer .social{ order:1; }
  html body .site-footer .footer-nav{ order:2; }
  html body .site-footer .copyright{ order:3; text-align:center !important; }
}
/* === FOOTER: alinhado ao container e sem vazamento === */
.site-footer { padding: 0; }

.site-footer > .container,
.site-footer .container.footerbar{
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-inline: auto !important;
  padding-inline: var(--page-gutter) !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: nowrap !important;   /* tudo em 1 linha no desktop */
  justify-content: flex-start !important;
}

.site-footer .copyright{
  flex: 1 1 auto !important;      /* ocupa o espaço “elástico” da esquerda */
  margin: 0 !important;
  white-space: nowrap !important;
  min-width: 0 !important;
  text-align: left !important;
}

.site-footer .social{
  margin: 0 !important;
  flex: 0 1 auto !important;
  min-width: 0 !important;
}

.site-footer .footer-nav{
  margin: 0 0 0 auto !important;  /* encosta à direita, mas dentro do container */
  display: flex !important;
  gap: 12px !important;
  flex: 0 1 auto !important;      /* pode encolher; não estoura o container */
  min-width: 0 !important;
  position: static !important;
  transform: none !important;
}

/* links um pouco mais compactos */
.site-footer .footer-nav a{ padding: 6px 8px; }

/* Quando faltar espaço, quebra em 2 linhas sem desalinhamento */
@media (max-width: 1100px){
  .site-footer .container.footerbar{
    flex-wrap: wrap !important;
    justify-content: center !important;
    row-gap: 8px !important;
  }
  .site-footer .social{ order: 1; }
  .site-footer .footer-nav{
    order: 2; width: 100%; justify-content: center;
  }
  .site-footer .copyright{
    order: 3; width: 100%; text-align: center !important;
  }
}
/* === FOOTER: layout estável e alinhado ao container === */
:root{
  --page-max: 1080px;
  --page-gutter: clamp(16px, 3vw, 24px);
}

.site-footer{ padding:0; }

/* usa o MESMO container do site e grade 3 colunas */
.site-footer .container.footerbar{
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-inline: auto !important;
  padding-inline: var(--page-gutter) !important;

  display: grid !important;                 /* <- troca flex por GRID */
  grid-template-columns: 1fr auto auto;     /* copyright | social | links */
  align-items: center;
  column-gap: 14px;
  row-gap: 8px;
  justify-content: initial !important;      /* neutraliza overrides antigos */
}

/* zera empurrões herdados */
.site-footer .copyright,
.site-footer .social,
.site-footer .footer-nav{
  margin: 0 !important;
}

/* copyright à esquerda, sem quebrar */
.site-footer .copyright{
  white-space: nowrap;
}

/* grupos da direita lado a lado, com wrap se faltar espaço */
.site-footer .social,
.site-footer .footer-nav{
  display: flex !important;
  gap: 10px;
  flex-wrap: wrap;                           /* permite quebrar, não sobrepor */
}

/* responsivo: empilha e centraliza */
@media (max-width: 800px){
  .site-footer .container.footerbar{
    grid-template-columns: 1fr;
    justify-items: center;
  }
  .site-footer .footer-nav{ order: 1; }
  .site-footer .social{ order: 2; }
  .site-footer .copyright{
    order: 3;
    text-align: center;
  }
}
/* === FOOTER estável + redes SÓ COM ÍCONES === */

/* usa o mesmo container e 3 colunas */
.site-footer .container.footerbar{
  width: min(100% - 2*var(--page-gutter), var(--page-max)) !important;
  margin-inline: auto !important;
  padding-inline: var(--page-gutter) !important;

  display: grid !important;
  grid-template-columns: 1fr auto auto;  /* copyright | social | links */
  align-items: center;
  column-gap: 14px;
  row-gap: 8px;
}

/* MUITO IMPORTANTE: deixa os itens encolherem sem sobrepor */
.site-footer .container.footerbar > *{ min-width: 0 !important; }

/* zera possíveis “empurrões” herdados */
.site-footer .copyright,
.site-footer .social,
.site-footer .footer-nav{ margin: 0 !important; }

/* --- Redes: só ícones, nunca sobrepõe --- */
.site-footer .social{
  display: flex !important;
  gap: 8px;
  flex-wrap: wrap;                 /* se faltar espaço, quebra */
}

.site-footer .social a{
  position: static !important;     /* mata qualquer absolute antigo */
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 36px;                     /* tamanho do botão */
  height: 36px;
  padding: 0 !important;
  border-radius: 999px !important; /* redondo */
  background: rgba(255,255,255,.06);
  border: 1px solid #2a1a14;
  color: #e5e7eb;
  overflow: hidden;                /* esconde textos residuais */
  line-height: 1;
  font-size: 0 !important;         /* esconde o texto do link se houver */
  gap: 0 !important;               /* evita “chips” largos */
}

.site-footer .social a:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.12);
  border-color: #3a281f;
}

.site-footer .social svg{
  width: 18px; height: 18px;       /* tamanho do ícone */
  display: block;
  stroke: currentColor;
  fill: none;
}

/* se você tiver <span class="label">Instagram</span> dentro do link */
.site-footer .social a .label{
  position: absolute !important;
  width: 1px; height: 1px;
  overflow: hidden; white-space: nowrap;
  clip: rect(1px,1px,1px,1px);
}

/* --- Links “Termos • Privacidade • Sitemap” --- */
.site-footer .footer-nav{
  display: flex !important;
  gap: 14px;
  flex-wrap: wrap;                 /* quebra bonitinho quando faltar espaço */
}

.site-footer .footer-nav a{ white-space: nowrap; }
/* ===== Só ícones no rodapé (reset forte) ===== */
:root{ --social-ico: 24px; } /* ajuste fino do tamanho */

.site-footer .footerbar{
  display:flex; align-items:center; gap:14px;
  flex-wrap:nowrap; /* quebra só no mobile (abaixo) */
}

/* grupo do meio: apenas ícones */
.site-footer .social.social-icons-only{
  display:flex; align-items:center; gap:12px;
  flex: 0 0 auto; min-width:0;
}

/* zera os “chips” antigos e garante só o ícone */
.site-footer .social.social-icons-only a{
  width: var(--social-ico);
  height: var(--social-ico);
  display:inline-flex; align-items:center; justify-content:center;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--muted);            /* se o SVG usar currentColor */
  transition: transform .15s ease, opacity .2s ease, color .2s ease;
}
.site-footer .social.social-icons-only a:hover{
  transform: translateY(-2px);
  color:#fff;
}

/* o arquivo SVG vira “bloco” e ocupa 100% do quadrado */
.site-footer .social.social-icons-only img,
.site-footer .social.social-icons-only svg{
  width:100%; height:100%; display:block;
}

/* se seus SVGs tiverem stroke/fill = currentColor, estas linhas colorem eles */
.site-footer .social.social-icons-only svg [stroke] { stroke: currentColor; }
.site-footer .social.social-icons-only svg [fill="currentColor"],
.site-footer .social.social-icons-only svg .icon-fill { fill: currentColor; }

/* mantém copyright à esquerda e links à direita */
.site-footer .copyright{ margin:0; margin-right:auto; white-space:nowrap; }
.site-footer .footer-nav{ margin-left:auto; display:flex; gap:14px; }

/* Mobile: pode empilhar sem atropelar nada */
@media (max-width: 720px){
  .site-footer .footerbar{
    flex-wrap: wrap;
    justify-content: center;
    row-gap: 10px;
  }
  .site-footer .copyright{
    order:3; width:100%; text-align:center; margin:0;
  }
  .site-footer .social{ order:1; }
  .site-footer .footer-nav{ order:2; }
}
/* ==== NAV MOBILE ==== */
.site-header { position: sticky; top: 0; z-index: 1000; }

/* estado desktop */
.nav { display: flex; gap: 14px; align-items: center; }

/* botão hamburguer (mostra só no mobile) */
.nav-toggle {
  display: none;
  -webkit-tap-highlight-color: transparent;
  background: transparent; border: 0; padding: 8px; margin-left: auto;
  width: 44px; height: 44px; border-radius: 10px;
}
.nav-toggle .bar{
  display:block; width: 24px; height: 2px; background: currentColor;
  margin: 5px auto; border-radius: 2px;
}

/* mobile */
@media (max-width: 980px){
  .nav-toggle{ display:inline-flex; align-items:center; justify-content:center; }

  /* nav vira um painel full-width a partir do topo do header */
  .nav{
    position: fixed; left: 0; right: 0; top: 60px; /* ajuste a altura do seu header */
    background: #0b0b0b; border-top: 1px solid var(--border, #222);
    padding: 14px 16px 18px;
    display: none; flex-direction: column; gap: 12px;
  }
  .nav.is-open{ display: flex; }

  /* backdrop para fechar ao tocar fora */
  .nav-backdrop{
    position: fixed; inset: 0; background: rgba(0,0,0,.45);
    display: none; z-index: 999; /* abaixo do header (1000) e acima do conteúdo */
  }
  .nav-backdrop.is-open{ display:block; }

  /* trava o scroll quando menu aberto */
  body.nav-open{ overflow: hidden; }
}

/* acessibilidade: foco visível nos links do menu */
.nav a:focus{
  outline: 2px solid #fff; outline-offset: 2px; border-radius: 6px;
}

/* (opcional) animação leve */
@media (prefers-reduced-motion: no-preference){
  .nav { transition: transform .2s ease, opacity .2s ease; }
}
