/*
Theme Name:        A Cabra Alquimista
Theme URI:         https://cabraalquimista.com.br/
Description:       Tema místico/alquímico autônomo que replica o site cabraalquimista.com.br. Fundo noturno, ouro velho, tipografia Cinzel + Cormorant Garamond + Lato. Não requer tema-pai. Compatível com Elementor.
Author:            A Cabra Alquimista
Author URI:        https://cabraalquimista.com.br/
Version:           1.0.0
Requires at least: 6.0
Tested up to:      6.7
Requires PHP:      7.4
License:           GNU General Public License v3 or later
License URI:       http://www.gnu.org/licenses/gpl-3.0.html
Text Domain:       cabra-alquimista
Tags:              dark, one-column, custom-colors, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready, full-width-template
*/

/* =====================================================================
   A CABRA ALQUIMISTA — Tema Místico/Alquímico (réplica fiel)
   Baseado em https://cabraalquimista.com.br/  (Hostinger / Zyro)
   ---------------------------------------------------------------------
   Cobre as 5 páginas: Início, Quem sou eu?, O Laboratório, O Baú, Contato.
   Compatível com WordPress: cole em "Personalizar → CSS Adicional"
   ou use como style.css de um tema-filho.

   ÍNDICE:
   §1   Fontes e tokens (variáveis CSS)
   §2   Reset + base
   §3   Atmosfera (brumas, grão, vinheta)
   §4   Container
   §5   Cabeçalho + logo NeuroVista + navegação
   §6   Hero com imagem de fundo (página inicial)
   §7   Botões e CTAs
   §8   Seção newsletter / iniciados
   §9   Páginas internas: Quem sou eu?
   §10  Páginas internas: O Laboratório
   §11  Páginas internas: O Baú
   §12  Páginas internas: Contato (formulário)
   §13  Rodapé com pergaminho de fundo
   §14  Compatibilidade WordPress (blocos, widgets, CF7, WPForms, Woo)
   §15  Responsividade mobile-first
   §16  Acessibilidade / motion
   ===================================================================== */


/* =================================================================
   §1  FONTES + TOKENS
   ================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Lato:wght@300;400;500;700&display=swap');

:root {
  /* — Paleta — fundos noturnos profundos */
  --cabra-bg:           #0b0814;
  --cabra-bg-deep:      #07050d;
  --cabra-bg-soft:      #14102a;
  --cabra-bg-elev:      #1a1535;

  /* — Texto */
  --cabra-text:         #f3ecdc;
  --cabra-text-soft:    #d4ccb6;
  --cabra-text-mute:    #9a8f78;

  /* — Ouro alquímico */
  --cabra-gold:         #c9a24a;
  --cabra-gold-bright:  #e7c478;
  --cabra-gold-deep:    #8a6a26;
  --cabra-copper:       #b87333;
  --cabra-blood:        #6b1e1e;   /* acento sangue de dragão (sutil) */

  /* — Linhas e sombras */
  --cabra-line:         rgba(201, 162, 74, 0.28);
  --cabra-line-strong:  rgba(201, 162, 74, 0.55);
  --cabra-shadow:       0 30px 80px -30px rgba(0, 0, 0, 0.85);
  --cabra-shadow-soft:  0 12px 35px -15px rgba(0, 0, 0, 0.65);

  /* — Tipografia */
  --cabra-font-display: "Cinzel", "Playfair Display", Georgia, serif;
  --cabra-font-serif:   "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --cabra-font-body:    "Lato", "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  /* — Tamanhos fluidos */
  --cabra-fs-xs:    clamp(0.78rem, 0.74rem + 0.2vw, 0.84rem);
  --cabra-fs-sm:    clamp(0.88rem, 0.84rem + 0.25vw, 0.94rem);
  --cabra-fs-base:  clamp(1rem,    0.96rem + 0.3vw,  1.08rem);
  --cabra-fs-lead:  clamp(1.1rem,  1.04rem + 0.5vw,  1.22rem);
  --cabra-fs-h4:    clamp(1.05rem, 1rem    + 0.4vw,  1.3rem);
  --cabra-fs-h3:    clamp(1.3rem,  1.15rem + 0.85vw, 1.7rem);
  --cabra-fs-h2:    clamp(1.6rem,  1.25rem + 1.7vw,  2.45rem);
  --cabra-fs-h1:    clamp(2.4rem,  1.6rem  + 3.6vw,  4.25rem);

  /* — Espaçamento */
  --cabra-space-1:  0.5rem;
  --cabra-space-2:  1rem;
  --cabra-space-3:  1.5rem;
  --cabra-space-4:  2.25rem;
  --cabra-space-5:  3.5rem;
  --cabra-space-6:  5rem;
  --cabra-space-7:  7rem;

  --cabra-radius:    2px;
  --cabra-radius-md: 4px;
  --cabra-radius-lg: 8px;

  /* — URLs das imagens originais do site (CDN da Hostinger) */
  --cabra-img-logo:    url("https://assets.zyrosite.com/cdn-cgi/image/format=auto,w=768,fit=crop/YHCUOfsTC17Zt6NF/semfundo2-W2z7Wi14VWk2Mo3X.png");
  --cabra-img-hero:    url("https://assets.zyrosite.com/cdn-cgi/image/format=auto,w=1920,fit=crop/YHCUOfsTC17Zt6NF/gemini_generated_image_w19v5ew19v5ew19v-j9eNjwC9dAER8o83.png");
  --cabra-img-lab:     url("https://assets.zyrosite.com/cdn-cgi/image/format=auto,w=1440,fit=crop/YHCUOfsTC17Zt6NF/laboratorio-xZa5uYcAYk4vcdfZ.png");
  --cabra-img-bau:     url("https://assets.zyrosite.com/cdn-cgi/image/format=auto,w=1440,fit=crop/YHCUOfsTC17Zt6NF/o-bau-nvPNm3lTlxbtJLcZ.png");
  --cabra-img-contato: url("https://assets.zyrosite.com/cdn-cgi/image/format=auto,w=1440,fit=crop/YHCUOfsTC17Zt6NF/generated/generated-vzcYMDd0jbin7pwk.png");
  --cabra-img-rodape:  url("https://assets.zyrosite.com/cdn-cgi/image/format=auto,w=1920,fit=crop/YHCUOfsTC17Zt6NF/rodapa-c-851aUFhwkA3EjTDD.png");
}


/* =================================================================
   §2  RESET + BASE
   ================================================================= */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body, .cabra-body {
  margin: 0;
  background:
    radial-gradient(ellipse at top, #1a1230 0%, var(--cabra-bg) 45%, var(--cabra-bg-deep) 100%) no-repeat fixed;
  color: var(--cabra-text);
  font-family: var(--cabra-font-body);
  font-size: var(--cabra-fs-base);
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, svg, video, picture { max-width: 100%; height: auto; display: block; }

a {
  color: var(--cabra-gold);
  text-decoration: none;
  transition: color .25s ease, text-shadow .25s ease;
}
a:hover, a:focus-visible {
  color: var(--cabra-gold-bright);
  text-shadow: 0 0 18px rgba(231, 196, 120, 0.35);
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--cabra-font-display);
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--cabra-text);
  margin: 0 0 var(--cabra-space-2);
  line-height: 1.18;
}

h1 { font-size: var(--cabra-fs-h1); letter-spacing: 0.02em; }
h2 { font-size: var(--cabra-fs-h2); }
h3 { font-size: var(--cabra-fs-h3); }
h4 { font-size: var(--cabra-fs-h4); font-family: var(--cabra-font-serif); font-style: italic; font-weight: 500; }
h5 { font-size: 0.85rem; letter-spacing: 0.32em; text-transform: uppercase; color: var(--cabra-gold); }
h6 { font-size: 1rem; font-family: var(--cabra-font-display); letter-spacing: 0.14em; text-transform: uppercase; color: var(--cabra-gold); }

p { margin: 0 0 var(--cabra-space-2); }

::selection { background: var(--cabra-gold); color: var(--cabra-bg-deep); }

:focus-visible {
  outline: 2px solid var(--cabra-gold-bright);
  outline-offset: 3px;
  border-radius: var(--cabra-radius);
}

.cabra-visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.cabra-emoji { font-style: normal; font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif; }


/* =================================================================
   §3  ATMOSFERA (brumas + grão + vinheta)
   ================================================================= */
.cabra-atmosphere {
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.cabra-fog {
  position: absolute;
  width: 80vmax; height: 80vmax;
  border-radius: 50%;
  filter: blur(120px);
  opacity: 0.18;
  mix-blend-mode: screen;
}
.cabra-fog--1 {
  top: -30vmax; left: -20vmax;
  background: radial-gradient(circle, rgba(201,162,74,0.6) 0%, transparent 65%);
  animation: cabra-float-1 28s ease-in-out infinite alternate;
}
.cabra-fog--2 {
  bottom: -30vmax; right: -20vmax;
  background: radial-gradient(circle, rgba(184,115,51,0.55) 0%, transparent 65%);
  animation: cabra-float-2 36s ease-in-out infinite alternate;
}

@keyframes cabra-float-1 {
  from { transform: translate(0,0) scale(1); }
  to   { transform: translate(8vw, 6vh) scale(1.08); }
}
@keyframes cabra-float-2 {
  from { transform: translate(0,0) scale(1); }
  to   { transform: translate(-6vw,-8vh) scale(1.12); }
}

.cabra-grain {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.85  0 0 0 0 0.6  0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity: 0.30;
  mix-blend-mode: overlay;
}

.cabra-vignette {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.6) 100%);
  pointer-events: none;
}

.site-header,
.site-main,
.site-footer { position: relative; z-index: 1; }


/* =================================================================
   §4  CONTAINER
   ================================================================= */
.cabra-container {
  width: 100%;
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 4vw, 2.5rem);
}
.cabra-container--narrow { max-width: 880px; }
.cabra-container--wide   { max-width: 1380px; }


/* =================================================================
   §5  CABEÇALHO + LOGO NEUROVISTA + NAVEGAÇÃO
   ================================================================= */
.site-header {
  padding-block: var(--cabra-space-3);
  border-bottom: 1px solid var(--cabra-line);
  background: linear-gradient(180deg, rgba(11,8,20,0.92), rgba(11,8,20,0.55));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 30;
}
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--cabra-space-3);
}

/* Logo NeuroVista — usa a mesma imagem real do site */
.site-branding {
  display: inline-flex; align-items: center; gap: 0.85rem;
  color: var(--cabra-gold);
  text-decoration: none;
  font-family: var(--cabra-font-display);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.site-branding__logo {
  width: 56px; height: 56px;
  background-image: var(--cabra-img-logo);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  filter: drop-shadow(0 0 14px rgba(201, 162, 74, 0.4));
  transition: transform .6s ease, filter .4s ease;
}
.site-branding:hover .site-branding__logo {
  transform: rotate(8deg) scale(1.05);
  filter: drop-shadow(0 0 22px rgba(231, 196, 120, 0.7));
}
.site-branding__text { line-height: 1; display: grid; }
.site-branding__top {
  font-size: 0.72rem; color: var(--cabra-text-soft);
  letter-spacing: 0.36em;
}
.site-branding__bottom {
  font-size: 1.15rem; color: var(--cabra-gold);
  letter-spacing: 0.22em; margin-top: 5px;
  text-shadow: 0 0 18px rgba(201,162,74,0.3);
}

/* Navegação principal */
.main-navigation__list {
  display: flex; gap: clamp(1rem, 2.5vw, 2.5rem);
  list-style: none; margin: 0; padding: 0;
}
.main-navigation a {
  font-family: var(--cabra-font-display);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--cabra-text-soft);
  padding-block: 0.5rem;
  position: relative;
}
.main-navigation a::after {
  content: ""; position: absolute;
  left: 50%; bottom: -2px; height: 1px; width: 0;
  background: linear-gradient(90deg, transparent, var(--cabra-gold), transparent);
  transition: width .35s ease, left .35s ease;
}
.main-navigation a:hover,
.main-navigation a:focus-visible,
.main-navigation .current-menu-item > a,
.main-navigation a.is-active {
  color: var(--cabra-gold-bright);
}
.main-navigation a:hover::after,
.main-navigation a:focus-visible::after,
.main-navigation a.is-active::after {
  width: 100%; left: 0;
}

/* Hambúrguer mobile */
.cabra-menu-toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--cabra-line-strong);
  width: 44px; height: 44px;
  padding: 0; cursor: pointer; position: relative;
  border-radius: var(--cabra-radius);
}
.cabra-menu-toggle span {
  position: absolute;
  left: 25%; right: 25%; height: 1.5px;
  background: var(--cabra-gold);
  transition: transform .3s ease, opacity .3s ease, top .3s ease;
}
.cabra-menu-toggle span:nth-child(1) { top: 32%; }
.cabra-menu-toggle span:nth-child(2) { top: 50%; }
.cabra-menu-toggle span:nth-child(3) { top: 68%; }
.cabra-menu-toggle.is-active span:nth-child(1) { top: 50%; transform: rotate(45deg); }
.cabra-menu-toggle.is-active span:nth-child(2) { opacity: 0; }
.cabra-menu-toggle.is-active span:nth-child(3) { top: 50%; transform: rotate(-45deg); }


/* =================================================================
   §6  HERO COM IMAGEM DE FUNDO (Página Inicial)
   ================================================================= */
.cabra-hero {
  position: relative;
  isolation: isolate;
  text-align: center;
  padding-block: clamp(5rem, 12vw, 11rem);
  min-height: clamp(640px, 90vh, 880px);
  display: flex; align-items: center; justify-content: center;
}

.cabra-hero::before {
  content: "";
  position: absolute; inset: 0;
  background-image: var(--cabra-img-hero);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: -2;
  /* desaturação leve + tom esverdeado/dourado */
  filter: contrast(1.05) saturate(0.85) brightness(0.65);
}
.cabra-hero::after {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at center, transparent 35%, rgba(7,5,13,0.85) 80%),
    linear-gradient(180deg, rgba(11,8,20,0.55) 0%, rgba(7,5,13,0.65) 60%, rgba(7,5,13,0.95) 100%);
  z-index: -1;
}

.cabra-hero__inner { max-width: 880px; margin-inline: auto; }

.cabra-hero__ornament {
  color: var(--cabra-gold);
  width: clamp(160px, 30vw, 240px);
  margin: 0 auto var(--cabra-space-3);
  opacity: 0.85;
}
.cabra-hero__ornament--bottom { margin: var(--cabra-space-5) auto 0; }

.cabra-hero__eyebrow {
  font-family: var(--cabra-font-display);
  font-size: 0.78rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--cabra-gold);
  margin-bottom: var(--cabra-space-3);
}

.cabra-hero__title {
  font-family: var(--cabra-font-serif);
  font-style: italic;
  font-weight: 600;
  font-size: var(--cabra-fs-h1);
  line-height: 1.05;
  margin: 0 0 var(--cabra-space-3);
  background: linear-gradient(180deg, #fff7e0 0%, var(--cabra-text) 50%, var(--cabra-gold) 100%);
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
  text-shadow: 0 0 80px rgba(201,162,74,0.35);
}
.cabra-hero__title .cabra-emoji {
  -webkit-text-fill-color: initial;
  background: none;
}

.cabra-hero__subtitle {
  font-family: var(--cabra-font-display);
  font-weight: 500;
  font-size: clamp(1.05rem, 0.9rem + 0.9vw, 1.5rem);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cabra-text-soft);
  margin-bottom: var(--cabra-space-4);
}

.cabra-hero__lead {
  font-family: var(--cabra-font-serif);
  font-size: var(--cabra-fs-lead);
  font-weight: 400;
  color: var(--cabra-text-soft);
  max-width: 64ch;
  margin: 0 auto var(--cabra-space-5);
  line-height: 1.85;
}

.cabra-hero__welcome {
  margin-top: var(--cabra-space-4);
  font-family: var(--cabra-font-serif);
  font-style: italic;
  font-size: clamp(1.05rem, 1rem + 0.4vw, 1.2rem);
  color: var(--cabra-text-soft);
  letter-spacing: 0.04em;
  font-weight: 500;
}


/* =================================================================
   §7  BOTÕES E CTAs
   ================================================================= */
.cabra-btn {
  --btn-bg: transparent;
  --btn-color: var(--cabra-gold-bright);
  --btn-border: var(--cabra-gold);
  display: inline-flex; align-items: center; gap: 0.6rem;
  padding: 1.05rem 2.05rem;
  font-family: var(--cabra-font-display);
  font-size: 0.86rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  background: var(--btn-bg);
  color: var(--btn-color);
  border: 1px solid var(--btn-border);
  border-radius: var(--cabra-radius);
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: color .3s, background .3s, transform .3s, box-shadow .3s, letter-spacing .3s;
}
.cabra-btn::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 0%, rgba(231,196,120,0.18) 50%, transparent 100%);
  transform: translateX(-100%);
  transition: transform .8s ease;
}
.cabra-btn:hover::before { transform: translateX(100%); }

.cabra-btn--primary {
  --btn-bg: linear-gradient(180deg, var(--cabra-gold) 0%, var(--cabra-gold-deep) 100%);
  --btn-color: var(--cabra-bg-deep);
  --btn-border: var(--cabra-gold-bright);
  box-shadow:
    0 14px 45px -12px rgba(201,162,74,0.6),
    inset 0 1px 0 rgba(255,255,255,0.25);
}
.cabra-btn--primary:hover,
.cabra-btn--primary:focus-visible {
  background: linear-gradient(180deg, var(--cabra-gold-bright), var(--cabra-gold));
  transform: translateY(-2px);
  letter-spacing: 0.26em;
  box-shadow:
    0 20px 60px -10px rgba(231,196,120,0.6),
    inset 0 1px 0 rgba(255,255,255,0.35);
}

.cabra-btn--ghost {
  --btn-bg: rgba(11,8,20,0.5);
  backdrop-filter: blur(6px);
}


/* =================================================================
   §8  NEWSLETTER / INICIADOS
   ================================================================= */
.cabra-newsletter {
  padding-block: clamp(3rem, 7vw, 6rem);
  position: relative;
}
.cabra-newsletter__card {
  position: relative;
  max-width: 760px;
  margin-inline: auto;
  padding: clamp(2rem, 5vw, 4rem) clamp(1.5rem, 4vw, 3.5rem);
  text-align: center;
  background:
    radial-gradient(ellipse at top, rgba(201,162,74,0.10), transparent 70%),
    linear-gradient(180deg, rgba(26,21,53,0.85), rgba(20,16,42,0.85));
  border: 1px solid var(--cabra-line);
  border-radius: var(--cabra-radius-lg);
  box-shadow: var(--cabra-shadow);
}
.cabra-newsletter__card::before,
.cabra-newsletter__card::after {
  content: "";
  position: absolute; width: 28px; height: 28px;
  border: 1px solid var(--cabra-gold);
}
.cabra-newsletter__card::before {
  top: -1px; left: -1px;
  border-right: 0; border-bottom: 0;
}
.cabra-newsletter__card::after {
  bottom: -1px; right: -1px;
  border-left: 0; border-top: 0;
}
.cabra-newsletter__seal {
  width: 70px; height: 70px;
  color: var(--cabra-gold);
  margin: 0 auto var(--cabra-space-3);
  filter: drop-shadow(0 0 18px rgba(201,162,74,0.4));
  animation: cabra-pulse 6s ease-in-out infinite;
}
@keyframes cabra-pulse {
  0%, 100% { transform: scale(1); opacity: 0.95; }
  50%      { transform: scale(1.05); opacity: 1; }
}
.cabra-newsletter__title {
  font-family: var(--cabra-font-serif);
  font-style: italic;
  font-weight: 600;
  font-size: var(--cabra-fs-h2);
  margin-bottom: var(--cabra-space-2);
}
.cabra-newsletter__desc {
  color: var(--cabra-text-soft);
  font-size: var(--cabra-fs-lead);
  margin-bottom: var(--cabra-space-4);
}
.cabra-newsletter__form {
  display: flex; flex-wrap: wrap; gap: 0.75rem;
  justify-content: center;
  max-width: 560px; margin: 0 auto;
}
.cabra-newsletter__form input[type="email"] {
  flex: 1 1 240px;
  padding: 1rem 1.15rem;
  font-family: var(--cabra-font-body);
  font-size: 1rem;
  color: var(--cabra-text);
  background: rgba(7,5,13,0.7);
  border: 1px solid var(--cabra-line-strong);
  border-radius: var(--cabra-radius);
  transition: border-color .25s, box-shadow .25s, background .25s;
}
.cabra-newsletter__form input[type="email"]::placeholder {
  color: var(--cabra-text-mute);
  font-style: italic;
}
.cabra-newsletter__form input[type="email"]:focus {
  outline: none;
  border-color: var(--cabra-gold);
  background: rgba(7,5,13,0.95);
  box-shadow: 0 0 0 3px rgba(201,162,74,0.18);
}
.cabra-newsletter__success {
  flex-basis: 100%;
  margin-top: var(--cabra-space-2);
  color: var(--cabra-gold-bright);
  font-style: italic;
}


/* =================================================================
   §9  PÁGINA: Quem sou eu? (O Guardião do Caldeirão)
   ================================================================= */
.cabra-page-hero {
  text-align: center;
  padding-block: clamp(4rem, 8vw, 7rem);
  position: relative;
  isolation: isolate;
}
.cabra-page-hero::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at top, rgba(201,162,74,0.1), transparent 60%);
  z-index: -1;
}
.cabra-page-hero__title {
  font-family: var(--cabra-font-serif);
  font-style: italic;
  font-weight: 600;
  background: linear-gradient(180deg, #fff7e0 0%, var(--cabra-text) 50%, var(--cabra-gold) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  margin-bottom: var(--cabra-space-3);
}
.cabra-page-hero__title .cabra-emoji { -webkit-text-fill-color: initial; background: none; }
.cabra-page-hero__lead {
  max-width: 70ch;
  margin: 0 auto;
  font-family: var(--cabra-font-serif);
  font-size: var(--cabra-fs-lead);
  color: var(--cabra-text-soft);
  line-height: 1.85;
}

.cabra-page-figure {
  margin: var(--cabra-space-5) auto;
  max-width: 1024px;
  padding-inline: clamp(1rem, 4vw, 2rem);
}
.cabra-page-figure img {
  width: 100%; height: auto;
  border-radius: var(--cabra-radius-lg);
  box-shadow: var(--cabra-shadow);
  border: 1px solid var(--cabra-line);
}

.cabra-content {
  padding-block: clamp(2rem, 5vw, 4rem);
}
.cabra-content__title {
  text-align: center;
  font-family: var(--cabra-font-display);
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--cabra-gold);
  margin-bottom: var(--cabra-space-5);
  font-size: 1.05rem;
}
.cabra-content__body {
  max-width: 760px;
  margin: 0 auto;
  font-size: var(--cabra-fs-base);
  line-height: 1.85;
  color: var(--cabra-text-soft);
}
.cabra-content__body p { margin-bottom: var(--cabra-space-3); }
.cabra-content__body p strong {
  display: block;
  font-family: var(--cabra-font-display);
  font-size: 1rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cabra-gold);
  margin-bottom: 0.4rem;
}


/* =================================================================
   §10  PÁGINA: O Laboratório
   ================================================================= */
.cabra-lab-hero {
  position: relative;
  isolation: isolate;
  text-align: center;
  padding-block: clamp(5rem, 11vw, 9rem);
  min-height: clamp(420px, 60vh, 600px);
  display: flex; align-items: center; justify-content: center;
}
.cabra-lab-hero::before {
  content: "";
  position: absolute; inset: 0;
  background-image: var(--cabra-img-lab);
  background-size: cover;
  background-position: center;
  filter: contrast(1.05) brightness(0.55) saturate(0.9);
  z-index: -2;
}
.cabra-lab-hero::after {
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(11,8,20,0.45), rgba(7,5,13,0.85)),
    radial-gradient(ellipse at center, transparent 30%, rgba(7,5,13,0.7) 90%);
  z-index: -1;
}
.cabra-lab-hero__inner { max-width: 800px; margin-inline: auto; padding-inline: 1.25rem; }
.cabra-lab-hero__title {
  font-size: var(--cabra-fs-h1);
  font-family: var(--cabra-font-serif);
  font-style: italic;
  background: linear-gradient(180deg, #fff7e0, var(--cabra-gold));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  margin-bottom: var(--cabra-space-3);
}
.cabra-lab-hero__subtitle {
  font-family: var(--cabra-font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.2rem, 1rem + 1vw, 1.6rem);
  color: var(--cabra-text-soft);
  margin-bottom: var(--cabra-space-3);
}
.cabra-lab-hero__lead {
  font-family: var(--cabra-font-serif);
  font-size: var(--cabra-fs-lead);
  color: var(--cabra-text-soft);
  line-height: 1.85;
}


/* =================================================================
   §11  PÁGINA: O Baú
   ================================================================= */
.cabra-bau-hero {
  text-align: center;
  padding-block: clamp(4rem, 8vw, 7rem) clamp(2rem, 4vw, 3rem);
}
.cabra-bau-hero h1 {
  font-family: var(--cabra-font-serif);
  font-style: italic;
  font-weight: 700;
  font-size: var(--cabra-fs-h1);
  background: linear-gradient(180deg, #fff7e0, var(--cabra-gold));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  margin-bottom: var(--cabra-space-4);
}
.cabra-bau-hero__lead {
  max-width: 70ch;
  margin: 0 auto;
  font-family: var(--cabra-font-serif);
  font-size: var(--cabra-fs-lead);
  color: var(--cabra-text-soft);
  line-height: 1.85;
}

.cabra-bau-banner {
  max-width: 1380px;
  margin: 0 auto;
  padding-inline: clamp(1rem, 4vw, 2.5rem);
}
.cabra-bau-banner img {
  width: 100%;
  height: auto;
  border-radius: var(--cabra-radius-lg);
  box-shadow: var(--cabra-shadow);
  border: 1px solid var(--cabra-line);
}

.cabra-bau-warn {
  max-width: 760px;
  margin: var(--cabra-space-5) auto;
  text-align: center;
  padding-inline: 1.5rem;
}
.cabra-bau-warn h4 {
  font-family: var(--cabra-font-display);
  font-style: normal;
  font-size: clamp(1.3rem, 1rem + 1vw, 1.7rem);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cabra-text);
  margin-bottom: var(--cabra-space-3);
}
.cabra-bau-warn h6 {
  font-size: 0.9rem;
  letter-spacing: 0.3em;
  margin-bottom: var(--cabra-space-2);
}
.cabra-bau-warn p {
  font-family: var(--cabra-font-serif);
  font-size: var(--cabra-fs-lead);
  color: var(--cabra-text-soft);
  line-height: 1.85;
  font-style: italic;
}


/* =================================================================
   §12  PÁGINA: Contato (Mensageria da Oficina)
   ================================================================= */
.cabra-contato {
  padding-block: clamp(4rem, 8vw, 7rem);
}
.cabra-contato__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}
@media (min-width: 880px) {
  .cabra-contato__grid {
    grid-template-columns: 1.05fr 1fr;
  }
}

.cabra-contato__form-wrap {
  background:
    radial-gradient(ellipse at top, rgba(201,162,74,0.10), transparent 70%),
    linear-gradient(180deg, rgba(26,21,53,0.85), rgba(20,16,42,0.85));
  border: 1px solid var(--cabra-line);
  border-radius: var(--cabra-radius-lg);
  box-shadow: var(--cabra-shadow);
  padding: clamp(1.75rem, 4vw, 3rem);
  position: relative;
}
.cabra-contato__form-wrap::before,
.cabra-contato__form-wrap::after {
  content: "";
  position: absolute; width: 24px; height: 24px;
  border: 1px solid var(--cabra-gold);
}
.cabra-contato__form-wrap::before {
  top: -1px; left: -1px;
  border-right: 0; border-bottom: 0;
}
.cabra-contato__form-wrap::after {
  bottom: -1px; right: -1px;
  border-left: 0; border-top: 0;
}

.cabra-contato__title {
  font-family: var(--cabra-font-serif);
  font-style: italic;
  font-weight: 600;
  font-size: clamp(1.5rem, 1.2rem + 1.4vw, 2rem);
  margin-bottom: var(--cabra-space-4);
  color: var(--cabra-text);
}
.cabra-contato__heading {
  font-family: var(--cabra-font-serif);
  font-style: italic;
  font-weight: 600;
  font-size: var(--cabra-fs-h1);
  background: linear-gradient(180deg, #fff7e0, var(--cabra-gold));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  margin-bottom: var(--cabra-space-3);
}
.cabra-contato__heading .cabra-emoji { -webkit-text-fill-color: initial; background: none; }

.cabra-contato__intro {
  font-family: var(--cabra-font-serif);
  font-size: var(--cabra-fs-lead);
  color: var(--cabra-text-soft);
  line-height: 1.85;
  margin-bottom: var(--cabra-space-3);
}

.cabra-contato__image {
  border-radius: var(--cabra-radius-lg);
  box-shadow: var(--cabra-shadow);
  border: 1px solid var(--cabra-line);
  margin-bottom: var(--cabra-space-3);
}

.cabra-contato__field {
  display: grid; gap: 0.4rem;
  margin-bottom: var(--cabra-space-3);
}
.cabra-contato__field label {
  font-family: var(--cabra-font-display);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--cabra-gold);
}
.cabra-contato__field input,
.cabra-contato__field textarea {
  font-family: var(--cabra-font-body);
  font-size: 1rem;
  color: var(--cabra-text);
  background: rgba(7,5,13,0.7);
  border: 1px solid var(--cabra-line-strong);
  border-radius: var(--cabra-radius);
  padding: 0.95rem 1.15rem;
  transition: border-color .25s, box-shadow .25s;
}
.cabra-contato__field textarea {
  min-height: 160px;
  resize: vertical;
  font-family: var(--cabra-font-serif);
  font-size: 1.05rem;
  line-height: 1.7;
}
.cabra-contato__field input:focus,
.cabra-contato__field textarea:focus {
  outline: none;
  border-color: var(--cabra-gold);
  box-shadow: 0 0 0 3px rgba(201,162,74,0.18);
}


/* =================================================================
   §13  RODAPÉ COM PERGAMINHO
   ================================================================= */
.site-footer {
  margin-top: var(--cabra-space-6);
  padding-top: var(--cabra-space-6);
  position: relative;
  isolation: isolate;
  border-top: 1px solid var(--cabra-line);
}
.site-footer::before {
  content: "";
  position: absolute; inset: 0;
  background-image: var(--cabra-img-rodape);
  background-size: cover;
  background-position: center bottom;
  filter: brightness(0.5) saturate(0.7);
  opacity: 0.5;
  z-index: -2;
}
.site-footer::after {
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(7,5,13,0.65) 0%, rgba(7,5,13,0.92) 100%);
  z-index: -1;
}

.site-footer__inner {
  display: grid;
  gap: var(--cabra-space-5);
  grid-template-columns: 1fr;
  padding-bottom: var(--cabra-space-5);
}

.site-footer__brand .site-branding__logo { width: 60px; height: 60px; }
.site-footer__tagline {
  color: var(--cabra-text-mute);
  font-style: italic;
  font-family: var(--cabra-font-serif);
  margin-top: var(--cabra-space-2);
  font-size: var(--cabra-fs-lead);
}

.site-footer__col h3,
.site-footer__title {
  font-family: var(--cabra-font-display);
  font-size: 0.82rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--cabra-gold);
  margin-bottom: var(--cabra-space-3);
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--cabra-line);
}

.site-footer__links,
.site-footer__contacts {
  list-style: none; margin: 0; padding: 0;
  display: grid; gap: 0.65rem;
}
.site-footer__links a {
  color: var(--cabra-text-soft);
  font-size: 0.95rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: color .25s, transform .25s;
}
.site-footer__links a:hover {
  color: var(--cabra-gold-bright);
  transform: translateX(4px);
}
.site-footer__contacts li { display: grid; gap: 0.15rem; }
.site-footer__contact-label {
  font-size: 0.72rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--cabra-text-mute);
}
.site-footer__contacts a {
  color: var(--cabra-text);
  font-size: 0.95rem;
  word-break: break-all;
}

.site-footer__copyright {
  border-top: 1px solid var(--cabra-line);
  padding-block: var(--cabra-space-3);
  text-align: center;
  color: var(--cabra-text-mute);
  font-size: var(--cabra-fs-sm);
}
.site-footer__divider {
  color: var(--cabra-gold);
  width: 200px; max-width: 60%;
  margin: 0 auto var(--cabra-space-2);
  opacity: 0.7;
}


/* =================================================================
   §14  COMPATIBILIDADE WORDPRESS
   ================================================================= */

/* Botão Gutenberg */
.wp-block-button .wp-block-button__link,
.wp-element-button {
  background: linear-gradient(180deg, var(--cabra-gold) 0%, var(--cabra-gold-deep) 100%) !important;
  color: var(--cabra-bg-deep) !important;
  border: 1px solid var(--cabra-gold-bright) !important;
  border-radius: var(--cabra-radius) !important;
  font-family: var(--cabra-font-display) !important;
  font-weight: 600 !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  padding: 1rem 1.95rem !important;
  box-shadow: 0 14px 45px -12px rgba(201,162,74,0.6) !important;
  transition: transform .3s, box-shadow .3s !important;
}
.wp-block-button .wp-block-button__link:hover,
.wp-element-button:hover { transform: translateY(-2px); }
.wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent !important;
  color: var(--cabra-gold) !important;
  border-color: var(--cabra-gold) !important;
  box-shadow: none !important;
}

/* Headings em Gutenberg */
.wp-block-heading,
.editor-styles-wrapper h1,
.editor-styles-wrapper h2,
.editor-styles-wrapper h3 {
  font-family: var(--cabra-font-display) !important;
  color: var(--cabra-text) !important;
}

/* Citações + separadores */
.wp-block-quote, blockquote {
  border-left: 2px solid var(--cabra-gold);
  padding: var(--cabra-space-2) var(--cabra-space-3);
  background: rgba(201,162,74,0.05);
  font-family: var(--cabra-font-serif);
  font-style: italic;
  color: var(--cabra-text-soft);
}
.wp-block-separator, hr.wp-block-separator, hr {
  border: none; height: 1px;
  background: linear-gradient(90deg, transparent, var(--cabra-gold), transparent);
  margin: var(--cabra-space-5) auto;
  max-width: 320px; opacity: 0.7;
}

/* Tabelas */
.wp-block-table table, table {
  border-collapse: collapse; width: 100%;
  border: 1px solid var(--cabra-line);
}
.wp-block-table th, .wp-block-table td,
table th, table td {
  padding: 0.85rem 1rem;
  border-bottom: 1px solid var(--cabra-line);
}
.wp-block-table th, table th {
  font-family: var(--cabra-font-display);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cabra-gold);
  font-size: 0.8rem;
}

/* Imagens */
.wp-block-image img {
  border-radius: var(--cabra-radius-lg);
  box-shadow: 0 25px 60px -25px rgba(0,0,0,0.85), 0 0 0 1px var(--cabra-line) inset;
}

/* Inputs / forms gerais */
input[type="text"], input[type="email"], input[type="url"],
input[type="tel"], input[type="number"], input[type="search"],
input[type="password"], textarea, select,
.wpcf7 input[type="text"], .wpcf7 input[type="email"], .wpcf7 textarea,
.wpforms-field input, .wpforms-field textarea, .wpforms-field select {
  font-family: var(--cabra-font-body);
  font-size: 1rem;
  color: var(--cabra-text);
  background: rgba(7,5,13,0.7);
  border: 1px solid var(--cabra-line-strong);
  border-radius: var(--cabra-radius);
  padding: 0.85rem 1.1rem;
  width: 100%;
  transition: border-color .25s, box-shadow .25s;
}
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--cabra-gold);
  box-shadow: 0 0 0 3px rgba(201,162,74,0.18);
}
::placeholder { color: var(--cabra-text-mute); font-style: italic; }

/* Submit em forms WP */
input[type="submit"], button[type="submit"],
.wpcf7 input[type="submit"], .wpforms-submit {
  background: linear-gradient(180deg, var(--cabra-gold) 0%, var(--cabra-gold-deep) 100%);
  color: var(--cabra-bg-deep);
  border: 1px solid var(--cabra-gold-bright);
  border-radius: var(--cabra-radius);
  font-family: var(--cabra-font-display);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 1rem 1.95rem;
  cursor: pointer;
  transition: transform .3s, box-shadow .3s;
  box-shadow: 0 14px 45px -12px rgba(201,162,74,0.6);
}
input[type="submit"]:hover, button[type="submit"]:hover { transform: translateY(-2px); }

/* Widgets */
.widget {
  background: rgba(20,16,42,0.55);
  border: 1px solid var(--cabra-line);
  border-radius: var(--cabra-radius-lg);
  padding: var(--cabra-space-3);
  margin-bottom: var(--cabra-space-3);
}
.widget-title, .widget h2, .widget h3 {
  font-family: var(--cabra-font-display);
  font-size: 0.85rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--cabra-gold);
  border-bottom: 1px solid var(--cabra-line);
  padding-bottom: 0.6rem;
  margin-bottom: var(--cabra-space-2);
}

/* WooCommerce */
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--cabra-gold) !important;
  font-family: var(--cabra-font-display);
}
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: linear-gradient(180deg, var(--cabra-gold), var(--cabra-gold-deep)) !important;
  color: var(--cabra-bg-deep) !important;
  border: 1px solid var(--cabra-gold-bright) !important;
  font-family: var(--cabra-font-display) !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  border-radius: var(--cabra-radius) !important;
}


/* =================================================================
   §15  RESPONSIVIDADE (Mobile-first)
   ================================================================= */
@media (max-width: 880px) {
  .cabra-menu-toggle { display: inline-block; color: var(--cabra-gold); }
  .main-navigation {
    position: fixed;
    inset: 80px 0 auto 0;
    background: linear-gradient(180deg, rgba(7,5,13,0.98), rgba(11,8,20,0.98));
    border-bottom: 1px solid var(--cabra-line);
    padding: var(--cabra-space-3) var(--cabra-space-3) var(--cabra-space-4);
    transform: translateY(-110%);
    transition: transform .35s ease;
    z-index: 50;
  }
  .main-navigation.is-open { transform: translateY(0); }
  .main-navigation__list {
    flex-direction: column; gap: 1.1rem; align-items: center;
  }
  .main-navigation a {
    font-size: 0.95rem; letter-spacing: 0.22em;
  }
  .site-branding__top    { font-size: 0.65rem; }
  .site-branding__bottom { font-size: 1rem; }
  .site-branding__logo   { width: 46px; height: 46px; }

  .cabra-newsletter__form { flex-direction: column; }
  .cabra-newsletter__form input[type="email"],
  .cabra-newsletter__form .cabra-btn { width: 100%; flex: 1 1 auto; }
  .cabra-newsletter__form .cabra-btn { justify-content: center; }
}

@media (min-width: 760px) {
  .site-footer__inner {
    grid-template-columns: 1.2fr 1fr 1.3fr;
    gap: var(--cabra-space-5);
  }
}
@media (min-width: 1024px) {
  .site-header { padding-block: var(--cabra-space-4); }
}


/* =================================================================
   §16  ACESSIBILIDADE — reduzir movimento
   ================================================================= */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}
