
:root{
  --paper:#f4efe7;
  --paper-deep:#efe8dc;
  --ink:#131316;
  --ink-soft:#2f2e33;
  --muted:#605d57;
  --muted-2:#8c8578;
  --line:#d7ccb9;
  --line-soft:#e6ddd0;
  --gold:#8e6f46;
  --black:#030303;
}
*{box-sizing:border-box}
html{scroll-behavior:auto;scroll-padding-top:0}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--paper);color:var(--ink);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
p,h1,h2,h3,dl,dd{margin:0}
.container{width:min(1200px,calc(100vw - 72px));margin:0 auto}
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:20px;top:20px;width:auto;height:auto;padding:10px 14px;border-radius:10px;background:#fff;z-index:999}
.site-header{position:sticky;top:0;z-index:50;background:rgba(244,239,231,.94);backdrop-filter:blur(14px);border-bottom:1px solid rgba(215,204,185,.8)}
.header-shell{display:flex;align-items:center;justify-content:space-between;gap:28px;min-height:78px}
.brand{display:flex;align-items:flex-start;gap:16px;min-width:0}
.brand img{width:min(192px,28vw);height:auto;flex:none}
.brand-meta{display:flex;flex-direction:column;gap:2px;padding-top:6px}
.brand-meta small,.brand-meta span{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);white-space:nowrap}
.site-nav{display:flex;align-items:center;gap:26px}
.site-nav ul{display:flex;gap:24px;list-style:none;padding:0;margin:0}
.site-nav a{font-size:.9rem;color:var(--ink-soft)}
.site-nav a:hover{color:#000}
.header-cta{padding-bottom:2px;border-bottom:1px solid var(--ink);font-size:.86rem;letter-spacing:.01em}
.nav-toggle{display:none;border:0;background:none;width:44px;height:44px;padding:0}
.nav-toggle span{display:block;width:20px;height:2px;background:#111;margin:4px auto;border-radius:2px}

.eyebrow{display:flex;align-items:center;gap:12px;font-size:.67rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2)}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--line)}
.hero{padding:64px 0 78px;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.06fr) minmax(290px,.72fr);gap:clamp(36px,5vw,92px);align-items:start}
.hero-copy h1{max-width:16.8ch;font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;font-size:clamp(1.72rem,2.12vw,2.16rem);line-height:1.1;letter-spacing:-.018em;margin-top:16px;text-wrap:balance}
.hero-copy .lead{margin-top:24px;max-width:33rem;font-size:.94rem;line-height:1.82;color:var(--ink-soft)}
.hero-copy .support{margin-top:12px;max-width:34rem;font-size:.88rem;line-height:1.82;color:var(--muted)}
.hero-links{display:flex;gap:26px;flex-wrap:wrap;margin-top:26px}
.text-link{display:inline-flex;align-items:center;gap:8px;font-size:.86rem;color:var(--ink-soft);padding-bottom:2px;border-bottom:1px solid var(--line-strong, #9d8a70)}
.text-link::after{content:'→';font-size:.88rem;line-height:1}
.text-link:hover{color:#000}
.hero-aside{padding-top:24px}
.meta-sheet{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.meta-row{display:grid;grid-template-columns:92px 1fr;gap:22px;padding:18px 0;border-bottom:1px solid var(--line-soft)}
.meta-row:last-child{border-bottom:none}
.meta-row span{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2)}
.meta-row p,.meta-row a{font-size:.94rem;line-height:1.68;color:var(--ink-soft)}
.meta-row a:hover{color:#000}

.section{padding:72px 0;border-bottom:1px solid var(--line)}
.section-grid{display:grid;grid-template-columns:minmax(230px,.68fr) minmax(0,1fr);gap:34px;align-items:end;margin-bottom:26px}
.section-intro h2{font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;font-size:clamp(1.48rem,1.9vw,1.78rem);line-height:1.12;letter-spacing:-.018em;margin-top:14px;max-width:14ch}
.section-note{max-width:32rem;justify-self:end;font-size:.9rem;line-height:1.8;color:var(--muted)}
.practice-shell{border-top:1px solid var(--line)}
.practice-row{display:grid;grid-template-columns:42px minmax(170px,240px) minmax(0,1fr) auto;gap:18px;align-items:start;padding:18px 0;border-bottom:1px solid var(--line)}
.practice-index{font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;font-size:1.18rem;color:var(--gold)}
.practice-row h3{font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;font-size:1.1rem;line-height:1.24;font-weight:400}
.practice-row p{font-size:.92rem;line-height:1.72;color:var(--muted)}
.practice-link{font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);padding-top:4px;white-space:nowrap}
.practice-row:hover h3,.practice-row:hover .practice-link{color:#000}

.structure-grid{display:grid;grid-template-columns:minmax(230px,.56fr) minmax(0,1fr);gap:40px;align-items:start}
.structure-copy h2{font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;font-size:clamp(1.42rem,1.75vw,1.68rem);line-height:1.14;letter-spacing:-.018em;max-width:14ch}
.structure-copy p{margin-top:18px;max-width:22rem;font-size:.94rem;line-height:1.82;color:var(--muted)}
.split-panels{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.content-panel{border-top:1px solid var(--line);padding-top:22px}
.content-panel h3{font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;font-size:1.36rem;line-height:1.14;margin-bottom:14px;font-weight:400}
.content-panel p{font-size:.93rem;line-height:1.8;color:var(--muted)}
.definition-list{margin-top:22px;border-top:1px solid var(--line-soft)}
.definition-list div{display:grid;grid-template-columns:112px 1fr;gap:18px;padding:12px 0;border-bottom:1px solid var(--line-soft)}
.definition-list dt,.contact-row span{font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2)}
.definition-list dd{margin:0;font-size:.9rem;line-height:1.62;color:var(--ink-soft)}

.commitments-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:28px}
.commitment{padding-top:14px;border-top:1px solid var(--line)}
.commitment h3{font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;font-size:1.02rem;line-height:1.24;margin-bottom:8px;font-weight:400}
.commitment p{font-size:.9rem;line-height:1.76;color:var(--muted)}

.section-contact{padding:76px 0 62px;background:var(--black);color:#f3ede3;border-bottom:none}
.section-contact .eyebrow{color:#b8a786}
.section-contact .eyebrow::before{background:rgba(183,154,110,.42)}
.contact-grid{display:grid;grid-template-columns:minmax(260px,.62fr) minmax(0,1fr);gap:44px;align-items:start}
.contact-brand{display:flex;align-items:center;gap:18px;margin-bottom:18px}
.contact-seal{width:52px;height:auto;opacity:.96}
.contact-wordmark{width:132px;height:auto;display:block;filter:invert(1) brightness(1.18) contrast(.94);opacity:.92}
.section-contact h2{font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;font-size:clamp(1.5rem,1.9vw,1.92rem);line-height:1.12;letter-spacing:-.018em;max-width:13ch;margin-top:14px}
.intro-copy{margin-top:16px;max-width:23rem;font-size:.94rem;line-height:1.82;color:#c8beb1}
.contact-sheet{border-top:1px solid rgba(183,154,110,.18)}
.contact-row{display:grid;grid-template-columns:160px 1fr;gap:18px;padding:16px 0;border-bottom:1px solid rgba(183,154,110,.18)}
.contact-row p,.contact-row a{font-size:.94rem;line-height:1.72;color:#f4eee3}
.contact-row a:hover{color:#fff}
.site-footer{padding:18px 0 26px;background:var(--black);border-top:1px solid rgba(183,154,110,.18)}
.footer-grid{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;flex-wrap:wrap}
.footer-copy p,.footer-links a{font-size:.83rem;line-height:1.58;color:#c8beb1}
.footer-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-links a:hover{color:#fff}

.hero--inner{padding:52px 0 66px}
.hero-copy--inner h1{max-width:none;font-size:clamp(1.48rem,1.82vw,1.82rem);line-height:1.14;margin-top:18px}
.back-link{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;color:var(--muted);margin-bottom:18px}
.back-link:hover{color:#000}
.hero-aside--inner{padding-top:18px}
.hero-aside--inner .meta-row{grid-template-columns:132px 1fr}
.section--scope .section-intro h2,.section--method .section-intro h2{max-width:none;font-size:clamp(1.26rem,1.6vw,1.48rem);line-height:1.16}
.scope-shell{border-top:1px solid var(--line)}
.scope-row{display:grid;grid-template-columns:minmax(220px,320px) minmax(0,1fr);gap:24px;padding:18px 0;border-bottom:1px solid var(--line)}
.scope-row h3{font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;font-size:1.06rem;line-height:1.28;font-weight:400}
.scope-row p{font-size:.92rem;line-height:1.72;color:var(--muted)}
.method-grid{display:grid;grid-template-columns:minmax(230px,.62fr) minmax(0,1fr);gap:42px;align-items:start}
.page-text p{font-size:.93rem;line-height:1.82;color:var(--muted)}
.page-text p + p{margin-top:16px}

.simple-shell h1{font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;font-size:clamp(1.72rem,2.2vw,2.18rem);line-height:1.1;margin-top:18px;margin-bottom:20px;max-width:16ch}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

@media (max-width:1060px){
  .hero-grid,.section-grid,.structure-grid,.split-panels,.contact-grid,.method-grid{grid-template-columns:1fr}
  .section-note{justify-self:start}
}
@media (max-width:880px){
  .site-nav{position:fixed;top:72px;left:0;right:0;bottom:0;display:none;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:20px;background:rgba(243,238,230,.985);padding:28px 24px 40px;border-top:1px solid var(--line);box-shadow:0 18px 50px rgba(0,0,0,.08);overflow:auto;z-index:60}
  .site-nav.open{display:flex}
  .site-nav ul{flex-direction:column;gap:0;align-items:flex-start;width:100%}
  .site-nav li{width:100%}
  .site-nav a{display:block;width:100%;font-size:1rem;line-height:1.35;padding:0 0 14px;border-bottom:1px solid var(--line-soft)}
  .site-nav .header-cta{display:inline-flex;align-items:center;padding:12px 0 0;border-bottom:none;font-size:.95rem;letter-spacing:.01em}
  .nav-toggle{display:block;position:relative;z-index:80}
  .brand-meta{display:none}
  .practice-row{grid-template-columns:38px 1fr;gap:14px}
  .practice-row p,.practice-link{grid-column:2}
  .practice-link{padding-top:0}
  .definition-list div,.contact-row,.meta-row,.hero-aside--inner .meta-row,.scope-row{grid-template-columns:1fr}
  .commitments-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .container{width:min(100vw - 32px, 640px)}
  .header-shell{min-height:72px}
  .brand img{width:168px}
  .site-nav{top:72px;left:0;right:0;bottom:0}
  .hero{padding:34px 0 48px}
  .hero-copy h1{font-size:clamp(1.25rem,4.75vw,1.48rem);max-width:16.8ch;line-height:1.14;letter-spacing:-.012em}
  .hero-copy .lead,.hero-copy .support,.section-note,.structure-copy p,.content-panel p,.commitment p,.page-text p,.scope-row p,.practice-row p,.contact-row p,.contact-row a,.intro-copy{font-size:.9rem}
  .hero-links{gap:16px;flex-direction:column;align-items:flex-start}
  .section{padding:48px 0}
  .section-intro h2{font-size:1.34rem;line-height:1.16}
  .structure-copy h2{font-size:1.34rem;line-height:1.16}
  .practice-row h3{font-size:1.02rem}
  .content-panel h3{font-size:1.24rem}
  .section-contact h2{font-size:1.42rem;line-height:1.16}
  .contact-brand{margin-bottom:10px}
  .contact-seal{width:42px}
  .contact-wordmark{width:118px}
  .hero-copy--inner h1{font-size:clamp(1.28rem,4.9vw,1.5rem);line-height:1.16}
  .section--scope .section-intro h2,.section--method .section-intro h2{font-size:1.18rem;line-height:1.18}
}

/* v12: base v10 preservada; apenas refino de escala tipográfica nos pontos criticados. */
@media (max-width:640px){
  .hero-copy .lead{margin-top:20px;}
  .meta-row p,.meta-row a{font-size:.9rem;}
}
/* v13: metadados redundantes removidos; hero reduzido para maior discrição. */
.content-panel .definition-list{display:none;}
@media (min-width:641px){.hero-copy .lead{max-width:32rem}.hero-copy .support{max-width:33rem}}

/* v14: remoção do texto redundante de escopo e realinhamento institucional do contato. */
.section-grid:has(.section-intro:only-child){grid-template-columns:1fr;margin-bottom:22px;}
.section-grid:has(.section-intro:only-child) .section-intro h2{max-width:18ch;}
.contact-brand-row{margin-bottom:24px;}
.contact-grid{grid-template-columns:minmax(260px,.5fr) minmax(0,1fr);align-items:start;}
.contact-copy{border-top:1px solid rgba(183,154,110,.18);padding-top:20px;}
.contact-sheet{border-top:1px solid rgba(183,154,110,.18);}
@media (max-width:1060px){.contact-brand-row{margin-bottom:18px}.contact-grid{grid-template-columns:1fr}.contact-copy{border-top:1px solid rgba(183,154,110,.18)}}
@media (max-width:640px){.contact-brand-row{margin-bottom:18px}.section-contact{padding-top:60px}.contact-grid{gap:28px}.contact-copy{padding-top:18px}.section-contact h2{max-width:16ch}.intro-copy{max-width:28rem}}
.areas-heading{grid-template-columns:1fr;margin-bottom:22px;}
.areas-heading .section-intro h2{max-width:18ch;}

/* v15: refinamento integral de alinhamento, proporção, hierarquia e silêncio visual. */
:root{
  --paper:#f3eee6;
  --paper-deep:#eee6da;
  --ink:#111113;
  --ink-soft:#303033;
  --muted:#625f59;
  --muted-2:#918a7e;
  --line:#d8ccbb;
  --line-soft:#e5dbcf;
}
.container{width:min(1120px,calc(100vw - 80px));}
.site-header{background:rgba(243,238,230,.95);}
.header-shell{min-height:72px;}
.brand{gap:14px;align-items:center;}
.brand img{width:min(176px,24vw);}
.brand-meta{padding-top:0;gap:1px;}
.brand-meta small,.brand-meta span{font-size:.59rem;letter-spacing:.16em;line-height:1.35;}
.site-nav{gap:24px;}
.site-nav ul{gap:22px;}
.site-nav a{font-size:.82rem;}
.header-cta{font-size:.8rem;}
.hero{padding:62px 0 70px;}
.hero-grid{grid-template-columns:minmax(0,.88fr) minmax(360px,.72fr);gap:clamp(56px,6vw,108px);}
.hero-copy h1{font-size:clamp(1.54rem,1.72vw,1.86rem);line-height:1.16;letter-spacing:-.012em;max-width:18ch;margin-top:18px;}
.hero-copy .lead{margin-top:22px;max-width:31rem;font-size:.88rem;line-height:1.82;}
.hero-copy .support{margin-top:10px;max-width:31rem;font-size:.84rem;line-height:1.82;}
.hero-links{margin-top:24px;gap:22px;}
.text-link{font-size:.8rem;}
.hero-aside{padding-top:16px;}
.meta-row{grid-template-columns:104px 1fr;gap:24px;padding:16px 0;}
.meta-row span{font-size:.6rem;letter-spacing:.18em;}
.meta-row p,.meta-row a{font-size:.86rem;line-height:1.68;}
.section{padding:68px 0;}
.section-grid{grid-template-columns:minmax(220px,.58fr) minmax(0,1fr);gap:34px;margin-bottom:26px;}
.section-grid--single{grid-template-columns:1fr;}
.section-intro h2{font-size:clamp(1.28rem,1.48vw,1.5rem);line-height:1.16;max-width:18ch;}
.section-note{font-size:.82rem;line-height:1.78;max-width:29rem;}
.practice-row{grid-template-columns:42px minmax(180px,230px) minmax(0,1fr) 96px;gap:18px;padding:16px 0;}
.practice-index{font-size:1.02rem;}
.practice-row h3{font-size:1rem;line-height:1.28;}
.practice-row p{font-size:.84rem;line-height:1.7;}
.practice-link{font-size:.68rem;letter-spacing:.12em;}
.structure-grid{grid-template-columns:minmax(220px,.44fr) minmax(0,1fr);gap:46px;}
.structure-copy h2{font-size:clamp(1.28rem,1.46vw,1.5rem);line-height:1.16;max-width:15ch;}
.structure-copy p{font-size:.86rem;line-height:1.82;max-width:20rem;}
.split-panels{gap:38px;}
.content-panel{padding-top:20px;}
.content-panel h3{font-size:1.12rem;line-height:1.22;margin-bottom:12px;}
.content-panel p{font-size:.84rem;line-height:1.78;}
.commitments-grid{gap:34px;}
.commitment h3{font-size:.94rem;line-height:1.28;}
.commitment p{font-size:.82rem;line-height:1.74;}
.section-contact{padding:82px 0 66px;}
.contact-grid{grid-template-columns:minmax(260px,.44fr) minmax(0,1fr);gap:72px;align-items:start;}
.contact-brand-row{display:none;}
.contact-brand{margin-bottom:22px;gap:16px;}
.contact-seal{width:44px;}
.contact-wordmark{width:122px;}
.contact-copy{border-top:1px solid rgba(183,154,110,.18);padding-top:22px;}
.section-contact h2{font-size:clamp(1.34rem,1.55vw,1.58rem);line-height:1.18;max-width:16ch;margin-top:14px;}
.intro-copy{margin-top:14px;max-width:21rem;font-size:.84rem;line-height:1.82;}
.contact-row{grid-template-columns:150px 1fr;gap:24px;padding:15px 0;}
.contact-row span{font-size:.58rem;letter-spacing:.18em;}
.contact-row p,.contact-row a{font-size:.84rem;line-height:1.72;}
.footer-copy p,.footer-links a{font-size:.76rem;}
.hero--inner{padding:50px 0 62px;}
.hero-copy--inner h1{font-size:clamp(1.34rem,1.55vw,1.58rem);line-height:1.18;max-width:18ch;}
.hero-copy--inner .lead{max-width:34rem;}
.hero-aside--inner .meta-row{grid-template-columns:132px 1fr;}
.section--scope .section-intro h2,.section--method .section-intro h2{font-size:clamp(1.18rem,1.36vw,1.34rem);line-height:1.18;}
.scope-row{grid-template-columns:minmax(220px,280px) minmax(0,1fr);gap:34px;padding:16px 0;}
.scope-row h3{font-size:.98rem;line-height:1.32;}
.scope-row p{font-size:.84rem;line-height:1.72;}
.method-grid{grid-template-columns:minmax(220px,.44fr) minmax(0,1fr);gap:46px;}
.page-text p{font-size:.84rem;line-height:1.82;max-width:44rem;}
.simple-shell h1{font-size:clamp(1.42rem,1.72vw,1.7rem);line-height:1.16;}
@media (max-width:1060px){
  .container{width:min(100vw - 56px, 900px);}
  .hero-grid,.section-grid,.structure-grid,.split-panels,.contact-grid,.method-grid{grid-template-columns:1fr;}
  .hero-grid{gap:38px;}
  .section-note{justify-self:start;}
  .contact-grid{gap:34px;}
}
@media (max-width:880px){
  .practice-row{grid-template-columns:36px 1fr;gap:12px 16px;}
  .practice-row p,.practice-link{grid-column:2;}
  .scope-row{grid-template-columns:1fr;gap:8px;}
}
@media (max-width:640px){
  .container{width:min(100vw - 36px, 640px);}
  .header-shell{min-height:70px;}
  .brand img{width:154px;}
  .hero{padding:30px 0 44px;}
  .hero-copy h1{font-size:clamp(1.22rem,6.1vw,1.44rem);max-width:15.5ch;line-height:1.16;letter-spacing:-.006em;}
  .hero-copy .lead,.hero-copy .support,.section-note,.structure-copy p,.content-panel p,.commitment p,.page-text p,.scope-row p,.practice-row p,.contact-row p,.contact-row a,.intro-copy{font-size:.86rem;line-height:1.74;}
  .hero-copy .lead{margin-top:18px;}
  .hero-links{margin-top:22px;gap:14px;}
  .text-link{font-size:.78rem;}
  .hero-aside{padding-top:8px;}
  .meta-row{padding:15px 0;}
  .section{padding:46px 0;}
  .section-intro h2,.structure-copy h2{font-size:1.22rem;line-height:1.18;}
  .section-grid{margin-bottom:20px;}
  .practice-row{padding:16px 0;}
  .practice-index{font-size:.98rem;}
  .practice-row h3{font-size:.96rem;}
  .practice-link{font-size:.66rem;}
  .content-panel h3{font-size:1.08rem;}
  .commitments-grid{gap:24px;}
  .section-contact{padding:56px 0 46px;}
  .contact-brand{margin-bottom:18px;}
  .contact-seal{width:38px;}
  .contact-wordmark{width:110px;}
  .section-contact h2{font-size:1.22rem;line-height:1.18;max-width:15ch;}
  .contact-row{grid-template-columns:1fr;gap:6px;padding:14px 0;}
  .hero-copy--inner h1{font-size:1.3rem;line-height:1.18;}
  .section--scope .section-intro h2,.section--method .section-intro h2{font-size:1.14rem;line-height:1.2;}
  .scope-row h3{font-size:.96rem;}
}

/* v16: alinhamento e justificação textual em blocos narrativos.
   Mantém a base aprovada e ajusta a percepção de ordem nas seções de texto. */
.content-panel p,
.structure-copy p,
.commitment p,
.page-text p,
.scope-row p,
.intro-copy {
  text-align: justify;
  text-align-last: left;
  text-justify: inter-word;
  hyphens: auto;
  -webkit-hyphens: auto;
  overflow-wrap: normal;
  font-kerning: normal;
  text-rendering: optimizeLegibility;
}

/* Dados formais, navegação e linhas técnicas permanecem alinhados à esquerda,
   porque justificação nesses blocos cria ruído e espaços artificiais. */
.meta-row p,
.meta-row a,
.contact-row p,
.contact-row a,
.practice-row p,
.practice-link,
.hero-copy .lead,
.hero-copy .support,
.section-note {
  text-align: left;
  hyphens: none;
}

/* Ajuste do bloco Estrutura/Titular: bordas, colunas e ritmo visual mais constantes. */
.split-panels {
  align-items: start;
}
.content-panel {
  min-width: 0;
}
.content-panel p {
  max-width: 38.5rem;
  margin-right: auto;
}
.structure-copy p {
  max-width: 21rem;
}
#estrutura .content-panel p,
#estrutura .structure-copy p {
  color: #56534e;
  line-height: 1.86;
  letter-spacing: .001em;
}

@media (min-width: 641px) {
  .split-panels {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}

@media (max-width: 640px) {
  /* No mobile, preserva a justificação nos textos longos solicitados,
     mas aumenta levemente a largura útil e o ritmo de leitura. */
  .content-panel p,
  .structure-copy p,
  .commitment p,
  .page-text p,
  .scope-row p,
  .intro-copy {
    text-align: justify;
    text-align-last: left;
    hyphens: auto;
    -webkit-hyphens: auto;
    line-height: 1.82;
  }
  .content-panel h3 {
    margin-bottom: 14px;
  }
}

/* v21: refinamento institucional de hierarquia, alinhamento e distribuição informacional. */
.hero-copy .eyebrow {
  max-width: 100%;
}
.hero-copy h1 {
  font-size: clamp(1.34rem, 1.46vw, 1.58rem);
  line-height: 1.18;
  max-width: 26ch;
  text-wrap: balance;
  letter-spacing: -0.006em;
}
.hero-copy .lead,
.hero-copy .support {
  max-width: 35rem;
}
.section-intro h2,
.structure-copy h2,
.hero-copy--inner h1,
.section-contact h2,
.simple-shell h1 {
  text-wrap: balance;
}
.section-contact h2 {
  max-width: none;
  font-size: clamp(1.22rem, 1.36vw, 1.42rem);
  line-height: 1.18;
}
.contact-copy .intro-copy {
  max-width: 22rem;
}
.section-grid--single {
  grid-template-columns: 1fr;
}
.section-grid--single .section-intro h2 {
  max-width: 18ch;
}
/* Justificação somente nos blocos narrativos longos; títulos, chamadas e dados permanecem compostos por alinhamento tipográfico. */
.content-panel p,
.page-text p,
.commitment p,
.scope-row p {
  text-align: justify;
  text-align-last: left;
  text-justify: inter-word;
  hyphens: auto;
  -webkit-hyphens: auto;
}
.hero-copy .lead,
.hero-copy .support,
.meta-row p,
.contact-row p,
.contact-row a,
.practice-row p,
.section-note,
.intro-copy,
.scope-row h3 {
  text-align: left;
  hyphens: none;
}
@media (max-width: 640px) {
  .hero-copy h1 {
    font-size: clamp(1.12rem, 5.05vw, 1.28rem);
    line-height: 1.18;
    max-width: 22ch;
  }
  .hero-copy .lead,
  .hero-copy .support {
    max-width: 100%;
  }
  .section-contact h2 {
    font-size: 1.12rem;
    max-width: none;
    white-space: nowrap;
  }
  .content-panel p,
  .page-text p,
  .commitment p,
  .scope-row p {
    text-align: justify;
    text-align-last: left;
  }
}


/* v22: refino institucional de alinhamento, texto e hierarquia informacional. */
/* Evita títulos excessivos e melhora a cadência no mobile sem alterar a base visual aprovada. */
.hero-copy h1 {
  font-size: clamp(1.26rem, 1.34vw, 1.46rem);
  line-height: 1.22;
  max-width: 27ch;
}
.hero-copy .lead,
.hero-copy .support {
  text-align: justify;
  text-align-last: left;
  hyphens: auto;
  -webkit-hyphens: auto;
}
.practice-row p {
  text-align: justify;
  text-align-last: left;
  hyphens: auto;
  -webkit-hyphens: auto;
}
.structure-copy h2 {
  max-width: 20ch;
  font-size: clamp(1.16rem, 1.24vw, 1.36rem);
  line-height: 1.22;
}
.structure-copy p {
  text-align: justify;
  text-align-last: left;
  max-width: 24rem;
}
.content-panel p {
  text-align: justify;
  text-align-last: left;
  max-width: none;
}
.split-panels {
  align-items: start;
}
.section-contact h2 {
  max-width: none;
  white-space: normal;
  font-size: clamp(1.18rem, 1.28vw, 1.34rem);
}
.contact-copy .intro-copy {
  max-width: 20rem;
  text-align: left;
}
.scope-row p,
.page-text p,
.commitment p {
  text-align: justify;
  text-align-last: left;
}
@media (max-width: 640px) {
  .container { width: min(100vw - 44px, 640px); }
  .hero-copy h1 {
    font-size: clamp(1.08rem, 4.65vw, 1.2rem);
    line-height: 1.22;
    max-width: 25ch;
  }
  .hero-copy .lead,
  .hero-copy .support,
  .practice-row p,
  .structure-copy p,
  .content-panel p,
  .commitment p,
  .scope-row p,
  .page-text p {
    text-align: justify;
    text-align-last: left;
    hyphens: auto;
    -webkit-hyphens: auto;
    overflow-wrap: normal;
    line-height: 1.78;
  }
  .meta-row {
    grid-template-columns: 94px 1fr;
    gap: 18px;
    align-items: start;
  }
  .meta-row p,
  .meta-row a {
    font-size: .82rem;
    line-height: 1.64;
    text-align: left;
  }
  .structure-copy h2 {
    font-size: 1.12rem;
    max-width: 22ch;
    line-height: 1.22;
  }
  .structure-copy p {
    max-width: none;
  }
  .content-panel h3 {
    font-size: 1.02rem;
  }
  .content-panel p {
    font-size: .82rem;
  }
  .section-contact h2 {
    font-size: 1.08rem;
    white-space: normal;
  }
}

/* v26: correção severa de alinhamento móvel e prevenção de sobreposição.
   Mantém a base visual aprovada; altera apenas grade técnica e composição tipográfica. */
@media (max-width: 640px) {
  .meta-row,
  .hero-aside--inner .meta-row {
    grid-template-columns: 1fr !important;
    gap: 7px !important;
    padding: 16px 0 !important;
  }
  .meta-row span,
  .hero-aside--inner .meta-row span {
    display: block;
    width: 100%;
    min-width: 0;
    white-space: normal;
    overflow-wrap: normal;
    letter-spacing: .20em;
    line-height: 1.35;
  }
  .meta-row p,
  .meta-row a,
  .hero-aside--inner .meta-row p,
  .hero-aside--inner .meta-row a {
    display: block;
    width: 100%;
    max-width: none;
    min-width: 0;
    text-align: justify;
    text-align-last: left;
    text-justify: inter-word;
    hyphens: auto;
    -webkit-hyphens: auto;
    overflow-wrap: normal;
    word-break: normal;
  }
  .hero-aside .meta-sheet,
  .hero-aside--inner .meta-sheet {
    overflow: visible;
  }
}

/* Enquadramentos técnicos: alinhamento de parágrafos longos sem sobreposição. */
.hero-aside--inner .meta-row p,
.scope-row p,
.practice-row p,
.content-panel p,
.commitment p,
.page-text p {
  text-align: justify;
  text-align-last: left;
  text-justify: inter-word;
  hyphens: auto;
  -webkit-hyphens: auto;
  overflow-wrap: normal;
  word-break: normal;
}

/* Mantém botões, links, rótulos e dados formais sem justificação artificial. */
.practice-link,
.text-link,
.header-cta,
.site-nav a,
.contact-row p,
.contact-row a,
.contact-row span,
.definition-list dd,
.definition-list dt {
  text-align: left;
  hyphens: none;
}

/* Previne colisão em linhas técnicas longas no mobile sem mudar o desenho. */
@media (max-width: 640px) {
  .practice-row {
    grid-template-columns: 34px minmax(0, 1fr) !important;
    column-gap: 14px !important;
  }
  .practice-row h3,
  .practice-row p,
  .practice-link {
    min-width: 0;
    overflow-wrap: normal;
    word-break: normal;
  }
  .practice-row p {
    grid-column: 2;
    max-width: 100%;
  }
  .practice-link {
    grid-column: 2;
  }
  .scope-row {
    grid-template-columns: 1fr !important;
  }
  .scope-row p {
    max-width: 100%;
  }
}

/* v28: ajustes acumulados — LGPD, rodapé funcional, localização e hierarquia institucional. */
.contact-wordmark{
  filter: invert(1) sepia(8%) saturate(70%) brightness(.92) contrast(.82);
  opacity:.76;
}
.map-link{
  display:inline-block;
  margin-top:8px;
  font-size:.78rem !important;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#c8beb1 !important;
}
.map-link:hover{color:#fff !important}
.footer-grid--minimal{
  justify-content:flex-end;
}
.footer-links--full{
  gap:22px;
  width:100%;
  justify-content:flex-end;
}
@media (max-width:640px){
  .footer-grid--minimal{justify-content:flex-start;}
  .footer-links--full{justify-content:flex-start;gap:18px 22px;}
}

/* v30: wordmark do rodapé em tom quente institucional, sem filtro azulado/lavanda. */
.contact-wordmark{
  filter:none !important;
  opacity:1 !important;
}


/* v32: link de agendamento pelo WhatsApp — sem verde comercial e sem flutuação ruidosa. */
.whatsapp-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  max-width:100%;
  margin-top:24px;
  padding:12px 18px 11px;
  border:1px solid rgba(202,188,164,.42);
  border-radius:999px;
  color:#d8cbb8 !important;
  background:rgba(202,188,164,.035);
  font-size:.72rem;
  line-height:1;
  letter-spacing:.14em;
  text-transform:uppercase;
  text-decoration:none;
  white-space:nowrap;
  transition:background .18s ease,border-color .18s ease,color .18s ease,transform .18s ease;
}
.whatsapp-cta:hover{
  color:#fff !important;
  border-color:rgba(216,203,184,.72);
  background:rgba(202,188,164,.09);
  transform:translateY(-1px);
}
.whatsapp-cta:focus-visible{
  outline:2px solid rgba(216,203,184,.75);
  outline-offset:4px;
}
@media (max-width:640px){
  .whatsapp-cta{
    margin-top:18px;
    padding:11px 16px 10px;
    font-size:.68rem;
    letter-spacing:.12em;
  }
}


/* v33: composição controlada do título principal da home.
   Não justifica título; cria quebras intencionais para alinhamento institucional, sem linha curta acidental. */
.hero-title span{display:block;}
.hero-copy .hero-title{
  max-width: none !important;
  width: fit-content;
  text-align: left;
}
@media (max-width:640px){
  .hero-copy .hero-title{
    font-size: clamp(1.13rem, 4.55vw, 1.24rem) !important;
    line-height: 1.2 !important;
    letter-spacing: -0.004em;
    max-width: none !important;
  }
}

/* v34: composição mais cuidadosa do título da seção Estrutura.
   Mantém a base visual; evita quebra acidental e estabiliza o alinhamento no mobile. */
#estrutura .structure-copy h2.structure-title{
  max-width:none !important;
  width:auto;
  text-align:left;
  text-wrap:normal;
}
@media (max-width:640px){
  #estrutura .structure-copy h2.structure-title{
    font-size:clamp(1rem, 4.05vw, 1.10rem) !important;
    line-height:1.24 !important;
    letter-spacing:-0.004em;
    white-space:nowrap;
    max-width:100% !important;
  }
}
@media (max-width:360px){
  #estrutura .structure-copy h2.structure-title{
    white-space:normal;
    max-width:22ch !important;
  }
}


/* v37: reancoragem do hero e do menu móvel
   - evita sobreposição do menu sobre a seção selecionada
   - substitui o rótulo redundante da home por 'Atuação reservada'
   - mantém o painel móvel em altura integral com fechamento ao clicar nos links */
section[id],
#conteudo > section,
.hero,
.section,
.section-contact{scroll-margin-top:96px;}

@media (max-width:880px){
  .site-nav{
    position:fixed;
    top:72px;
    left:0;
    right:0;
    bottom:0;
    display:none;
    flex-direction:column;
    align-items:flex-start;
    justify-content:flex-start;
    gap:18px;
    background:rgba(244,239,231,.985);
    padding:22px 20px 28px;
    border-top:1px solid var(--line);
    border-bottom:none;
    overflow:auto;
    z-index:120;
    box-shadow:0 18px 42px rgba(0,0,0,.08);
  }
  .site-nav.open{display:flex;}
  .site-nav ul{width:100%;}
  .site-nav li{width:100%;}
  .site-nav a{display:block;width:100%;padding:2px 0;}
  .header-cta{margin-top:8px;}
  body.nav-open{overflow:hidden;}
}

@media (max-width:640px){
  .hero-copy .eyebrow{letter-spacing:.16em;}
}


/* v38: remoção do rótulo superior da home e correção de navegação móvel/âncoras */
.hero-copy--clean h1{margin-top:0;}
#areas,#estrutura,#contato{scroll-margin-top:96px;}
body.nav-open{overflow:hidden;}
@media (max-width:880px){
  .site-nav{max-height:calc(100vh - 72px);overflow:auto;box-shadow:0 18px 40px rgba(0,0,0,.06);z-index:60;}
}
@media (max-width:640px){
  #areas,#estrutura,#contato{scroll-margin-top:88px;}
}


@media (max-width:880px){
  .site-nav::after{content:"";display:block;height:24px;flex:none}
  .site-nav .header-cta::after{content:"→";margin-left:8px;font-size:.95em;line-height:1}
}
@media (max-width:640px){
  html{scroll-padding-top:82px}
  [id]{scroll-margin-top:82px}
  .site-nav{padding:24px 20px 34px}
  .site-nav a{font-size:1rem;padding-bottom:13px}
  .site-nav .header-cta{font-size:.92rem}
}


/* v40: menu móvel em painel fixo integral e visível */
@media (max-width: 880px) {
  .site-header {
    z-index: 1000;
  }
  .site-nav {
    position: fixed !important;
    inset: 72px 0 0 0 !important;
    width: 100vw !important;
    height: calc(100dvh - 72px) !important;
    min-height: calc(100dvh - 72px) !important;
    max-height: none !important;
    display: none !important;
    background: rgba(243, 238, 230, 0.995) !important;
    padding: 28px 24px 40px !important;
    border-top: 1px solid var(--line) !important;
    box-shadow: 0 18px 48px rgba(0,0,0,.08) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    z-index: 999 !important;
  }
  .site-nav.open {
    display: block !important;
  }
  .site-nav ul {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  .site-nav li {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  .site-nav a {
    display: block !important;
    width: 100% !important;
    padding: 0 0 16px !important;
    font-size: 1.02rem !important;
    line-height: 1.4 !important;
    border-bottom: 1px solid var(--line-soft) !important;
  }
  .site-nav .header-cta {
    display: block !important;
    width: 100% !important;
    margin-top: 18px !important;
    padding-top: 0 !important;
    border-bottom: none !important;
    font-size: .96rem !important;
    letter-spacing: .01em !important;
  }
  body.nav-open {
    overflow: hidden !important;
  }
}
@media (max-width: 640px) {
  .site-nav {
    inset: 70px 0 0 0 !important;
    height: calc(100dvh - 70px) !important;
    min-height: calc(100dvh - 70px) !important;
    padding: 24px 20px 34px !important;
  }
}

/* v41: âncoras exatas no mobile e desktop */
html{scroll-padding-top:0 !important;}
[id], section[id], #conteudo > section, .hero, .section, .section-contact, #areas, #estrutura, #contato{
  scroll-margin-top:0 !important;
}


/* v44: seção de acolhimento e acessibilidade com integração artística do símbolo de apoio ao autismo */
.section-autismo{
  background: linear-gradient(180deg,#f7f3ec 0%, var(--paper) 100%);
}
.autism-shell{
  display:grid;
  gap:28px;
  align-items:start;
}
.autism-copy{
  max-width: 62rem;
}
.autism-copy h2{
  font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;
  font-size:clamp(1.52rem,1.95vw,2.02rem);
  line-height:1.06;
  letter-spacing:-.02em;
  max-width:11ch;
  margin-top:18px;
}
.autism-text{
  max-width:40rem;
  font-size:.96rem;
  line-height:1.84;
  color:var(--ink-soft);
  margin-top:18px;
}
.autism-artwork{
  margin:4px 0 0;
  border:1px solid var(--line);
  border-radius:34px;
  overflow:hidden;
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,.92) 0%, rgba(246,241,233,.96) 72%, rgba(240,232,220,.98) 100%);
}
.autism-artwork img{
  width:100%;
  height:auto;
  display:block;
}
.autism-link{
  color:var(--gold);
  width:max-content;
}
.autism-link:hover{
  color:#6f5433;
}
@media (max-width:640px){
  .section-autismo{padding:52px 0;}
  .autism-shell{gap:22px;}
  .autism-copy h2{
    font-size:clamp(1.32rem,7vw,1.58rem);
    line-height:1.08;
    max-width:10ch;
  }
  .autism-text{
    font-size:.9rem;
    line-height:1.78;
    max-width:none;
  }
  .autism-artwork{border-radius:24px;}
}


/* Integração da Área do Cliente no bloco institucional */
.client-area-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:16px;
}
.client-area-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  max-width:100%;
  padding:11px 16px 10px;
  border:1px solid rgba(202,188,164,.42);
  border-radius:999px;
  color:#d8cbb8 !important;
  background:rgba(202,188,164,.035);
  font-size:.68rem;
  line-height:1;
  letter-spacing:.13em;
  text-transform:uppercase;
  text-decoration:none;
  white-space:nowrap;
  transition:background .18s ease,border-color .18s ease,color .18s ease,transform .18s ease;
}
.client-area-cta:hover{
  color:#fff !important;
  border-color:rgba(216,203,184,.72);
  background:rgba(202,188,164,.09);
  transform:translateY(-1px);
}
.client-area-cta--secondary{
  background:transparent;
}
.contact-row--client-area p{
  text-align:left;
}
@media (max-width:640px){
  .client-area-actions{gap:10px;margin-top:14px;}
  .client-area-cta{width:100%;font-size:.66rem;letter-spacing:.11em;}
}


/* v45: reorganização dos CTAs institucionais e refinamento silencioso da seção de acolhimento. */
.client-area-actions{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:12px;
  margin-top:12px;
}
.client-area-cta{
  max-width:100%;
  white-space:normal;
  line-height:1.28;
  text-align:center;
}
.client-area-cta--secondary{
  background:transparent;
}
@media (max-width:640px){
  .client-area-actions{
    width:100%;
    gap:10px;
    margin-top:10px;
  }
  .client-area-cta{
    width:100%;
  }
}

.section-autismo{
  background:linear-gradient(180deg,#f7f3ec 0%, var(--paper) 100%);
}
.autism-shell{
  display:grid;
  grid-template-columns:minmax(0,.78fr) minmax(320px,1fr);
  gap:34px 56px;
  align-items:center;
}
.autism-copy{
  max-width:31rem;
}
.autism-copy h2{
  max-width:12ch;
}
.autism-text{
  max-width:31rem;
}
.autism-artwork{
  width:min(100%, 820px);
  margin:0 0 0 auto;
  padding:34px 38px 28px;
  border:1px solid rgba(216,204,187,.72);
  border-radius:34px;
  background:radial-gradient(circle at 50% 50%, rgba(255,255,255,.94) 0%, rgba(246,241,233,.96) 70%, rgba(240,232,220,.98) 100%);
}
.autism-artwork img{
  width:100%;
  max-width:680px;
  height:auto;
  margin:0 auto;
  display:block;
}
.autism-link{
  grid-column:1 / -1;
  margin-top:-8px;
}
@media (max-width:1060px){
  .autism-shell{
    grid-template-columns:1fr;
    gap:26px;
    align-items:start;
  }
  .autism-copy{
    max-width:36rem;
  }
  .autism-artwork{
    width:100%;
    margin:0;
    padding:26px 24px 22px;
  }
  .autism-artwork img{
    max-width:620px;
  }
  .autism-link{
    margin-top:-4px;
  }
}
@media (max-width:640px){
  .section-autismo{
    padding:52px 0;
  }
  .autism-shell{
    gap:22px;
  }
  .autism-copy h2{
    font-size:clamp(1.32rem,7vw,1.58rem);
    line-height:1.08;
    max-width:11ch;
  }
  .autism-text{
    font-size:.9rem;
    line-height:1.78;
    max-width:none;
  }
  .autism-artwork{
    padding:18px 14px 14px;
    border-radius:26px;
  }
  .autism-artwork img{
    max-width:100%;
  }
  .autism-link{
    margin-top:0;
  }
}


/* v46: reancoragem visual dos CTAs e símbolo de acolhimento. */
.institutional-actions{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
  margin-top:20px;
  max-width:18.5rem;
}
.institutional-action{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:42px;
  padding:11px 18px 10px;
  border:1px solid rgba(216,203,184,.44);
  border-radius:999px;
  color:#d8cbb8 !important;
  background:rgba(202,188,164,.026);
  font-size:.67rem;
  line-height:1.12;
  letter-spacing:.12em;
  text-transform:uppercase;
  text-decoration:none;
  text-align:center;
  white-space:nowrap;
  transition:background .18s ease,border-color .18s ease,color .18s ease,transform .18s ease;
}
.institutional-action:hover{
  color:#fff !important;
  border-color:rgba(216,203,184,.72);
  background:rgba(202,188,164,.08);
  transform:translateY(-1px);
}
.institutional-action--primary{
  border-color:rgba(216,203,184,.58);
  background:rgba(216,203,184,.06);
}
.institutional-action--muted{
  border-color:rgba(216,203,184,.34);
  background:transparent;
}
.institutional-action:focus-visible{
  outline:2px solid rgba(216,203,184,.70);
  outline-offset:4px;
}
.client-area-actions,
.client-area-cta,
.whatsapp-cta{
  /* classes antigas preservadas apenas para páginas eventualmente em cache; sem uso no novo bloco. */
}
.contact-row p{
  text-align:left;
  text-align-last:left;
}
@media (max-width:640px){
  .institutional-actions{
    max-width:21rem;
    margin-top:18px;
    gap:9px;
  }
  .institutional-action{
    min-height:40px;
    padding:10px 15px 9px;
    font-size:.64rem;
    letter-spacing:.105em;
  }
}

.section-autismo{
  background:linear-gradient(180deg,#f7f3ec 0%, var(--paper) 100%);
}
.autism-shell{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(220px,.46fr);
  gap:22px 46px;
  align-items:center;
}
.autism-copy{
  max-width:42rem;
}
.autism-copy h2{
  font-family:"Iowan Old Style","Palatino Linotype",Georgia,serif;
  font-size:clamp(1.24rem,1.34vw,1.46rem);
  line-height:1.12;
  letter-spacing:-.012em;
  max-width:17ch;
  margin-top:16px;
}
.autism-text{
  max-width:38rem;
  font-size:.84rem;
  line-height:1.76;
  font-weight:400;
  color:#5b5751;
  margin-top:16px;
  text-align:left;
}
.autism-artwork{
  width:min(100%, 360px);
  margin:0 0 0 auto;
  padding:0;
  border:0;
  border-radius:0;
  overflow:visible;
  background:transparent;
  opacity:.78;
  filter:saturate(.74) contrast(.94);
}
.autism-artwork img{
  width:100%;
  max-width:100%;
  height:auto;
  display:block;
}
.autism-link{
  grid-column:1 / -1;
  margin-top:0;
  width:max-content;
}
@media (max-width:1060px){
  .autism-shell{
    grid-template-columns:1fr;
    gap:18px;
  }
  .autism-artwork{
    width:min(66vw, 330px);
    margin:4px 0 0 auto;
  }
}
@media (max-width:640px){
  .section-autismo{
    padding:46px 0;
  }
  .autism-shell{
    gap:18px;
  }
  .autism-copy h2{
    font-size:clamp(1.12rem,5.4vw,1.32rem);
    line-height:1.12;
    max-width:15ch;
  }
  .autism-text{
    font-size:.84rem;
    line-height:1.7;
    max-width:none;
  }
  .autism-artwork{
    width:min(72vw, 292px);
    margin:2px 0 0 auto;
    opacity:.82;
  }
}
