/*
Theme Name:   Advocacia Child
Theme URI:    https://seudominio.com.br
Description:  Tema filho do Hello Elementor para escritório de advocacia
Author:       Seu Nome
Template:     hello-elementor
Version:      1.0.0
Text Domain:  advocacia-child
*/

/* ============================================================
   IMPORTA O TEMA PAI (Hello Elementor)
   ============================================================ */
@import url("../hello-elementor/style.css");

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

/* ============================================================
   CSS VARIABLES — PALETA E TOKENS
   ============================================================ */
:root {
  --adv-gold:        #C9952A;
  --adv-gold-light:  #D4A843;
  --adv-gold-dim:    rgba(201, 149, 42, 0.12);
  --adv-dark:        #0D0D0D;
  --adv-dark-2:      #141414;
  --adv-dark-3:      #1C1C1C;
  --adv-dark-4:      #252525;
  --adv-light:       #F9F6F0;
  --adv-white:       #FFFFFF;
  --adv-text:        #1A1A1A;
  --adv-muted:       #666666;
  --adv-border:      rgba(201, 149, 42, 0.2);
  --adv-border-dark: rgba(255, 255, 255, 0.08);
  --adv-radius:      8px;
  --adv-radius-lg:   16px;
  --adv-shadow:      0 4px 24px rgba(0,0,0,0.08);
  --adv-shadow-lg:   0 12px 48px rgba(0,0,0,0.14);
  --adv-transition:  0.3s cubic-bezier(.4,0,.2,1);
}

/* ============================================================
   RESET GLOBAL DENTRO DO ELEMENTOR
   ============================================================ */
.elementor-page body,
body.elementor-page {
  font-family: 'Outfit', sans-serif;
  color: var(--adv-text);
  background: var(--adv-white);
  -webkit-font-smoothing: antialiased;
}

/* Remove margens padrão do Hello Elementor no header/footer */
.elementor-location-header,
.elementor-location-footer {
  margin: 0 !important;
  padding: 0 !important;
}

/* ============================================================
   TIPOGRAFIA GLOBAL
   ============================================================ */
.elementor-widget-heading .elementor-heading-title {
  font-family: 'Cormorant Garamond', serif !important;
  line-height: 1.15 !important;
}

.elementor-widget-text-editor,
.elementor-widget-text-editor p {
  font-family: 'Outfit', sans-serif;
  line-height: 1.65;
}

/* ============================================================
   EYEBROW — RÓTULO ACIMA DOS TÍTULOS
   Uso: Heading com classe CSS "adv-eyebrow"
   ============================================================ */
.adv-eyebrow .elementor-heading-title,
.elementor-element.adv-eyebrow .elementor-heading-title {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--adv-gold) !important;
}

/* ============================================================
   BOTÕES GLOBAIS
   ============================================================ */
.adv-btn-primary .elementor-button,
.elementor-element.adv-btn-primary .elementor-button {
  background: var(--adv-gold) !important;
  color: #fff !important;
  border: 2px solid var(--adv-gold) !important;
  font-family: 'Outfit', sans-serif !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
  border-radius: var(--adv-radius) !important;
  padding: 14px 32px !important;
  transition: var(--adv-transition) !important;
}
.adv-btn-primary .elementor-button:hover {
  background: var(--adv-gold-light) !important;
  border-color: var(--adv-gold-light) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(201,149,42,0.35) !important;
}

.adv-btn-outline .elementor-button,
.elementor-element.adv-btn-outline .elementor-button {
  background: transparent !important;
  color: var(--adv-gold) !important;
  border: 2px solid var(--adv-gold) !important;
  font-family: 'Outfit', sans-serif !important;
  font-weight: 500 !important;
  border-radius: var(--adv-radius) !important;
  padding: 14px 32px !important;
  transition: var(--adv-transition) !important;
}
.adv-btn-outline .elementor-button:hover {
  background: var(--adv-gold) !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
}

.adv-btn-outline-light .elementor-button,
.elementor-element.adv-btn-outline-light .elementor-button {
  background: transparent !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,0.4) !important;
  font-family: 'Outfit', sans-serif !important;
  border-radius: var(--adv-radius) !important;
  padding: 14px 32px !important;
  transition: var(--adv-transition) !important;
}
.adv-btn-outline-light .elementor-button:hover {
  background: rgba(255,255,255,0.1) !important;
  border-color: rgba(255,255,255,0.7) !important;
}

.adv-btn-whatsapp .elementor-button,
.elementor-element.adv-btn-whatsapp .elementor-button {
  background: #25D366 !important;
  color: #fff !important;
  border: 2px solid #25D366 !important;
  font-family: 'Outfit', sans-serif !important;
  font-weight: 500 !important;
  border-radius: var(--adv-radius) !important;
  padding: 14px 32px !important;
  transition: var(--adv-transition) !important;
}
.adv-btn-whatsapp .elementor-button:hover {
  background: #20b858 !important;
  box-shadow: 0 8px 24px rgba(37,211,102,0.35) !important;
  transform: translateY(-2px) !important;
}

/* ============================================================
   SEÇÕES — BACKGROUNDS
   ============================================================ */
/* Seção escura (hero, casos de sucesso) */
.adv-section-dark {
  background-color: var(--adv-dark) !important;
}

/* Seção off-white (áreas, sobre, blog) */
.adv-section-light {
  background-color: var(--adv-light) !important;
}

/* Seção branca (contato, faq) */
.adv-section-white {
  background-color: var(--adv-white) !important;
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.adv-hero {
  background-color: var(--adv-dark) !important;
  min-height: 90vh !important;
  position: relative !important;
  overflow: hidden !important;
}
.adv-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 10% 20%, rgba(201,149,42,0.06) 0%, transparent 50%),
    radial-gradient(circle at 90% 80%, rgba(201,149,42,0.04) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
}

.adv-hero-title .elementor-heading-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(2.4rem, 5vw, 3.8rem) !important;
  font-weight: 600 !important;
  line-height: 1.1 !important;
  color: #FFFFFF !important;
}

.adv-hero-eyebrow .elementor-heading-title {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--adv-gold) !important;
}

/* Texto em dourado itálico dentro do hero title */
.adv-hero-title em,
.adv-hero-title .adv-accent {
  color: var(--adv-gold);
  font-style: italic;
}

/* ============================================================
   STATS BAR (contadores)
   ============================================================ */
.adv-stats-bar {
  background-color: var(--adv-dark-3) !important;
  border-top: 1px solid var(--adv-border-dark) !important;
}

.adv-stat-number .elementor-counter-number-wrapper {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 2.8rem !important;
  font-weight: 700 !important;
  color: var(--adv-gold) !important;
  line-height: 1 !important;
}
.adv-stat-number .elementor-counter-number-suffix {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 2rem !important;
  color: var(--adv-gold) !important;
}
.adv-stat-number .elementor-counter-title {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.8rem !important;
  font-weight: 400 !important;
  color: rgba(255,255,255,0.45) !important;
  letter-spacing: 0.04em !important;
  margin-top: 4px !important;
}

/* ============================================================
   BADGE (ícone + texto no hero)
   ============================================================ */
.adv-badge-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
}
.adv-badge-wrap .elementor-icon {
  color: var(--adv-gold) !important;
}
.adv-badge-text {
  font-size: 0.8rem !important;
  color: rgba(255,255,255,0.65) !important;
  line-height: 1.3 !important;
}

/* ============================================================
   ÁREA CARD
   ============================================================ */
.adv-area-card {
  background: var(--adv-white) !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  border-radius: var(--adv-radius-lg) !important;
  padding: 32px 28px !important;
  transition: border-color var(--adv-transition), box-shadow var(--adv-transition), transform var(--adv-transition) !important;
  position: relative !important;
  overflow: hidden !important;
}
.adv-area-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--adv-gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--adv-transition);
}
.adv-area-card:hover::before { transform: scaleX(1); }
.adv-area-card:hover {
  border-color: var(--adv-border) !important;
  box-shadow: var(--adv-shadow-lg) !important;
  transform: translateY(-4px) !important;
}

.adv-area-card .elementor-icon-box-icon {
  background: var(--adv-gold-dim) !important;
  border-radius: 12px !important;
  padding: 13px !important;
  width: 52px !important;
  height: 52px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 18px !important;
}
.adv-area-card .elementor-icon-box-icon .elementor-icon {
  color: var(--adv-gold) !important;
  font-size: 1.4rem !important;
}
.adv-area-card .elementor-icon-box-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.3rem !important;
  font-weight: 600 !important;
  color: var(--adv-text) !important;
  margin-bottom: 14px !important;
}
.adv-area-card .elementor-icon-box-description {
  font-size: 0.875rem !important;
  color: var(--adv-muted) !important;
  line-height: 1.7 !important;
}

/* ============================================================
   CASO CARD (dark)
   ============================================================ */
.adv-caso-card {
  background: var(--adv-dark-3) !important;
  border: 1px solid var(--adv-border-dark) !important;
  border-radius: var(--adv-radius-lg) !important;
  padding: 32px 28px !important;
  transition: border-color var(--adv-transition), transform var(--adv-transition) !important;
}
.adv-caso-card:hover {
  border-color: rgba(201,149,42,0.3) !important;
  transform: translateY(-4px) !important;
}
.adv-caso-card .elementor-icon-box-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.25rem !important;
  color: #fff !important;
  margin-bottom: 10px !important;
}
.adv-caso-card .elementor-icon-box-description {
  font-size: 0.875rem !important;
  color: rgba(255,255,255,0.5) !important;
  line-height: 1.65 !important;
}
.adv-caso-card .elementor-icon-box-icon .elementor-icon {
  color: var(--adv-gold) !important;
}

/* ============================================================
   TESTIMONIAL / DEPOIMENTO
   ============================================================ */
.adv-depoimento .elementor-testimonial-content {
  font-size: 0.87rem !important;
  color: rgba(255,255,255,0.6) !important;
  font-style: italic !important;
  line-height: 1.55 !important;
  font-family: 'Outfit', sans-serif !important;
}
.adv-depoimento .elementor-testimonial-name {
  font-size: 0.78rem !important;
  color: rgba(255,255,255,0.35) !important;
  font-style: normal !important;
}
.adv-depoimento .elementor-testimonial-job {
  display: none !important;
}

/* ============================================================
   CREDENTIAL ITEM
   ============================================================ */
.adv-credential {
  background: var(--adv-white) !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  border-radius: var(--adv-radius) !important;
  padding: 16px !important;
  transition: border-color var(--adv-transition) !important;
}
.adv-credential:hover {
  border-color: var(--adv-border) !important;
}
.adv-credential .elementor-icon-box-icon {
  background: var(--adv-gold-dim) !important;
  border-radius: 8px !important;
  padding: 10px !important;
  width: 40px !important;
  height: 40px !important;
  flex-shrink: 0 !important;
}
.adv-credential .elementor-icon-box-icon .elementor-icon {
  color: var(--adv-gold) !important;
  font-size: 1.1rem !important;
}
.adv-credential .elementor-icon-box-title {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  color: var(--adv-text) !important;
}
.adv-credential .elementor-icon-box-description {
  font-size: 0.78rem !important;
  color: var(--adv-muted) !important;
  line-height: 1.4 !important;
}

/* ============================================================
   DIVIDER DOURADO
   ============================================================ */
.adv-divider-gold .elementor-divider-separator {
  border-top-color: var(--adv-gold) !important;
  border-top-width: 2px !important;
  width: 60px !important;
}

/* ============================================================
   TÍTULO DE SEÇÃO COM LINHA DOURADA
   ============================================================ */
.adv-section-title {
  position: relative;
  padding-bottom: 18px;
}
.adv-section-title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 2px;
  background: var(--adv-gold);
}
.adv-section-title-left::after {
  left: 0;
  transform: none;
}

/* ============================================================
   FAQ / ACCORDION (widget Toggle do Elementor Free)
   ============================================================ */
.adv-faq .elementor-tab-title {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  color: var(--adv-text) !important;
  background: var(--adv-light) !important;
  border: 1.5px solid rgba(0,0,0,0.07) !important;
  border-radius: var(--adv-radius) !important;
  padding: 16px 20px !important;
  margin-bottom: 8px !important;
  transition: color var(--adv-transition), border-color var(--adv-transition) !important;
}
.adv-faq .elementor-tab-title:hover,
.adv-faq .elementor-tab-title.elementor-active {
  color: var(--adv-gold) !important;
  border-color: var(--adv-gold) !important;
}
.adv-faq .elementor-tab-title .elementor-toggle-icon {
  color: var(--adv-gold) !important;
}
.adv-faq .elementor-tab-content {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.875rem !important;
  color: var(--adv-muted) !important;
  line-height: 1.65 !important;
  background: var(--adv-light) !important;
  border: 1.5px solid var(--adv-gold) !important;
  border-top: none !important;
  border-radius: 0 0 var(--adv-radius) var(--adv-radius) !important;
  padding: 16px 20px !important;
  margin-bottom: 8px !important;
}

/* ============================================================
   FORMULÁRIO (widget Form do Elementor Free)
   ============================================================ */
.adv-form .elementor-field-group label {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  color: var(--adv-text) !important;
  margin-bottom: 6px !important;
}
.adv-form .elementor-field {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.9rem !important;
  background: var(--adv-light) !important;
  border: 1.5px solid rgba(0,0,0,0.1) !important;
  border-radius: var(--adv-radius) !important;
  color: var(--adv-text) !important;
  padding: 12px 16px !important;
  transition: border-color var(--adv-transition), box-shadow var(--adv-transition) !important;
}
.adv-form .elementor-field:focus {
  border-color: var(--adv-gold) !important;
  box-shadow: 0 0 0 3px rgba(201,149,42,0.12) !important;
  outline: none !important;
}
.adv-form .elementor-button {
  background: var(--adv-gold) !important;
  color: #fff !important;
  border: none !important;
  font-family: 'Outfit', sans-serif !important;
  font-weight: 500 !important;
  border-radius: var(--adv-radius) !important;
  padding: 14px 32px !important;
  width: 100% !important;
  transition: var(--adv-transition) !important;
}
.adv-form .elementor-button:hover {
  background: var(--adv-gold-light) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(201,149,42,0.35) !important;
}
.adv-form .elementor-message {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.85rem !important;
  padding: 12px 16px !important;
  border-radius: var(--adv-radius) !important;
}
.adv-form .elementor-message.elementor-message-success {
  background: #f0fdf4 !important;
  color: #166534 !important;
  border: 1.5px solid #86efac !important;
}

/* ============================================================
   CONTACT ICON LIST (info de contato)
   ============================================================ */
.adv-contact-list .elementor-icon-list-item {
  padding: 14px 0 !important;
  border-bottom: 1px solid rgba(0,0,0,0.05) !important;
  gap: 16px !important;
  align-items: flex-start !important;
}
.adv-contact-list .elementor-icon-list-item:last-child {
  border-bottom: none !important;
}
.adv-contact-list .elementor-icon-list-icon {
  background: var(--adv-gold-dim) !important;
  border-radius: 10px !important;
  padding: 10px !important;
  width: 40px !important;
  height: 40px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
.adv-contact-list .elementor-icon-list-icon i,
.adv-contact-list .elementor-icon-list-icon svg {
  color: var(--adv-gold) !important;
  font-size: 1rem !important;
}
.adv-contact-list .elementor-icon-list-text {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.875rem !important;
  color: var(--adv-muted) !important;
  line-height: 1.5 !important;
}
.adv-contact-list .elementor-icon-list-text a {
  color: var(--adv-muted) !important;
  transition: color var(--adv-transition) !important;
}
.adv-contact-list .elementor-icon-list-text a:hover {
  color: var(--adv-gold) !important;
}

/* ============================================================
   BLOG CARD (Posts widget Elementor Free)
   ============================================================ */
.adv-blog .elementor-post {
  background: var(--adv-white) !important;
  border-radius: var(--adv-radius-lg) !important;
  overflow: hidden !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  transition: box-shadow var(--adv-transition), transform var(--adv-transition) !important;
}
.adv-blog .elementor-post:hover {
  box-shadow: var(--adv-shadow-lg) !important;
  transform: translateY(-4px) !important;
}
.adv-blog .elementor-post__thumbnail__link img {
  transition: transform 0.5s ease !important;
}
.adv-blog .elementor-post:hover .elementor-post__thumbnail__link img {
  transform: scale(1.04) !important;
}
.adv-blog .elementor-post__text {
  padding: 24px 24px 28px !important;
}
.adv-blog .elementor-post__title a {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.2rem !important;
  font-weight: 600 !important;
  color: var(--adv-text) !important;
  line-height: 1.3 !important;
  transition: color var(--adv-transition) !important;
}
.adv-blog .elementor-post__title a:hover {
  color: var(--adv-gold) !important;
}
.adv-blog .elementor-post-date {
  font-size: 0.78rem !important;
  color: #aaa !important;
  margin-bottom: 10px !important;
}
.adv-blog .elementor-post__excerpt p {
  font-size: 0.875rem !important;
  color: var(--adv-muted) !important;
}
.adv-blog .elementor-post__read-more {
  font-size: 0.83rem !important;
  font-weight: 600 !important;
  color: var(--adv-gold) !important;
  transition: letter-spacing var(--adv-transition) !important;
}
.adv-blog .elementor-post__read-more:hover {
  letter-spacing: 0.05em !important;
  color: var(--adv-gold) !important;
}

/* Categoria tag */
.adv-blog .elementor-post__badge {
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--adv-gold) !important;
  background: var(--adv-gold-dim) !important;
  padding: 4px 10px !important;
  border-radius: 4px !important;
}

/* ============================================================
   PHOTO FRAME (imagem com decoração)
   ============================================================ */
.adv-photo-frame {
  position: relative !important;
}
.adv-photo-frame .elementor-widget-container {
  position: relative !important;
}
.adv-photo-frame img {
  border-radius: var(--adv-radius-lg) !important;
  box-shadow: var(--adv-shadow-lg) !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
}
.adv-photo-frame::after {
  content: '';
  position: absolute;
  bottom: -16px;
  right: -16px;
  width: 120px;
  height: 120px;
  border-radius: 12px;
  border: 3px solid var(--adv-gold);
  opacity: 0.25;
  z-index: -1;
  pointer-events: none;
}

/* ============================================================
   FOOTER CUSTOM
   ============================================================ */
.adv-footer {
  background: var(--adv-dark) !important;
}
.adv-footer .elementor-heading-title {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.4) !important;
  margin-bottom: 16px !important;
}
.adv-footer .elementor-icon-list-text {
  font-size: 0.875rem !important;
  color: rgba(255,255,255,0.55) !important;
  font-family: 'Outfit', sans-serif !important;
}
.adv-footer .elementor-icon-list-text a {
  color: rgba(255,255,255,0.55) !important;
  transition: color var(--adv-transition) !important;
}
.adv-footer .elementor-icon-list-text a:hover {
  color: var(--adv-gold) !important;
}
.adv-footer .elementor-icon-list-icon i,
.adv-footer .elementor-icon-list-icon svg {
  color: var(--adv-gold) !important;
}
.adv-footer-tagline {
  font-size: 0.82rem !important;
  color: rgba(255,255,255,0.4) !important;
  line-height: 1.6 !important;
}
.adv-footer-bottom {
  background: var(--adv-dark) !important;
  border-top: 1px solid var(--adv-border-dark) !important;
  padding: 20px 0 !important;
}
.adv-footer-bottom .elementor-text-editor,
.adv-footer-bottom .elementor-text-editor p {
  font-size: 0.78rem !important;
  color: rgba(255,255,255,0.3) !important;
}
.adv-footer-bottom .elementor-text-editor a {
  color: rgba(255,255,255,0.4) !important;
  transition: color var(--adv-transition) !important;
}
.adv-footer-bottom .elementor-text-editor a:hover {
  color: var(--adv-gold) !important;
}

/* ============================================================
   SOCIAL ICONS (footer)
   ============================================================ */
.adv-social .elementor-social-icon {
  background: var(--adv-dark-4) !important;
  border: 1px solid var(--adv-border-dark) !important;
  border-radius: 8px !important;
  width: 36px !important;
  height: 36px !important;
  transition: color var(--adv-transition), background var(--adv-transition) !important;
}
.adv-social .elementor-social-icon:hover {
  background: var(--adv-gold-dim) !important;
  border-color: var(--adv-border) !important;
}
.adv-social .elementor-social-icon i {
  color: rgba(255,255,255,0.5) !important;
  font-size: 0.9rem !important;
}
.adv-social .elementor-social-icon:hover i {
  color: var(--adv-gold) !important;
}

/* ============================================================
   HEADER ELEMENTOR (nav customizada)
   ============================================================ */
.adv-header {
  background: rgba(13,13,13,0.96) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  transition: box-shadow var(--adv-transition) !important;
}
.adv-header.sticky-applied,
.adv-header.elementor-sticky--active {
  box-shadow: 0 4px 32px rgba(0,0,0,0.5) !important;
}

/* Logo no header */
.adv-logo-monogram {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 44px !important;
  height: 44px !important;
  background: var(--adv-gold) !important;
  color: #fff !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.3rem !important;
  font-weight: 600 !important;
  border-radius: 4px !important;
}

/* Nav links */
.adv-nav .elementor-nav-menu a,
.adv-nav .elementor-nav-menu--main .elementor-item {
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 400 !important;
  color: rgba(255,255,255,0.75) !important;
  transition: color var(--adv-transition) !important;
  padding: 8px 12px !important;
}
.adv-nav .elementor-nav-menu a:hover,
.adv-nav .elementor-nav-menu--main .elementor-item:hover,
.adv-nav .elementor-nav-menu--main .elementor-item.elementor-item-active {
  color: var(--adv-gold) !important;
}
/* Remove underline padrão do Elementor nav */
.adv-nav .elementor-nav-menu--main .elementor-item:after {
  display: none !important;
}

/* ============================================================
   WHATSAPP FLOAT — injetado via JS/HTML Widget
   ============================================================ */
.adv-whatsapp-float {
  position: fixed !important;
  bottom: 28px !important;
  right: 28px !important;
  z-index: 9999 !important;
  width: 56px !important;
  height: 56px !important;
  background: #25D366 !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 4px 20px rgba(37,211,102,0.45) !important;
  transition: transform var(--adv-transition), box-shadow var(--adv-transition) !important;
  text-decoration: none !important;
}
.adv-whatsapp-float:hover {
  transform: scale(1.08) translateY(-2px) !important;
  box-shadow: 0 8px 32px rgba(37,211,102,0.6) !important;
}
.adv-whatsapp-float svg {
  width: 28px;
  height: 28px;
  fill: #fff;
}
.adv-whatsapp-float__tooltip {
  position: absolute;
  right: calc(100% + 12px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--adv-dark-3);
  color: #fff;
  font-family: 'Outfit', sans-serif;
  font-size: 0.78rem;
  font-weight: 500;
  padding: 6px 12px;
  border-radius: 6px;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--adv-transition);
}
.adv-whatsapp-float:hover .adv-whatsapp-float__tooltip { opacity: 1; }
.adv-whatsapp-float__tooltip::after {
  content: '';
  position: absolute;
  left: 100%; top: 50%;
  transform: translateY(-50%);
  border: 6px solid transparent;
  border-left-color: var(--adv-dark-3);
}

/* ============================================================
   SCROLL REVEAL (classes aplicadas via JS)
   ============================================================ */
.adv-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.adv-reveal.adv-revealed {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   RESPONSIVIDADE ELEMENTOR — AJUSTES FINOS
   ============================================================ */
@media (max-width: 767px) {
  .adv-hero { min-height: auto !important; padding: 40px 0 !important; }
  .adv-hero-title .elementor-heading-title { font-size: 2.2rem !important; }
  .adv-stat-number .elementor-counter-number-wrapper { font-size: 2rem !important; }
  .adv-photo-frame::after { display: none; }
  .adv-area-card { padding: 24px 20px !important; }
  .adv-caso-card { padding: 24px 20px !important; }
  .adv-whatsapp-float { bottom: 20px !important; right: 20px !important; }
  .adv-whatsapp-float__tooltip { display: none !important; }
}

/* ============================================================
   ACESSIBILIDADE
   ============================================================ */
:focus-visible {
  outline: 2px solid var(--adv-gold);
  outline-offset: 3px;
  border-radius: 4px;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
  html { scroll-behavior: auto; }
  .adv-reveal { opacity: 1 !important; transform: none !important; }
}
