/* Fallback system-font stack enquanto Barlow carrega */
@font-face {
  font-family: 'Barlow';
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: local('Barlow');
}
/*
Theme Name:  CEADV
Theme URI:   https://ceadv.com.br
Author:      Eduardo Cardoso Advogados & Associados
Author URI:  https://ceadv.com.br
Description: Tema profissional CEADV v7 — paleta completa (Gold #B8960C · Wine #6B1A1A · Navy #1A2354 · Dark #1A1A1A)
Version:     7.0
Requires at least: 6.0
Requires PHP: 8.0
License:     Proprietary
Text Domain: ceadv
*/

/* ============================================================
   DESIGN TOKENS — CEADV v7
   Gold  #B8960C  dourado âmbar principal
   Wine  #6B1A1A  vinho (acento discreto: barras, sublinhados, ícones)
   Navy  #1A2354  azul-marinho (acento discreto: fundos alt, bordas)
   Dark  #1A1A1A  preto profundo — header / footer / hero
   ============================================================ */
:root {
  /* Paleta */
  --gold:         #B8960C;
  --gold-light:   #D4AC15;
  --gold-pale:    #E8D168;
  --gold-dark:    #8C7009;
  --wine:         #6B1A1A;
  --wine-light:   #8B2A2A;
  --wine-pale:    #F5EDED;
  --navy:         #1A2354;
  --navy-light:   #243070;
  --navy-pale:    #EDF0FA;
  --dark:         #1A1A1A;
  --dark-mid:     #252525;
  --gray:         #333333;
  --gray-mid:     #555555;
  --gray-light:   #888888;
  --white:        #FFFFFF;
  --off-white:    #F8F6F1;
  --border:       #E8E4DB;

  /* Tipografia */
  --font: 'Barlow', sans-serif;

  /* Espaçamentos */
  --sp-2:.5rem; --sp-3:.75rem; --sp-4:1rem; --sp-6:1.5rem;
  --sp-8:2rem; --sp-10:2.5rem; --sp-12:3rem; --sp-16:4rem;
  --sp-20:5rem; --sp-24:6rem;

  /* Bordas */
  --r-sm:2px; --r-md:4px; --r-lg:8px; --r-xl:16px;

  /* Sombras */
  --sh-sm: 0 1px 4px rgba(0,0,0,.08);
  --sh-md: 0 4px 20px rgba(0,0,0,.14);
  --sh-lg: 0 8px 40px rgba(0,0,0,.18);
  --sh-gold: 0 4px 24px rgba(184,150,12,.28);
  --sh-wine: 0 4px 20px rgba(107,26,26,.25);

  /* Transições */
  --t:.25s ease;
  --t-slow:.45s ease;

  /* Header */
  --hh:80px;
  --hh-lg:100px;

  /* Container */
  --cmax:1280px;
  --cpad:1.5rem;
}

/* ── RESET ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);font-size:1rem;color:var(--gray);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:inherit}

/* ── UTILITÁRIOS ────────────────────────────────────────────── */
.container{width:100%;max-width:var(--cmax);margin-inline:auto;padding-inline:var(--cpad)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .65s ease,transform .65s ease}
.fade-in.visible{opacity:1;transform:none}

/* ── TIPOGRAFIA ─────────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{font-family:var(--font);font-weight:800;line-height:1.15;color:var(--dark)}
h1{font-size:clamp(2rem,5vw,3.75rem)}
h2{font-size:clamp(1.55rem,3.5vw,2.5rem)}
h3{font-size:clamp(1.15rem,2.5vw,1.65rem)}
h4{font-size:1.1rem}
p{margin-bottom:var(--sp-4)}
p:last-child{margin-bottom:0}
strong{font-weight:700}

/* ── SECTION LABEL ──────────────────────────────────────────── */
.section-label{
  display:inline-flex;align-items:center;gap:var(--sp-3);
  font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);margin-bottom:var(--sp-4);
}
.section-label::before{content:'';display:block;width:32px;height:2px;background:var(--gold);flex-shrink:0}

/* Variantes de label */
.section-label--wine{color:var(--wine)}
.section-label--wine::before{background:var(--wine)}
.section-label--navy{color:var(--navy)}
.section-label--navy::before{background:var(--navy)}

/* ── BOTÕES ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:.82em 2em;font-family:var(--font);font-size:.82rem;
  font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  border-radius:var(--r-sm);
  transition:background var(--t),color var(--t),transform var(--t),box-shadow var(--t);
  white-space:nowrap;cursor:pointer;border:none;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:none}

.btn-gold{background:var(--gold);color:var(--dark);box-shadow:var(--sh-gold)}
.btn-gold:hover{background:var(--gold-light);box-shadow:0 6px 28px rgba(184,150,12,.4)}
.btn-wine{background:var(--wine);color:var(--white);box-shadow:var(--sh-wine)}
.btn-wine:hover{background:var(--wine-light)}
.btn-navy{background:var(--navy);color:var(--white)}
.btn-navy:hover{background:var(--navy-light)}
.btn-dark{background:var(--dark);color:var(--white)}
.btn-dark:hover{background:var(--dark-mid)}
.btn-outline-gold{background:transparent;border:2px solid var(--gold);color:var(--white)}
.btn-outline-gold:hover{background:var(--gold);color:var(--dark)}
.btn-outline-wine{background:transparent;border:2px solid var(--wine);color:var(--wine)}
.btn-outline-wine:hover{background:var(--wine);color:var(--white)}
.btn-wa{background:#25D366;color:var(--white);box-shadow:0 4px 16px rgba(37,211,102,.32)}
.btn-wa:hover{background:#1ebe5c;box-shadow:0 6px 24px rgba(37,211,102,.48)}
.btn-wa svg{fill:var(--white);flex-shrink:0}

/* ── FORMS ─────────────────────────────────────────────────── */
.form-group{margin-bottom:var(--sp-4)}
.form-label{display:block;font-size:.8rem;font-weight:700;color:var(--dark);margin-bottom:var(--sp-2);letter-spacing:.05em;text-transform:uppercase}
.form-control{
  display:block;width:100%;padding:.75em 1em;
  font-family:var(--font);font-size:1rem;color:var(--gray);
  background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);
  transition:border-color var(--t),box-shadow var(--t);
}
.form-control:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,150,12,.15)}
textarea.form-control{resize:vertical;min-height:140px}

/* ══════════════════════════════════════════════════════════════
   HEADER
══════════════════════════════════════════════════════════════ */
#site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--hh);background:var(--dark);
  border-bottom:2px solid transparent;
  transition:border-color var(--t),box-shadow var(--t),background var(--t);
}
#site-header.scrolled{
  background:rgba(26,26,26,.97);border-bottom-color:var(--gold);
  box-shadow:0 2px 24px rgba(0,0,0,.4);backdrop-filter:blur(8px);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;gap:var(--sp-6);max-width:var(--cmax);margin:0 auto;padding-inline:var(--cpad);
}

/* Logo */
.header-logo{flex-shrink:0}
.header-logo img,.header-logo .wp-custom-logo img{height:54px;width:auto}
.logo-text-fallback{font-size:1.1rem;font-weight:800;color:var(--white);letter-spacing:.05em;text-transform:uppercase}
.logo-text-fallback span{color:var(--gold)}

/* Nav desktop */
.nav-desktop{display:none}
.nav-desktop ul{display:flex;align-items:center;gap:var(--sp-1)}
.nav-desktop ul li{position:relative}
.nav-desktop ul li > a{
  color:rgba(255,255,255,.8);font-size:.8rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  padding:var(--sp-3) var(--sp-4);display:block;
  border-bottom:2px solid transparent;
  transition:color var(--t),border-color var(--t);
}
.nav-desktop ul li > a:hover,
.nav-desktop ul li.current-menu-item > a,
.nav-desktop ul li.current-page-ancestor > a{color:var(--gold);border-bottom-color:var(--gold)}

/* Dropdown */
.nav-desktop .sub-menu{
  display:none;position:absolute;top:calc(100% + 2px);left:50%;
  transform:translateX(-50%);
  background:var(--dark);border-top:2px solid var(--wine);
  border-radius:0 0 var(--r-md) var(--r-md);
  box-shadow:var(--sh-lg);min-width:260px;padding:var(--sp-3) 0;z-index:100;
}
.nav-desktop li:hover > .sub-menu,.nav-desktop li:focus-within > .sub-menu{display:block}
.nav-desktop .sub-menu li a{
  color:rgba(255,255,255,.72);font-size:.8rem;font-weight:500;
  padding:var(--sp-3) var(--sp-6);display:block;
  border-bottom:none;text-transform:none;letter-spacing:.04em;
  transition:color var(--t),padding var(--t),background var(--t);
}
.nav-desktop .sub-menu li a:hover{color:var(--gold);background:rgba(255,255,255,.05);padding-left:calc(var(--sp-6) + 6px)}

/* Header actions */
.header-actions{display:flex;align-items:center;gap:var(--sp-3);flex-shrink:0}
.btn-header-whatsapp{
  display:flex;align-items:center;gap:var(--sp-2);
  background:#25D366;color:var(--white);
  padding:.5em 1.2em;border-radius:var(--r-sm);
  font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  transition:background var(--t);white-space:nowrap;
}
.btn-header-whatsapp:hover{background:#1ebe5c}
.btn-header-whatsapp svg{width:16px;height:16px;fill:var(--white)}
.btn-header-whatsapp .btn-label{display:none}

/* Seletor idiomas */
.lang-selector{position:relative}
.lang-toggle{
  display:flex;align-items:center;gap:4px;background:transparent;
  border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.75);
  border-radius:var(--r-sm);padding:.4em .75em;font-size:.75rem;font-weight:600;
  cursor:pointer;transition:border-color var(--t),color var(--t);
  letter-spacing:.06em;text-transform:uppercase;
}
.lang-toggle:hover{border-color:var(--gold);color:var(--gold)}
.lang-code{display:none}
.lang-arrow{font-size:.65em;transition:transform var(--t)}
.lang-selector.open .lang-arrow{transform:rotate(180deg)}
.lang-dropdown{
  position:absolute;top:calc(100% + 6px);right:0;
  background:var(--dark);border-top:2px solid var(--wine);
  border-radius:0 0 var(--r-md) var(--r-md);
  box-shadow:var(--sh-lg);min-width:180px;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity var(--t),visibility var(--t),transform var(--t);z-index:200;
}
.lang-selector.open .lang-dropdown{opacity:1;visibility:visible;transform:none}
.lang-option{
  display:flex;align-items:center;gap:var(--sp-3);
  padding:var(--sp-3) var(--sp-4);font-size:.82rem;
  color:rgba(255,255,255,.7);cursor:pointer;
  transition:color var(--t),background var(--t);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.lang-option:last-child{border-bottom:none}
.lang-option:hover{color:var(--gold);background:rgba(255,255,255,.04)}
.lang-option.active{color:var(--gold);font-weight:700}

/* Hamburger */
.btn-hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:var(--sp-2)}
.btn-hamburger span{display:block;height:2px;background:var(--white);border-radius:2px;transition:transform var(--t),opacity var(--t),width var(--t)}
.btn-hamburger span:nth-child(2){width:70%}
.btn-hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.btn-hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.btn-hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav */
#mobile-nav{
  position:fixed;top:0;right:0;bottom:0;width:min(320px,88vw);
  background:var(--dark);border-left:3px solid var(--wine);
  transform:translateX(100%);transition:transform var(--t-slow);
  z-index:1100;overflow-y:auto;padding:var(--sp-8) var(--sp-6);
}
#mobile-nav.open{transform:none}
.mobile-nav-close{position:absolute;top:var(--sp-4);right:var(--sp-4);color:var(--white);font-size:1.4rem;padding:var(--sp-2);transition:color var(--t)}
.mobile-nav-close:hover{color:var(--gold)}
#mobile-nav ul{margin-top:var(--sp-12)}
#mobile-nav ul li{border-bottom:1px solid rgba(255,255,255,.07)}
#mobile-nav ul li a{
  display:block;padding:var(--sp-4) 0;color:rgba(255,255,255,.85);
  font-size:.88rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  transition:color var(--t),padding var(--t);
}
#mobile-nav ul li a:hover{color:var(--gold);padding-left:var(--sp-3)}
#mobile-nav .sub-menu{padding-left:var(--sp-4);border-top:1px solid rgba(255,255,255,.05)}
#mobile-nav .sub-menu li a{font-size:.82rem;text-transform:none;color:rgba(255,255,255,.6);letter-spacing:.04em}
.mobile-nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);opacity:0;visibility:hidden;transition:opacity var(--t-slow),visibility var(--t-slow);z-index:1050}
.mobile-nav-overlay.open{opacity:1;visibility:visible}

/* ══════════════════════════════════════════════════════════════
   HERO — Ken Burns responsivo
══════════════════════════════════════════════════════════════ */
#hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--dark);padding-top:var(--hh)}
@media(min-width:1024px){#hero{padding-top:var(--hh-lg)}}

/* Hero background — base: estático em todos os dispositivos */
#hero-bg{
  position:absolute;inset:-2%;
  background-size:cover;background-position:center 25%;background-repeat:no-repeat;
  /* Sem animação por padrão — mobile e tablet ficam estáticos */
}
#hero-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(155deg,rgba(26,26,26,.92) 0%,rgba(26,26,26,.72) 55%,rgba(107,26,26,.2) 100%);
}

/* Ken Burns declarado aqui no style.css (carrega depois do critical CSS)
   O !important garante que sobrescreve qualquer inline anterior no desktop */
@keyframes kb-desktop{
  0%  {transform:scale3d(1.00,1.00,1)}
  50% {transform:scale3d(1.05,1.05,1)}
  100%{transform:scale3d(1.00,1.00,1)}
}
@media(min-width:1200px){
  #hero-bg{
    inset:-5% !important;
    animation:kb-desktop 32s ease-in-out infinite alternate !important;
    will-change:transform;
  }
}

.hero-content{position:relative;z-index:2;max-width:740px;padding-block:6rem 14rem}
.hero-badge{
  display:inline-block;background:rgba(184,150,12,.18);border:1px solid rgba(184,150,12,.45);
  color:var(--gold-pale);font-size:.7rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;padding:.45em 1.4em;border-radius:999px;margin-bottom:var(--sp-6);
}
/* Acento vinho: linha sob o badge */
.hero-badge-wine-line{display:block;width:64px;height:2px;background:var(--wine);margin-bottom:var(--sp-6);opacity:.8}
.hero-title{font-size:clamp(2rem,5vw,3.75rem);font-weight:800;color:var(--white);line-height:1.1;margin-bottom:var(--sp-6)}
.hero-sub{font-size:clamp(1rem,2vw,1.15rem);color:rgba(255,255,255,.76);margin-bottom:var(--sp-10);max-width:580px;line-height:1.78}
.hero-actions{display:flex;flex-wrap:wrap;gap:var(--sp-4)}

/* Stats bar — navy */
.hero-stats{position:absolute;bottom:0;left:0;right:0;z-index:3;background:var(--navy)}
.hero-stats-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.08)}
.stat-item{background:var(--navy);padding:var(--sp-6) var(--sp-4);text-align:center}
.stat-number{display:block;font-size:clamp(1.75rem,4vw,2.75rem);font-weight:800;color:var(--gold);line-height:1;margin-bottom:var(--sp-2)}
.stat-label{font-size:.72rem;font-weight:600;color:rgba(255,255,255,.65);letter-spacing:.04em;line-height:1.4}

/* Scroll hint */
.scroll-hint{
  position:absolute;bottom:90px;left:50%;transform:translateX(-50%);
  z-index:3;display:flex;flex-direction:column;align-items:center;gap:.4rem;
  opacity:.5;animation:scroll-bounce 2.5s ease-in-out infinite;pointer-events:none;
}
.scroll-hint span{font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--white)}
.scroll-hint svg{width:18px;height:18px;fill:var(--gold)}
@keyframes scroll-bounce{0%,100%{transform:translateX(-50%) translateY(0);opacity:.5}50%{transform:translateX(-50%) translateY(6px);opacity:.9}}

/* ══════════════════════════════════════════════════════════════
   SEÇÕES GENÉRICAS
══════════════════════════════════════════════════════════════ */
.section{padding-block:var(--sp-20)}
/* Seções abaixo do fold: browser não renderiza até próximo do viewport */
.section+.section,.section~.section{content-visibility:auto;contain-intrinsic-size:0 400px}
.section-white{background:var(--white)}
.section-off{background:var(--off-white)}
.section-dark{background:var(--dark);color:var(--white)}
.section-dark h2,.section-dark h3,.section-dark h4{color:var(--white)}
.section-navy{background:var(--navy);color:var(--white)}
.section-navy h2,.section-navy h3{color:var(--white)}
.section-wine{background:var(--wine);color:var(--white)}
.section-wine h2,.section-wine h3{color:var(--white)}

.section-header{text-align:center;max-width:700px;margin-inline:auto;margin-bottom:var(--sp-16)}
.section-header h2{margin-bottom:var(--sp-4)}
.section-header p{color:var(--gray-light);font-size:1.05rem}

/* Acento vinho: barra lateral nas seções alternadas */
.wine-accent{border-left:3px solid var(--wine);padding-left:var(--sp-4)}
.navy-accent{border-left:3px solid var(--navy);padding-left:var(--sp-4)}

/* ══════════════════════════════════════════════════════════════
   CARDS DE SERVIÇO
══════════════════════════════════════════════════════════════ */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(272px,1fr));gap:var(--sp-6)}
.service-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:var(--sp-8);display:flex;flex-direction:column;gap:var(--sp-4);
  position:relative;overflow:hidden;
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--wine) 0%,var(--gold) 100%);
  transform:scaleX(0);transform-origin:left;transition:transform var(--t);
}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{
  width:52px;height:52px;background:rgba(184,150,12,.1);border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;color:var(--gold);
}
.service-icon svg{width:26px;height:26px}
.service-card h3{font-size:.98rem;font-weight:700;color:var(--dark);line-height:1.35}
.service-card p{font-size:.88rem;color:var(--gray-light);line-height:1.65;flex:1}
.card-link{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  font-size:.76rem;font-weight:700;color:var(--wine);
  letter-spacing:.1em;text-transform:uppercase;transition:gap var(--t),color var(--t);
}
.card-link:hover{gap:var(--sp-4);color:var(--gold)}

/* ══════════════════════════════════════════════════════════════
   SLIDESHOW DE FOTOS (Quem Somos / Home)
══════════════════════════════════════════════════════════════ */
.photo-slider{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio:4/5;background:var(--dark);
  /* Badge OAB posicionado sobre o slider */
}
@media(min-width:900px){.photo-slider{aspect-ratio:unset;height:560px}}
.photo-slider-track{position:relative;width:100%;height:100%}
.photo-slide{
  position:absolute;inset:0;opacity:0;
  transition:opacity 1.2s ease;
}
.photo-slide.active{opacity:1}
.photo-slide img{
  width:100%;height:100%;object-fit:cover;object-position:center 20%;
  /* Ken Burns por slide */
  animation:none;
}
.photo-slide.active img{animation:kb-slide 12s ease-in-out forwards;will-change:transform}
@keyframes kb-slide{
  0%  {transform:scale3d(1.00,1.00,1)}
  100%{transform:scale3d(1.07,1.07,1)}
}

/* Setas do slider */
.slider-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:5;width:42px;height:42px;border-radius:50%;
  background:rgba(26,26,26,.65);border:2px solid var(--gold);
  color:var(--gold);display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background var(--t),transform var(--t);
  backdrop-filter:blur(4px);
}
.slider-btn:hover{background:var(--gold);color:var(--dark);transform:translateY(-50%) scale(1.08)}
.slider-btn svg{width:18px;height:18px;fill:currentColor}
.slider-prev{left:var(--sp-4)}
.slider-next{right:var(--sp-4)}

/* Dots */
.slider-dots{
  position:absolute;bottom:var(--sp-4);left:50%;transform:translateX(-50%);
  display:flex;gap:var(--sp-2);z-index:5;
}
.slider-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.4);border:none;cursor:pointer;
  transition:background var(--t),transform var(--t);
}
.slider-dot.active{background:var(--gold);transform:scale(1.3)}

/* Badge OAB sobre o slider */
.slider-badge{
  position:absolute;bottom:var(--sp-6);left:var(--sp-6);z-index:6;
  background:var(--wine);color:var(--white);
  font-weight:800;font-size:.78rem;padding:.5rem 1.25rem;
  border-radius:var(--r-sm);letter-spacing:.06em;text-transform:uppercase;
  border-left:3px solid var(--gold);
}

/* ══════════════════════════════════════════════════════════════
   SEÇÃO SOBRE / RESPONSÁVEL
══════════════════════════════════════════════════════════════ */
.about-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-12);align-items:center}
@media(min-width:900px){.about-grid{grid-template-columns:420px 1fr}}
.about-content h2{color:var(--dark);margin-bottom:.35rem}
.about-content .oab-tag{
  display:inline-block;font-size:.78rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--wine);margin-bottom:var(--sp-6);
}
.about-content p{color:var(--gray-mid);line-height:1.85;margin-bottom:var(--sp-4)}
.about-btns{display:flex;gap:var(--sp-4);flex-wrap:wrap;margin-top:var(--sp-8)}

/* ══════════════════════════════════════════════════════════════
   CTA BANNER
══════════════════════════════════════════════════════════════ */
.cta-section{
  padding-block:var(--sp-20);background:var(--dark);text-align:center;
  position:relative;overflow:hidden;
}
/* Acento vinho: faixa topo */
.cta-section::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--wine),var(--gold),var(--wine))}
.cta-section::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 700px 400px at 50% 0%,rgba(184,150,12,.07),transparent);pointer-events:none}
.cta-section h2{color:var(--white);margin-bottom:var(--sp-4);position:relative;z-index:1}
.cta-section p{color:rgba(255,255,255,.7);margin-bottom:var(--sp-8);font-size:1.05rem;position:relative;z-index:1}
.cta-actions{display:flex;flex-wrap:wrap;gap:var(--sp-4);justify-content:center;position:relative;z-index:1}

/* ══════════════════════════════════════════════════════════════
   BLOG CARDS
══════════════════════════════════════════════════════════════ */
.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--sp-8)}
.post-card{
  background:var(--white);border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--border);box-shadow:var(--sh-sm);
  transition:box-shadow var(--t),transform var(--t);display:flex;flex-direction:column;
}
.post-card:hover{box-shadow:var(--sh-lg);transform:translateY(-4px)}
.post-card-thumb{display:block;height:210px;overflow:hidden;flex-shrink:0}
.post-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.post-card:hover .post-card-thumb img{transform:scale(1.05)}
.post-card-thumb-placeholder{width:100%;height:210px;background:var(--dark);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:2.5rem}
.post-card-body{padding:var(--sp-6);display:flex;flex-direction:column;flex:1}
.post-card-cat{
  display:inline-block;background:var(--wine);color:var(--white);
  font-size:.68rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  padding:.25em .9em;border-radius:999px;margin-bottom:var(--sp-3);
}
.post-card-title{font-size:1rem;font-weight:700;color:var(--dark);margin-bottom:var(--sp-3);line-height:1.35;transition:color var(--t)}
.post-card:hover .post-card-title{color:var(--wine)}
.post-card-excerpt{font-size:.88rem;color:var(--gray-light);line-height:1.65;margin-bottom:var(--sp-6);flex:1}
.post-card-link{font-size:.76rem;font-weight:800;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;margin-top:auto;transition:color var(--t)}
.post-card-link:hover{color:var(--wine)}

/* Paginação */
.pagination{display:flex;justify-content:center;gap:var(--sp-2);margin-top:var(--sp-12);flex-wrap:wrap}
.page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;font-size:.85rem;font-weight:700;
  border-radius:var(--r-md);color:var(--dark);border:1px solid var(--border);
  transition:background var(--t),color var(--t),border-color var(--t);
}
.page-numbers:hover,.page-numbers.current{background:var(--wine);color:var(--white);border-color:var(--wine)}

/* ══════════════════════════════════════════════════════════════
   SINGLE POST
══════════════════════════════════════════════════════════════ */
.single-hero{padding-top:calc(var(--hh) + var(--sp-16));padding-bottom:var(--sp-12);background:var(--dark);color:var(--white)}
.single-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-4);font-size:.82rem;color:rgba(255,255,255,.55);margin-bottom:var(--sp-6)}
.single-title{color:var(--white)}
.single-content{max-width:780px;margin-inline:auto;padding-block:var(--sp-16)}
.single-content h2,.single-content h3{margin-top:var(--sp-10);margin-bottom:var(--sp-4)}
.single-content p{color:var(--gray-mid);line-height:1.85;margin-bottom:var(--sp-6)}
.single-content ul,.single-content ol{margin-left:var(--sp-6);margin-bottom:var(--sp-6)}
.single-content ul li{list-style:disc;margin-bottom:var(--sp-2)}
.single-content ol li{list-style:decimal;margin-bottom:var(--sp-2)}
.single-content img{border-radius:var(--r-lg);margin-block:var(--sp-8)}
.single-content blockquote{
  border-left:4px solid var(--wine);padding:var(--sp-4) var(--sp-6);
  background:var(--off-white);border-radius:0 var(--r-md) var(--r-md) 0;
  margin-block:var(--sp-8);font-style:italic;color:var(--dark);
}
.share-buttons{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-3);padding-block:var(--sp-8);border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:var(--sp-12)}
.share-label{font-weight:700;font-size:.8rem;color:var(--dark);text-transform:uppercase;letter-spacing:.08em}
.share-btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:.5em 1.2em;border-radius:999px;font-size:.75rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;transition:opacity var(--t)}
.share-btn:hover{opacity:.85}
.share-btn-wa{background:#25D366;color:var(--white)}
.share-btn-fb{background:#1877F2;color:var(--white)}
.share-btn-li{background:#0A66C2;color:var(--white)}

/* Sidebar blog */
.blog-layout{display:grid;grid-template-columns:1fr;gap:var(--sp-12)}
.sidebar-widget{margin-bottom:var(--sp-8);padding:var(--sp-6);background:var(--off-white);border-radius:var(--r-lg);border:1px solid var(--border)}
.sidebar-widget-title{font-size:.8rem;font-weight:800;color:var(--dark);margin-bottom:var(--sp-6);padding-bottom:var(--sp-3);border-bottom:2px solid var(--wine);text-transform:uppercase;letter-spacing:.1em}
.sidebar-search{display:flex;gap:var(--sp-2)}
.sidebar-search input{flex:1}
.sidebar-search button{background:var(--wine);color:var(--white);padding:.75em 1.2em;border-radius:var(--r-md);font-size:.82rem;font-weight:700;cursor:pointer;transition:background var(--t)}
.sidebar-search button:hover{background:var(--wine-light)}
.sidebar-cats li{border-bottom:1px solid var(--border)}
.sidebar-cats li:last-child{border:none}
.sidebar-cats li a{display:flex;justify-content:space-between;padding:var(--sp-3) 0;font-size:.88rem;color:var(--gray-mid);transition:color var(--t)}
.sidebar-cats li a:hover{color:var(--wine)}
.sidebar-cats li a span{background:var(--wine);color:var(--white);font-size:.72rem;font-weight:800;padding:.15em .65em;border-radius:999px}
.recent-post-item{display:flex;gap:var(--sp-4);padding-bottom:var(--sp-4);margin-bottom:var(--sp-4);border-bottom:1px solid var(--border)}
.recent-post-item:last-child{border:none;margin:0;padding:0}
.recent-post-thumb{width:72px;height:72px;flex-shrink:0;border-radius:var(--r-md);overflow:hidden}
.recent-post-thumb img{width:100%;height:100%;object-fit:cover}
.recent-post-title{font-size:.88rem;font-weight:700;color:var(--dark);line-height:1.35;margin-bottom:var(--sp-2);display:block;transition:color var(--t)}
.recent-post-title:hover{color:var(--wine)}
.recent-post-date{font-size:.75rem;color:var(--gray-light)}

/* ══════════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════════ */
#site-footer{background:var(--dark);color:rgba(255,255,255,.62);padding-top:var(--sp-16);border-top:3px solid var(--wine)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-10);padding-bottom:var(--sp-12)}
.footer-col h4{font-size:.78rem;font-weight:800;color:var(--gold);margin-bottom:var(--sp-6);text-transform:uppercase;letter-spacing:.14em}
.footer-logo img{height:52px;width:auto}
.footer-cnpj{font-size:.72rem;color:rgba(255,255,255,.32);margin-top:var(--sp-4);margin-bottom:var(--sp-6)}
.footer-socials{display:flex;gap:var(--sp-3);flex-wrap:wrap}
.footer-social-link{
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-md);color:rgba(255,255,255,.6);
  transition:background var(--t),color var(--t),border-color var(--t);
}
.footer-social-link:hover{background:var(--wine);color:var(--white);border-color:var(--wine)}
.footer-nav li{margin-bottom:var(--sp-3)}
.footer-nav li a{font-size:.88rem;color:rgba(255,255,255,.52);transition:color var(--t),padding var(--t)}
.footer-nav li a:hover{color:var(--gold);padding-left:var(--sp-2)}
.footer-contact-item{display:flex;gap:var(--sp-3);font-size:.88rem;margin-bottom:var(--sp-4);align-items:flex-start}
.footer-contact-item svg{flex-shrink:0;width:18px;height:18px;fill:var(--wine);margin-top:2px}
.footer-contact-item a{color:rgba(255,255,255,.52);transition:color var(--t)}
.footer-contact-item a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:var(--sp-6) 0;display:flex;flex-wrap:wrap;gap:var(--sp-4);justify-content:space-between;align-items:center}
.footer-bottom-copy{font-size:.75rem;color:rgba(255,255,255,.32)}
.footer-bottom-links{display:flex;gap:var(--sp-6);flex-wrap:wrap}
.footer-bottom-links a{font-size:.75rem;color:rgba(255,255,255,.32);transition:color var(--t)}
.footer-bottom-links a:hover{color:var(--gold)}

/* WhatsApp flutuante */
.whatsapp-float{
  position:fixed;bottom:var(--sp-6);right:var(--sp-6);z-index:900;
  background:#25D366;color:var(--white);width:58px;height:58px;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.45);transition:transform var(--t),box-shadow var(--t);
}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,.6)}
.whatsapp-float svg{width:28px;height:28px;fill:var(--white)}

/* ══════════════════════════════════════════════════════════════
   PÁGINA INTERNA — HERO
══════════════════════════════════════════════════════════════ */
.page-hero{
  padding-top:calc(var(--hh) + var(--sp-16));padding-bottom:var(--sp-12);
  background:var(--dark);position:relative;overflow:hidden;
}
@media(min-width:1024px){.page-hero{padding-top:calc(var(--hh-lg) + var(--sp-16))}}
.page-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--wine) 0%,var(--gold) 50%,var(--wine) 100%)}
.page-hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 600px 300px at 100% 50%,rgba(107,26,26,.12),transparent);pointer-events:none}
.page-hero h1{color:var(--white);position:relative;z-index:1}
.breadcrumb{display:flex;gap:var(--sp-2);font-size:.8rem;color:rgba(255,255,255,.48);margin-bottom:var(--sp-4);flex-wrap:wrap;position:relative;z-index:1}
.breadcrumb a{color:rgba(255,255,255,.48);transition:color var(--t)}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span:last-child{color:var(--wine-light)}
.page-hero p.hero-desc{color:rgba(255,255,255,.72);font-size:1.05rem;max-width:640px;margin-top:var(--sp-4);position:relative;z-index:1}
.page-content{max-width:840px;margin-inline:auto;padding-block:var(--sp-16)}
.page-content h2,.page-content h3{margin-top:var(--sp-10);margin-bottom:var(--sp-4)}
.page-content p{color:var(--gray-mid);line-height:1.85;margin-bottom:var(--sp-6)}
.page-content ul li{list-style:disc;margin-left:var(--sp-6);margin-bottom:var(--sp-2)}

/* ══════════════════════════════════════════════════════════════
   PÁGINA DE REDES SOCIAIS
══════════════════════════════════════════════════════════════ */
.social-page-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-10)}
@media(min-width:900px){.social-page-grid{grid-template-columns:1fr 340px}}
.social-links-sidebar{display:flex;flex-direction:column;gap:var(--sp-4)}
.social-card{
  display:flex;align-items:center;gap:var(--sp-4);
  background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:var(--sp-4) var(--sp-6);
  transition:box-shadow var(--t),transform var(--t),border-color var(--t);
  border-left:4px solid var(--wine);
}
.social-card:hover{box-shadow:var(--sh-md);transform:translateX(4px);border-left-color:var(--gold)}
.social-card-icon{width:46px;height:46px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.social-card-icon svg{width:24px;height:24px;fill:var(--white)}
.social-card-info h4{font-size:.9rem;font-weight:700;color:var(--dark);margin-bottom:.15rem}
.social-card-info span{font-size:.8rem;color:var(--gray-light)}
.social-card-arrow{margin-left:auto;color:var(--gold);font-size:1.2rem}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVO
══════════════════════════════════════════════════════════════ */
@media(min-width:768px){
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:400px 1fr}
  .blog-layout{grid-template-columns:60fr 40fr}
}
@media(min-width:1024px){
  #site-header{height:var(--hh-lg)}
  .btn-hamburger{display:none}
  .nav-desktop{display:block}
  .btn-header-whatsapp .btn-label{display:inline}
  .lang-code{display:inline}
  .footer-grid{grid-template-columns:1.6fr 1fr 1fr 1fr}
}
@media(min-width:1280px){
  .services-grid{grid-template-columns:repeat(4,1fr)}
}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
