/*
Theme Name: Reginaldo Araújo - Child Theme
Theme URI: https://rmbg.adv.br
Description: Tema filho personalizado para Dr. Reginaldo Araújo - RMBG Advogados
Author: RMBG Advogados
Author URI: https://rmbg.adv.br
Template: hello-elementor
Version: 1.0.0
Text Domain: reginaldo-child
*/

/* ================================================
   VARIÁVEIS GLOBAIS
   ================================================ */
:root {
  --navy:        #0B1A2C;
  --navy-light:  #122238;
  --gold:        #B8962E;
  --gold-light:  #D4AF5A;
  --gold-pale:   #F5EDD6;
  --cream:       #FAF8F3;
  --white:       #FFFFFF;
  --gray-text:   #6B7280;
  --border:      rgba(184,150,46,0.2);
}

/* ================================================
   TIPOGRAFIA GLOBAL
   ================================================ */
body {
  font-family: 'Outfit', sans-serif !important;
  background-color: var(--cream) !important;
  color: var(--navy) !important;
}

h1, h2, h3, h4, h5, h6,
.elementor-heading-title {
  font-family: 'Cormorant Garamond', serif !important;
  color: var(--navy) !important;
}

/* ================================================
   NAVBAR / HEADER
   ================================================ */
.site-header,
#site-header,
.elementor-location-header {
  background-color: rgba(11, 26, 44, 0.97) !important;
  backdrop-filter: blur(12px) !important;
  border-bottom: 1px solid rgba(184,150,46,0.15) !important;
  position: fixed !important;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
}

.elementor-nav-menu a,
.elementor-nav-menu .menu-item a {
  color: rgba(255,255,255,0.75) !important;
  font-family: 'Outfit', sans-serif !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  letter-spacing: 0.5px !important;
  transition: color 0.25s !important;
}

.elementor-nav-menu a:hover,
.elementor-nav-menu .menu-item a:hover {
  color: var(--gold-light) !important;
}

/* Botão CTA no menu */
.menu-item-cta > a,
.nav-cta {
  background: var(--gold) !important;
  color: var(--navy) !important;
  padding: 9px 20px !important;
  border-radius: 3px !important;
  font-weight: 600 !important;
  transition: background 0.25s !important;
}

.menu-item-cta > a:hover {
  background: var(--gold-light) !important;
}

/* ================================================
   BOTÕES ELEMENTOR
   ================================================ */
.elementor-button.btn-primary,
.elementor-button-primary,
.e-btn-primary {
  background-color: var(--gold) !important;
  color: var(--navy) !important;
  border: none !important;
  border-radius: 3px !important;
  font-family: 'Outfit', sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  letter-spacing: 0.3px !important;
  padding: 14px 28px !important;
  transition: all 0.25s !important;
}

.elementor-button.btn-primary:hover,
.e-btn-primary:hover {
  background-color: var(--gold-light) !important;
  transform: translateY(-1px) !important;
}

.elementor-button.btn-outline,
.e-btn-outline {
  background-color: transparent !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
  color: rgba(255,255,255,0.8) !important;
  border-radius: 3px !important;
  font-family: 'Outfit', sans-serif !important;
  font-weight: 400 !important;
  font-size: 14px !important;
  padding: 14px 28px !important;
  transition: all 0.25s !important;
}

.elementor-button.btn-outline:hover {
  border-color: var(--gold) !important;
  color: var(--gold-light) !important;
}

/* ================================================
   SEÇÕES
   ================================================ */

/* Hero */
.section-hero {
  background-color: var(--navy) !important;
  min-height: 100vh !important;
}

/* Seções claras */
.section-light {
  background-color: var(--cream) !important;
}

.section-white {
  background-color: var(--white) !important;
}

/* Seções escuras */
.section-dark {
  background-color: var(--navy) !important;
}

/* ================================================
   BADGE / ETIQUETA DE SEÇÃO
   ================================================ */
.section-badge,
.elementor-widget .section-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(184,150,46,0.12);
  border: 1px solid rgba(184,150,46,0.3);
  padding: 7px 16px;
  border-radius: 2px;
  font-size: 11px;
  font-weight: 500;
  color: var(--gold-light);
  letter-spacing: 2px;
  text-transform: uppercase;
  font-family: 'Outfit', sans-serif;
}

/* Subtítulo de seção (tag acima do h2) */
.elementor-widget-text-editor .section-tag-text,
.section-tag-sm {
  font-size: 11px !important;
  font-weight: 500 !important;
  color: var(--gold) !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  font-family: 'Outfit', sans-serif !important;
  display: block !important;
  margin-bottom: 14px !important;
}

/* ================================================
   CARDS DE ÁREAS DE ATUAÇÃO
   ================================================ */
.area-card {
  background: var(--white);
  padding: 44px 36px;
  position: relative;
  overflow: hidden;
  transition: all 0.35s;
  border: 1px solid rgba(0,0,0,0.06);
}

.area-card:hover {
  background: var(--navy);
  border-color: var(--navy);
  transform: translateY(-4px);
  box-shadow: 0 20px 60px rgba(11,26,44,0.2);
}

.area-card .area-number {
  position: absolute;
  top: 24px;
  right: 28px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 56px;
  font-weight: 600;
  color: rgba(0,0,0,0.04);
  line-height: 1;
  transition: color 0.35s;
}

.area-card:hover .area-number { color: rgba(255,255,255,0.04); }

.area-card .area-icon {
  font-size: 28px;
  color: var(--gold);
  margin-bottom: 20px;
  display: block;
  transition: color 0.35s;
}

.area-card:hover .area-icon { color: var(--gold-light); }

.area-card h3 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 22px !important;
  font-weight: 600 !important;
  color: var(--navy) !important;
  margin-bottom: 14px !important;
  transition: color 0.35s;
}

.area-card:hover h3 { color: var(--white) !important; }

.area-card p {
  font-size: 14px;
  color: var(--gray-text);
  line-height: 1.8;
  margin-bottom: 28px;
  transition: color 0.35s;
}

.area-card:hover p { color: rgba(255,255,255,0.6); }

.area-card .area-link {
  font-size: 12px;
  font-weight: 500;
  color: var(--gold);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  text-decoration: none;
  transition: color 0.35s;
}

.area-card:hover .area-link { color: var(--gold-light); }

/* ================================================
   DEPOIMENTOS
   ================================================ */
.depo-card {
  background: var(--white);
  padding: 40px 36px;
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 4px;
  position: relative;
}

.depo-card::before {
  content: '"';
  font-family: 'Cormorant Garamond', serif;
  font-size: 80px;
  color: var(--gold);
  opacity: 0.3;
  position: absolute;
  top: 10px;
  left: 28px;
  line-height: 1;
}

/* ================================================
   BLOG / POSTS
   ================================================ */
.elementor-post__card,
.elementor-posts-container .elementor-post {
  border: 1px solid rgba(0,0,0,0.07) !important;
  border-radius: 4px !important;
  overflow: hidden !important;
  transition: transform 0.3s !important;
}

.elementor-post__card:hover,
.elementor-posts-container .elementor-post:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 40px rgba(11,26,44,0.1) !important;
}

.elementor-post__title a {
  font-family: 'Cormorant Garamond', serif !important;
  font-weight: 600 !important;
  color: var(--navy) !important;
  transition: color 0.25s !important;
}

.elementor-post__title a:hover {
  color: var(--gold) !important;
}

.elementor-post__excerpt p {
  font-family: 'Outfit', sans-serif !important;
  font-size: 13px !important;
  color: var(--gray-text) !important;
  line-height: 1.75 !important;
}

.elementor-post__badge {
  background: transparent !important;
  color: var(--gold) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
}

/* ================================================
   FORMULÁRIO DE CONTATO / LEADS
   ================================================ */
.elementor-form .elementor-field-group label,
.elementor-field-label {
  font-size: 11px !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,0.45) !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  font-family: 'Outfit', sans-serif !important;
  margin-bottom: 8px !important;
}

.elementor-form .elementor-field,
.elementor-field-textual {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 3px !important;
  color: var(--white) !important;
  font-family: 'Outfit', sans-serif !important;
  font-size: 14px !important;
  padding: 12px 16px !important;
  transition: border-color 0.25s !important;
}

.elementor-form .elementor-field:focus,
.elementor-field-textual:focus {
  border-color: var(--gold) !important;
  outline: none !important;
}

.elementor-form .elementor-button[type="submit"] {
  background-color: var(--gold) !important;
  color: var(--navy) !important;
  border: none !important;
  border-radius: 3px !important;
  font-family: 'Outfit', sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  width: 100% !important;
  padding: 15px !important;
  transition: background 0.25s !important;
}

.elementor-form .elementor-button[type="submit"]:hover {
  background-color: var(--gold-light) !important;
}

/* ================================================
   GALERIA DE FOTOS
   ================================================ */
.elementor-gallery-item__overlay {
  background: rgba(11,26,44,0.55) !important;
  transition: all 0.35s !important;
}

.elementor-gallery-item:hover .elementor-gallery-item__overlay {
  background: rgba(184,150,46,0.35) !important;
}

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

/* ================================================
   ESTATÍSTICAS / CONTADORES
   ================================================ */
.elementor-counter-number-wrapper,
.elementor-counter-number {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 48px !important;
  font-weight: 600 !important;
  color: var(--gold-light) !important;
  line-height: 1 !important;
}

.elementor-counter-title {
  font-family: 'Outfit', sans-serif !important;
  font-size: 11px !important;
  font-weight: 300 !important;
  color: rgba(255,255,255,0.45) !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
}

/* ================================================
   RODAPÉ
   ================================================ */
.site-footer,
.elementor-location-footer {
  background-color: #071018 !important;
}

.elementor-location-footer *,
.site-footer * {
  color: rgba(255,255,255,0.4);
}

.elementor-location-footer h4,
.elementor-location-footer .footer-title {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--white) !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  margin-bottom: 24px !important;
}

.elementor-location-footer a {
  color: rgba(255,255,255,0.4) !important;
  text-decoration: none !important;
  transition: color 0.25s !important;
  font-size: 13px !important;
}

.elementor-location-footer a:hover {
  color: var(--gold-light) !important;
}

/* ================================================
   BOTÃO FLUTUANTE WHATSAPP
   ================================================ */
.whatsapp-float {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 9999;
  width: 56px;
  height: 56px;
  background: #25D366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  box-shadow: 0 4px 20px rgba(37,211,102,0.35);
  transition: all 0.25s;
}

.whatsapp-float:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(37,211,102,0.45);
}

/* ================================================
   LANDING PAGE — DIREITO À VIDA
   ================================================ */
.lp-hero {
  background: var(--navy) !important;
  min-height: 100vh !important;
  position: relative;
}

.lp-urgency-bar {
  background: var(--gold) !important;
  color: var(--navy) !important;
  text-align: center !important;
  padding: 12px !important;
  font-family: 'Outfit', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px !important;
}

/* ================================================
   RESPONSIVO
   ================================================ */
@media (max-width: 768px) {
  .area-card { padding: 32px 24px; }
  .depo-card { padding: 32px 28px; }

  .elementor-counter-number {
    font-size: 36px !important;
  }
}

/* ================================================
   ANIMAÇÕES
   ================================================ */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

.animate-fade-up {
  animation: fadeUp 0.7s ease forwards;
}
