:root {
    --gold:       #B8963E;
    --gold-light: #D4AE60;
    --gold-pale:  #F5EDD8;
    --navy:       #23312d;
    --navy-mid:   #2f4942;
    --navy-light: #3a5a50;
    --gray-soft:  #F0EDE6;
    --gray-mid:   #5A5A58;
    --white:      #FAFAF8;
    --serif:      'Playfair Display', serif;
    --sans:       'DM Sans', sans-serif;
  }

  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body { font-family: var(--sans); color: #1A1A18; background: var(--white); -webkit-font-smoothing: antialiased; }
  .whatsapp-fixo {
position: fixed;
bottom:10px;
right:10px;
z-index: 999;
}

  
  .fw-300 { font-weight: 300; }
  .serif  { font-family: var(--serif); }
  .section-tag { font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
  .section-tag.light { color: var(--gold-light); }

  /* ── TOP BAR ── */
  .topbar { background: var(--navy-mid); border-bottom: 1px solid rgba(184,150,62,.15); font-size: .72rem; letter-spacing: .04em; color: rgba(255,255,255,.45); padding: .45rem 0; }
  .topbar a { color: rgba(255,255,255,.55); text-decoration: none; transition: color .2s; }
  .topbar a:hover { color: var(--gold-light); }
  .topbar .sep { margin: 0 .6rem; opacity: .25; }

  /* ── NAVBAR ── */
  .navbar { background: rgba(35,49,45,.97) !important; border-bottom: 1px solid rgba(184,150,62,.2); min-height: 80px; }
  .navbar-brand { font-family: var(--serif); color: var(--gold-light) !important; font-size: 1.35rem; line-height: 1.1; padding: .75rem 0; }
  .navbar-brand small { display: block; font-family: var(--sans); font-size: .62rem; font-weight: 300; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.45); margin-top: 1px; }
  .nav-link { color: rgba(255,255,255,.65) !important; font-size: .85rem; letter-spacing: .04em; padding-top: .65rem !important; padding-bottom: .65rem !important; }
  .nav-link:hover, .nav-link:focus, .nav-link.active { color: var(--gold-light) !important; }
  .nav-link.dropdown-toggle::after { border: none; content: '\F282'; font-family: 'bootstrap-icons'; font-size: .65rem; vertical-align: 1px; margin-left: .25rem; transition: transform .2s; }
  .nav-item.dropdown:hover .nav-link.dropdown-toggle::after,
  .nav-item.dropdown.show  .nav-link.dropdown-toggle::after { transform: rotate(180deg); }
  .dropdown-menu { background: var(--navy-mid); border: 1px solid rgba(184,150,62,.2); border-radius: 4px; padding: .5rem 0; min-width: 260px; margin-top: 0 !important; box-shadow: 0 12px 32px rgba(0,0,0,.35); }
  .dropdown-item { color: rgba(255,255,255,.62) !important; font-size: .82rem; font-weight: 300; padding: .55rem 1.25rem; display: flex; align-items: center; gap: .65rem; transition: background .15s, color .15s; }
  .dropdown-item:hover { background: rgba(184,150,62,.1) !important; color: var(--gold-light) !important; }
  .dropdown-item .di-icon { width: 26px; height: 26px; background: rgba(184,150,62,.12); border-radius: 3px; display: flex; align-items: center; justify-content: center; color: var(--gold-light); font-size: .78rem; flex-shrink: 0; }
  .dropdown-divider { border-color: rgba(184,150,62,.12); margin: .35rem 0; }
  .dropdown-header { font-size: .62rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.25) !important; padding: .5rem 1.25rem .25rem; }
  @media (min-width: 992px) { .nav-item.dropdown:hover > .dropdown-menu { display: block; } }
  .btn-nav-cta { background: var(--gold); color: var(--navy) !important; font-size: .78rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; border-radius: 3px; padding: .55rem 1.3rem; border: none; transition: background .2s; text-decoration: none; }
  .btn-nav-cta:hover { background: var(--gold-light); color: var(--navy) !important; }
  .navbar-toggler { border-color: rgba(184,150,62,.4); }
  .navbar-toggler-icon { filter: invert(1) sepia(1) saturate(2) hue-rotate(5deg); }

  /* ── PAGE HERO ── */
  .page-hero {
    background-color: var(--navy);
    background-image:
      repeating-linear-gradient(0deg, transparent, transparent 59px, rgba(184,150,62,.04) 60px),
      repeating-linear-gradient(90deg, transparent, transparent 59px, rgba(184,150,62,.04) 60px);
    padding: 7rem 0 5rem;
    position: relative; overflow: hidden;
    margin-top: calc(29px + 80px);
  }
  .page-hero::before { content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 4px; height: 160px; background: var(--gold); }
  .page-hero::after  { content: ''; position: absolute; right: -60px; top: 50%; transform: translateY(-50%); width: 500px; height: 500px; border-radius: 50%; background: radial-gradient(circle, rgba(184,150,62,.07) 0%, transparent 70%); pointer-events: none; }
  .breadcrumb-nav { display: flex; align-items: center; gap: .5rem; font-size: .72rem; color: rgba(255,255,255,.3); letter-spacing: .05em; text-transform: uppercase; margin-bottom: 1.5rem; }
  .breadcrumb-nav a { color: rgba(255,255,255,.45); text-decoration: none; transition: color .2s; }
  .breadcrumb-nav a:hover { color: var(--gold-light); }
  .breadcrumb-nav i { font-size: .55rem; }
  .page-hero h1 { font-family: var(--serif); font-size: clamp(2.4rem, 4.5vw, 3.8rem); font-weight: 600; color: #fff; line-height: 1.12; margin-bottom: 1.25rem; }
  .page-hero h1 em { font-style: italic; color: var(--gold-light); }
  .page-hero .hero-lead { color: rgba(255,255,255,.55); font-weight: 300; font-size: 1.05rem; line-height: 1.8; max-width: 560px; }

  /* números no hero */
  .hero-numbers { display: flex; flex-wrap: wrap; gap: 1px; margin-top: 3rem; background: rgba(184,150,62,.15); border-radius: 4px; overflow: hidden; }
  .hero-num-item { background: rgba(255,255,255,.03); padding: 1.25rem 2rem; flex: 1; min-width: 120px; border-right: 1px solid rgba(184,150,62,.15); }
  .hero-num-item:last-child { border-right: none; }
  .hero-num-val { font-family: var(--serif); font-size: 2.2rem; font-weight: 700; color: var(--gold-light); line-height: 1; }
  .hero-num-label { font-size: .65rem; text-transform: uppercase; letter-spacing: .12em; color: rgba(255,255,255,.4); margin-top: .3rem; }

  /* ── SEÇÃO MISSÃO ── */
  .sobre-missao { background: var(--white); padding: 5rem 0; }
  .missao-text { font-size: 1.05rem; color: #2a2a28; font-weight: 300; line-height: 1.9; margin-bottom: 1.5rem; }
  .missao-text strong { font-weight: 600; color: var(--navy); }
  .missao-pilares { display: flex; flex-direction: column; gap: 1px; background: rgba(0,0,0,.07); border-radius: 4px; overflow: hidden; margin-top: 2.5rem; }
  .pilar-row { background: var(--white); padding: 1.25rem 1.5rem; display: flex; align-items: flex-start; gap: 1rem; transition: background .2s; }
  .pilar-row:hover { background: var(--gold-pale); }
  .pilar-icon { width: 40px; height: 40px; background: var(--gold-pale); border-radius: 3px; display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 1rem; flex-shrink: 0; }
  .pilar-row h4 { font-size: .9rem; font-weight: 600; color: var(--navy); margin-bottom: .2rem; }
  .pilar-row p  { font-size: .8rem; color: var(--gray-mid); font-weight: 300; line-height: 1.55; margin: 0; }

  /* ── SEÇÃO CEO ── */
  .ceo-section { background: var(--navy); padding: 5rem 0; position: relative; overflow: hidden; }
  .ceo-section::after { content: ''; position: absolute; left: -80px; bottom: -80px; width: 400px; height: 400px; border-radius: 50%; border: 1px solid rgba(184,150,62,.1); pointer-events: none; }

  /* foto do CEO com moldura dourada */
  .ceo-photo-wrap {
    position: relative;
    display: inline-block;
  }
  .ceo-photo {
    width: 100%;
    max-width: 400px;
    border-radius: 4px;
    display: block;
    filter: grayscale(15%);
    position: relative; z-index: 1;
  }
  /* moldura decorativa */
  .ceo-photo-wrap::before {
    content: '';
    position: absolute;
    top: -12px; right: -12px;
    width: 100%; height: 100%;
    border: 2px solid var(--gold);
    border-radius: 4px;
    z-index: 0;
    opacity: .4;
  }
  /* badge de anos */
  .ceo-years-badge {
    position: absolute;
    bottom: -16px; left: -16px;
    background: var(--gold);
    color: var(--navy);
    border-radius: 4px;
    padding: 1rem 1.25rem;
    z-index: 2;
    text-align: center;
    line-height: 1;
    box-shadow: 0 8px 24px rgba(0,0,0,.3);
  }
  .ceo-years-badge .num { font-family: var(--serif); font-size: 2.2rem; font-weight: 700; display: block; }
  .ceo-years-badge .txt { font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; margin-top: .2rem; display: block; }

  .ceo-name { font-family: var(--serif); font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 600; color: #fff; line-height: 1.15; margin-bottom: .4rem; }
  .ceo-title { font-size: .72rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--gold-light); margin-bottom: 1.5rem; }
  .ceo-bio { font-size: .97rem; color: rgba(255,255,255,.6); font-weight: 300; line-height: 1.85; margin-bottom: 1.5rem; }
  .ceo-bio strong { color: rgba(255,255,255,.85); font-weight: 500; }

  /* conquistas do CEO */
  .ceo-achievements { display: flex; flex-direction: column; gap: .5rem; margin-top: 1.75rem; }
  .achievement-row {
    display: flex; align-items: center; gap: .85rem;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(184,150,62,.15);
    border-radius: 3px; padding: .75rem 1rem;
    transition: border-color .2s;
  }
  .achievement-row:hover { border-color: rgba(184,150,62,.4); }
  .ach-icon { width: 30px; height: 30px; background: rgba(184,150,62,.12); border-radius: 3px; display: flex; align-items: center; justify-content: center; color: var(--gold-light); font-size: .8rem; flex-shrink: 0; }
  .achievement-row span { font-size: .82rem; color: rgba(255,255,255,.65); font-weight: 300; line-height: 1.4; }

  /* ── HISTÓRIA / TIMELINE ── */
  .historia { background: var(--gray-soft); padding: 5rem 0; }
  .timeline { position: relative; padding-left: 2rem; }
  .timeline::before { content: ''; position: absolute; left: 7px; top: 8px; bottom: 8px; width: 2px; background: linear-gradient(to bottom, var(--gold), rgba(184,150,62,.15)); }
  .tl-item { position: relative; padding: 0 0 2.5rem 2rem; }
  .tl-item:last-child { padding-bottom: 0; }
  .tl-dot {
    position: absolute; left: -2rem; top: 4px;
    width: 16px; height: 16px; border-radius: 50%;
    background: var(--white); border: 2px solid var(--gold);
    display: flex; align-items: center; justify-content: center;
  }
  .tl-dot::after { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--gold); display: block; }
  .tl-year { font-family: var(--serif); font-size: 1.1rem; font-weight: 600; color: var(--gold); margin-bottom: .3rem; }
  .tl-title { font-size: .95rem; font-weight: 600; color: var(--navy); margin-bottom: .35rem; line-height: 1.3; }
  .tl-desc { font-size: .82rem; color: var(--gray-mid); font-weight: 300; line-height: 1.65; margin: 0; }

  /* ── ESCRITÓRIOS ── */
  .escritorios { background: var(--navy); padding: 5rem 0; }
  .esc-map-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1px;
    background: rgba(255,255,255,.06);
    border-radius: 4px; overflow: hidden;
    margin-top: 3rem;
  }
  .esc-card {
    background: var(--navy);
    padding: 1.75rem 1.5rem;
    transition: background .2s;
    position: relative;
  }
  .esc-card:hover { background: rgba(184,150,62,.07); }
  .esc-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--gold); opacity: 0; transition: opacity .2s; }
  .esc-card:hover::before { opacity: 1; }
  .esc-flag { font-size: .62rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--gold-light); margin-bottom: .5rem; display: flex; align-items: center; gap: .4rem; }
  .esc-flag i { font-size: .75rem; }
  .esc-city { font-family: var(--serif); font-size: 1.2rem; font-weight: 600; color: #fff; line-height: 1; margin-bottom: .25rem; }
  .esc-state { font-size: .72rem; color: rgba(255,255,255,.35); font-weight: 300; letter-spacing: .05em; }
  /* destaque para sede */
  .esc-card.sede { background: rgba(184,150,62,.08); border: 1px solid rgba(184,150,62,.2); }
  .esc-card.sede .esc-city { color: var(--gold-light); }
  .esc-sede-badge { font-size: .6rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; background: var(--gold); color: var(--navy); padding: .15rem .5rem; border-radius: 2px; margin-top: .5rem; display: inline-block; }

  /* EUA card especial */
  .esc-eua {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(184,150,62,.15);
    border-radius: 4px; padding: 1.75rem;
    margin-top: 1.5rem;
    display: flex; align-items: center; gap: 1.5rem;
    flex-wrap: wrap;
  }
  .esc-eua-icon { width: 52px; height: 52px; background: rgba(184,150,62,.1); border: 1px solid rgba(184,150,62,.25); border-radius: 3px; display: flex; align-items: center; justify-content: center; font-size: 1.4rem; flex-shrink: 0; }
  .esc-eua h4 { font-family: var(--serif); font-size: 1.05rem; font-weight: 600; color: #fff; margin-bottom: .2rem; }
  .esc-eua p  { font-size: .8rem; color: rgba(255,255,255,.45); font-weight: 300; margin: 0; line-height: 1.5; }

  /* ── ATUAÇÃO ── */
  .atuacao { background: var(--white); padding: 5rem 0; }
  .area-card {
    background: var(--gray-soft);
    border-radius: 4px; padding: 2rem;
    border-left: 3px solid var(--gold);
    height: 100%;
    transition: box-shadow .2s, transform .2s;
  }
  .area-card:hover { box-shadow: 0 8px 28px rgba(0,0,0,.07); transform: translateY(-2px); }
  .area-icon { width: 48px; height: 48px; background: var(--gold-pale); border-radius: 3px; display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 1.15rem; margin-bottom: 1rem; }
  .area-card h3 { font-family: var(--serif); font-size: 1.1rem; font-weight: 600; color: var(--navy); line-height: 1.3; margin-bottom: .5rem; }
  .area-card p  { font-size: .82rem; color: var(--gray-mid); font-weight: 300; line-height: 1.65; margin: 0; }

  /* ── DIFERENCIAIS ── */
  .diferenciais { background: var(--navy); padding: 5rem 0; }
  .dif-row {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 1px; background: rgba(255,255,255,.05);
    border-radius: 4px; overflow: hidden; margin-top: 3rem;
  }
  .dif-cell {
    background: var(--navy); padding: 2rem;
    transition: background .2s;
  }
  .dif-cell:hover { background: rgba(184,150,62,.06); }
  .dif-num { font-family: var(--serif); font-size: 2.8rem; font-weight: 700; color: rgba(184,150,62,.12); line-height: 1; margin-bottom: .5rem; }
  .dif-cell h4 { font-size: .95rem; font-weight: 600; color: rgba(255,255,255,.85); margin-bottom: .4rem; }
  .dif-cell p  { font-size: .82rem; color: rgba(255,255,255,.4); font-weight: 300; line-height: 1.65; margin: 0; }

  /* ── NOTA OFICIAL ── */
  .nota-section { background: var(--gray-soft); padding: 4rem 0; }
  .nota-card {
    background: var(--white);
    border: 1px solid rgba(0,0,0,.08);
    border-left: 4px solid var(--gold);
    border-radius: 0 4px 4px 0;
    padding: 2rem 2.5rem;
    display: flex; align-items: flex-start; gap: 1.5rem;
  }
  .nota-icon { width: 52px; height: 52px; background: var(--gold-pale); border-radius: 3px; display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 1.3rem; flex-shrink: 0; }
  .nota-card h4 { font-family: var(--serif); font-size: 1.1rem; font-weight: 600; color: var(--navy); margin-bottom: .4rem; }
  .nota-card p  { font-size: .85rem; color: var(--gray-mid); font-weight: 300; line-height: 1.7; margin-bottom: 1rem; }
  .btn-nota { display: inline-flex; align-items: center; gap: .45rem; font-size: .75rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--gold); text-decoration: none; transition: gap .2s; }
  .btn-nota:hover { gap: .7rem; }

  /* ── CTA FINAL ── */
  .cta-section { background: var(--navy); padding: 5rem 0; }
  .cta-inner {
    background: rgba(184,150,62,.06);
    border: 1px solid rgba(184,150,62,.25);
    border-radius: 5px; padding: 3rem;
    position: relative; overflow: hidden;
  }
  .cta-inner::after { content: ''; position: absolute; right: -60px; bottom: -60px; width: 300px; height: 300px; border-radius: 50%; border: 1px solid rgba(184,150,62,.1); pointer-events: none; }
  .cta-inner h2 { font-family: var(--serif); color: #fff; font-size: clamp(1.6rem, 2.5vw, 2.2rem); font-weight: 600; margin-bottom: .75rem; }
  .cta-inner p  { color: rgba(255,255,255,.5); font-size: .92rem; font-weight: 300; line-height: 1.75; margin-bottom: 2rem; max-width: 520px; }
  .btn-cta-wa { display: inline-flex; align-items: center; gap: .55rem; background: var(--gold); color: var(--navy); font-weight: 700; font-size: .85rem; letter-spacing: .08em; text-transform: uppercase; padding: .85rem 2rem; border-radius: 3px; text-decoration: none; transition: background .2s; }
  .btn-cta-wa:hover { background: var(--gold-light); color: var(--navy); }
  .btn-cta-ghost { display: inline-flex; align-items: center; gap: .55rem; background: transparent; color: rgba(255,255,255,.7); border: 1px solid rgba(255,255,255,.2); font-size: .85rem; letter-spacing: .06em; text-transform: uppercase; padding: .85rem 1.75rem; border-radius: 3px; text-decoration: none; transition: all .2s; }
  .btn-cta-ghost:hover { border-color: var(--gold-light); color: var(--gold-light); }

  /* ── FOOTER ── */
  footer { background: var(--navy); }
  footer h5 { font-size: .7rem; letter-spacing: .15em; text-transform: uppercase; color: var(--gold-light); font-weight: 600; }
  footer a  { color: rgba(255,255,255,.48); text-decoration: none; font-size: .85rem; font-weight: 300; transition: color .2s; }
  footer a:hover { color: var(--gold-light); }
  footer li { margin-bottom: .4rem; }
  .footer-brand-name { font-family: var(--serif); color: var(--gold-light); font-size: 1.2rem; }
  .footer-brand-name small { display: block; font-family: var(--sans); font-size: .62rem; letter-spacing: .15em; text-transform: uppercase; color: rgba(255,255,255,.4); font-weight: 300; }

  @media (max-width: 991px) {
    .page-hero::before { display: none; }
    .dif-row { grid-template-columns: 1fr; }
    .ceo-photo-wrap { margin-bottom: 3rem; }
  }
  @media (max-width: 767px) {
    .hero-numbers { flex-direction: column; }
    .hero-num-item { border-right: none; border-bottom: 1px solid rgba(184,150,62,.15); }
    .hero-num-item:last-child { border-bottom: none; }
  }