:root {
  --ink: #08111f;
  --ink-soft: #111d2e;
  --paper: #f3f1eb;
  --white: #fffdf8;
  --blue: #3348ff;
  --blue-light: #8290ff;
  --coral: #ff674d;
  --lime: #c7ff5b;
  --line: rgba(8, 17, 31, .15);
  --font-display: "Manrope", sans-serif;
  --font-body: "DM Sans", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--font-body); overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
em { color: var(--blue); font-style: normal; }

.site-header { height: 84px; padding: 0 clamp(24px, 4vw, 72px); display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 34px; background: rgba(243, 241, 235, .95); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 100; backdrop-filter: blur(16px); }
.brand { width: fit-content; display: flex; align-items: center; gap: 12px; font-family: var(--font-display); font-weight: 800; letter-spacing: -.04em; line-height: .84; }
.brand-mark { width: 42px; height: 42px; display: grid; place-items: center; background: var(--blue); color: white; font-size: 14px; letter-spacing: -.06em; border-radius: 50%; }
.brand-name { font-size: 15px; }
.main-nav { display: flex; gap: clamp(20px, 3vw, 48px); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; }
.main-nav a { position: relative; padding: 32px 0; }
.main-nav a::after { content: ""; height: 2px; width: 0; background: var(--blue); position: absolute; bottom: 23px; left: 0; transition: width .25s ease; }
.main-nav a:hover::after, .main-nav a.active::after { width: 100%; }
.header-cta { justify-self: end; background: var(--ink); color: white; padding: 17px 22px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; transition: .25s ease; }
.header-cta:hover { background: var(--blue); transform: translateY(-2px); }
.header-cta span { margin-left: 12px; }
.menu-toggle { display: none; background: none; border: 0; padding: 10px; }

.section-dark { color: white; background: var(--ink); }
.section-light { background: var(--paper); }
.hero { min-height: calc(100svh - 84px); position: relative; padding: clamp(80px, 10vw, 145px) clamp(24px, 5.6vw, 96px) 52px; display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(360px, .75fr); column-gap: clamp(70px, 9vw, 155px); overflow: hidden; background: radial-gradient(circle at 82% 15%, rgba(51,72,255,.22), transparent 28%), var(--ink); }
.hero-noise { position: absolute; inset: 0; opacity: .04; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.8'/%3E%3C/svg%3E"); pointer-events: none; }
.hero-orbit { position: absolute; border: 1px solid rgba(255,255,255,.11); border-radius: 50%; pointer-events: none; }
.orbit-one { width: 580px; height: 580px; right: -230px; top: -230px; }
.orbit-two { width: 410px; height: 410px; right: -145px; top: -145px; border-color: rgba(199,255,91,.23); }
.eyebrow { text-transform: uppercase; font-weight: 700; font-size: 11px; letter-spacing: .17em; display: flex; align-items: center; gap: 10px; }
.status { color: var(--lime); margin-bottom: 30px; }
.status span { display: block; width: 8px; height: 8px; background: var(--lime); border-radius: 50%; box-shadow: 0 0 0 5px rgba(199,255,91,.1); }
.hero h1 { font-family: var(--font-display); font-size: clamp(54px, 6.7vw, 108px); line-height: .93; letter-spacing: -.075em; margin: 0; max-width: 950px; }
.hero h1 em { color: var(--coral); }
.hero-copy > p { max-width: 660px; color: rgba(255,255,255,.66); line-height: 1.7; font-size: clamp(16px, 1.25vw, 20px); margin: 34px 0 38px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.button { padding: 18px 24px; min-height: 58px; display: inline-flex; align-items: center; gap: 28px; text-transform: uppercase; letter-spacing: .07em; font-size: 12px; font-weight: 700; border: 1px solid rgba(255,255,255,.3); transition: .25s ease; }
.button span { font-size: 17px; }
.button-primary { color: var(--ink); background: var(--lime); border-color: var(--lime); }
.button-primary:hover { background: white; border-color: white; transform: translateY(-3px); }
.button-ghost:hover { background: rgba(255,255,255,.08); transform: translateY(-3px); }
.registry-card { align-self: center; padding: 32px; border: 1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.06); backdrop-filter: blur(14px); box-shadow: 0 35px 80px rgba(0,0,0,.3); z-index: 1; }
.card-topline { display: flex; align-items: center; justify-content: space-between; padding-bottom: 28px; border-bottom: 1px solid rgba(255,255,255,.12); text-transform: uppercase; font-size: 10px; letter-spacing: .16em; color: rgba(255,255,255,.5); }
.card-topline strong { color: var(--lime); font-size: 10px; }
.cnpj-label { color: var(--coral); text-transform: uppercase; letter-spacing: .18em; font-size: 10px; font-weight: 700; margin-top: 30px; }
.cnpj { font-family: var(--font-display); font-size: clamp(20px, 2vw, 29px); font-weight: 700; letter-spacing: -.04em; margin: 10px 0 28px; }
.registry-card dl { margin: 0; }
.registry-card dl > div { padding: 18px 0; border-top: 1px solid rgba(255,255,255,.11); }
.registry-card .split { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.registry-card dt, .official-grid dt { color: rgba(255,255,255,.45); text-transform: uppercase; letter-spacing: .12em; font-size: 9px; margin-bottom: 7px; }
.registry-card dd { margin: 0; font-size: 14px; font-weight: 600; }
.hero-metrics { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; max-width: 780px; border-top: 1px solid rgba(255,255,255,.14); margin-top: 70px; padding-top: 28px; z-index: 1; }
.hero-metrics div { display: flex; flex-direction: column; gap: 6px; }
.hero-metrics strong { font-family: var(--font-display); color: var(--coral); font-size: clamp(25px, 2.5vw, 38px); letter-spacing: -.05em; }
.hero-metrics span { font-size: 9px; color: rgba(255,255,255,.5); text-transform: uppercase; letter-spacing: .12em; }
.scroll-note { align-self: end; justify-self: end; color: rgba(255,255,255,.4); font-size: 10px; text-transform: uppercase; letter-spacing: .15em; }
.scroll-note span { margin-left: 12px; }

.about, .governance { padding: clamp(90px, 10vw, 160px) clamp(24px, 5.6vw, 96px); display: grid; grid-template-columns: .55fr 1.1fr .9fr; gap: clamp(45px, 6vw, 110px); }
.section-index { font-size: 10px; letter-spacing: .16em; text-transform: uppercase; font-weight: 700; display: flex; gap: 12px; align-items: flex-start; padding-top: 10px; }
.section-index span { color: var(--blue); }
.section-index.inverted { color: rgba(255,255,255,.58); }
.section-index.inverted span { color: var(--lime); }
.about h2, .services h2, .governance h2, .official h2, .contact h2 { font-family: var(--font-display); font-size: clamp(43px, 5vw, 76px); letter-spacing: -.06em; line-height: 1.02; margin: 0 0 36px; }
.about-main .lead { font-family: var(--font-display); font-weight: 600; font-size: clamp(19px, 1.6vw, 25px); line-height: 1.45; letter-spacing: -.025em; }
.about-main p:not(.lead), .governance-heading p { color: #5c6470; font-size: 16px; line-height: 1.75; }
.about-facts { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; align-content: start; }
.about-facts article { min-height: 150px; border: 1px solid var(--line); padding: 24px; display: flex; flex-direction: column; justify-content: space-between; background: rgba(255,255,255,.25); }
.about-facts span, .about-facts small { color: #727986; font-size: 9px; text-transform: uppercase; letter-spacing: .11em; }
.about-facts strong { font-family: var(--font-display); font-size: 18px; letter-spacing: -.04em; }
.about-facts .accent-fact { grid-column: 1 / -1; background: var(--blue); color: white; border: 0; min-height: 180px; }
.about-facts .accent-fact strong { font-size: clamp(28px, 3vw, 42px); }
.about-facts .accent-fact span, .about-facts .accent-fact small { color: rgba(255,255,255,.6); }

.services { background: var(--blue); color: white; padding: clamp(90px, 10vw, 160px) clamp(24px, 5.6vw, 96px); display: grid; grid-template-columns: .78fr 1.22fr; gap: clamp(70px, 9vw, 150px); }
.services-heading .section-index { margin-bottom: 50px; }
.services h2 em { color: var(--lime); }
.services-heading > p { color: rgba(255,255,255,.65); line-height: 1.7; max-width: 460px; }
.service-list { border-top: 1px solid rgba(255,255,255,.27); }
.service-item { min-height: 230px; border-bottom: 1px solid rgba(255,255,255,.27); display: grid; grid-template-columns: 70px 1fr auto; gap: 30px; align-items: center; padding: 36px 8px; transition: background .3s ease, padding .3s ease; }
.service-item:hover { background: rgba(255,255,255,.08); padding-left: 25px; padding-right: 25px; }
.service-number { color: var(--lime); font-family: var(--font-display); font-size: 14px; }
.service-item small { color: rgba(255,255,255,.52); text-transform: uppercase; letter-spacing: .12em; font-size: 9px; }
.service-item h3 { margin: 12px 0 0; font-family: var(--font-display); font-size: clamp(25px, 2.5vw, 39px); line-height: 1.12; letter-spacing: -.045em; }
.service-item p { color: rgba(255,255,255,.55); margin: 12px 0 0; }
.service-arrow { width: 54px; height: 54px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.3); border-radius: 50%; font-size: 22px; }

.governance { grid-template-columns: .38fr .68fr 1.24fr; }
.governance h2 em { color: var(--coral); }
.people-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.person-card { background: var(--white); border: 1px solid var(--line); padding: 25px; min-height: 240px; display: flex; flex-direction: column; justify-content: space-between; position: relative; transition: .3s ease; }
.person-card:hover { transform: translateY(-5px); box-shadow: 0 20px 45px rgba(8,17,31,.08); }
.person-card.wide { grid-column: 1 / -1; min-height: 210px; }
.initials { width: 52px; height: 52px; border-radius: 50%; display: grid; place-items: center; background: var(--ink); color: white; font-family: var(--font-display); font-size: 11px; font-weight: 700; }
.person-card h3 { font-family: var(--font-display); font-size: 18px; letter-spacing: -.03em; margin: 0 35px 7px 0; }
.person-card p { margin: 0; color: var(--blue); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.person-card small { display: block; margin-top: 9px; color: #717986; }
.card-arrow { position: absolute; right: 25px; top: 25px; }
.responsible-note { grid-column: 2 / -1; margin: 0; border-top: 1px solid var(--line); padding-top: 24px; font-weight: 600; }
.responsible-note span { color: #757c87; font-size: 9px; text-transform: uppercase; letter-spacing: .13em; margin-right: 22px; }

.official { background: var(--ink-soft); color: white; padding: clamp(90px, 10vw, 160px) clamp(24px, 5.6vw, 96px); display: grid; grid-template-columns: .75fr 1.25fr; gap: clamp(70px, 9vw, 160px); }
.official-intro .section-index { margin-bottom: 50px; }
.official h2 em { color: var(--coral); }
.official-intro > p { color: rgba(255,255,255,.58); line-height: 1.7; max-width: 460px; }
.official-grid { display: grid; grid-template-columns: 1fr 1fr; margin: 0; border-top: 1px solid rgba(255,255,255,.16); }
.official-grid > div { min-height: 150px; padding: 33px 20px 25px 0; border-bottom: 1px solid rgba(255,255,255,.16); }
.official-grid > div:nth-child(odd) { border-right: 1px solid rgba(255,255,255,.16); }
.official-grid > div:nth-child(even) { padding-left: 32px; }
.official-grid dd { margin: 20px 0 0; font-family: var(--font-display); font-weight: 600; font-size: clamp(17px, 1.45vw, 22px); line-height: 1.35; letter-spacing: -.025em; }

.contact { padding: clamp(90px, 10vw, 160px) clamp(24px, 5.6vw, 96px); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(60px, 9vw, 160px); background: var(--lime); }
.contact h2 { font-size: clamp(48px, 6vw, 88px); margin-top: 58px; }
.contact h2 em { color: var(--blue); }
.contact-copy > p { color: #455027; }
.big-mail { display: flex; align-items: center; justify-content: space-between; gap: 20px; font-weight: 700; padding: 25px 0; border-bottom: 2px solid var(--ink); margin-top: 55px; overflow-wrap: anywhere; }
.big-mail span { font-size: 24px; }
.contact-cards { display: grid; grid-template-columns: 1.2fr .8fr; gap: 12px; align-content: end; }
.contact-card { background: var(--ink); color: white; min-height: 390px; padding: 30px; display: flex; flex-direction: column; transition: transform .3s ease; }
.contact-card:hover { transform: translateY(-6px); }
.contact-card small { color: rgba(255,255,255,.5); text-transform: uppercase; letter-spacing: .14em; font-size: 9px; margin: 70px 0 20px; }
.contact-card strong { font-family: var(--font-display); font-size: 19px; line-height: 1.6; }
.contact-card em { color: var(--lime); font-style: normal; font-size: 12px; margin-top: auto; }
.contact-icon { width: 48px; height: 48px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.25); border-radius: 50%; font-size: 22px; }
.contact-phone { background: var(--blue); }
.contact-phone strong { font-size: clamp(22px, 2vw, 31px); line-height: 1.2; }

footer { min-height: 180px; padding: 45px clamp(24px, 5.6vw, 96px); display: grid; grid-template-columns: 1fr 1fr 1fr; align-items: center; gap: 30px; background: var(--paper); border-top: 1px solid var(--line); font-size: 11px; line-height: 1.6; text-transform: uppercase; letter-spacing: .06em; }
.footer-right { text-align: right; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 1050px) {
  .main-nav { display: none; }
  .site-header { grid-template-columns: 1fr auto auto; }
  .menu-toggle { display: block; width: 42px; height: 42px; position: relative; z-index: 105; }
  .menu-toggle span { display: block; width: 23px; height: 2px; background: var(--ink); margin: 6px auto; transition: .25s ease; }
  .menu-toggle[aria-expanded="true"] span:first-child { transform: translateY(4px) rotate(45deg); }
  .menu-toggle[aria-expanded="true"] span:last-child { transform: translateY(-4px) rotate(-45deg); }
  .main-nav.open { display: flex; position: fixed; inset: 84px 0 auto; background: var(--paper); padding: 35px 24px; flex-direction: column; gap: 0; border-bottom: 1px solid var(--line); box-shadow: 0 20px 40px rgba(8,17,31,.12); }
  .main-nav.open a { padding: 15px 0; font-size: 14px; }
  .hero { grid-template-columns: 1fr .8fr; gap: 50px; }
  .about, .governance { grid-template-columns: 1fr 1fr; }
  .about .section-index, .governance .section-index { grid-column: 1 / -1; }
  .governance-heading { grid-column: 1; }
  .people-grid { grid-column: 2; }
  .contact { grid-template-columns: 1fr; }
  .contact-cards { max-width: 760px; }
}

@media (max-width: 760px) {
  .site-header { height: 72px; padding: 0 18px; gap: 10px; }
  .brand-mark { width: 38px; height: 38px; }
  .brand-name { font-size: 13px; }
  .header-cta { display: none; }
  .main-nav.open { inset: 72px 0 auto; }
  .hero { min-height: auto; padding: 78px 22px 45px; grid-template-columns: 1fr; gap: 55px; }
  .hero h1 { font-size: clamp(50px, 16vw, 72px); }
  .registry-card { padding: 25px; }
  .hero-metrics { margin-top: 5px; gap: 12px; }
  .hero-metrics strong { font-size: 24px; }
  .hero-metrics span { font-size: 8px; }
  .scroll-note { display: none; }
  .about, .governance, .services, .official, .contact { padding: 80px 22px; grid-template-columns: 1fr; gap: 48px; }
  .section-index { grid-column: 1 !important; }
  .about-main, .about-facts, .governance-heading, .people-grid, .responsible-note { grid-column: 1; }
  .about-facts { grid-template-columns: 1fr; }
  .about-facts .accent-fact { grid-column: 1; }
  .services-heading .section-index, .official-intro .section-index { margin-bottom: 35px; }
  .service-item { grid-template-columns: 42px 1fr; min-height: 190px; gap: 15px; }
  .service-arrow { display: none; }
  .people-grid { grid-template-columns: 1fr; }
  .person-card.wide { grid-column: 1; }
  .official-grid { grid-template-columns: 1fr; }
  .official-grid > div:nth-child(odd) { border-right: 0; }
  .official-grid > div:nth-child(even) { padding-left: 0; }
  .contact-cards { grid-template-columns: 1fr; }
  .contact-card { min-height: 310px; }
  footer { grid-template-columns: 1fr; text-align: left; padding: 45px 22px; }
  .footer-right { text-align: left; }
}

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