:root{
  --c-bg:#060709;
  --c-surface:#0b0d12;
  --c-petrol:#0d2a2a;
  --c-petrol-2:#081c1e;
  --c-gold:#b89462;
  --c-text:#f6f2ea;
  --c-muted:rgba(246,242,234,.72);

  --border:rgba(246,242,234,.08);
  --border-strong:rgba(184,148,98,.26);

  --shadow-lg:0 40px 90px rgba(0,0,0,.55);
  --shadow-md:0 18px 50px rgba(0,0,0,.45);
  --radius-lg:22px;
  --radius-md:16px;

  --font-serif:"Playfair Display",serif;
  --font-sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;

  --content-pad:clamp(1.1rem,2.8vw,2.8rem);
  --section-pad-y:clamp(4.2rem,7.8vh,6.8rem);

  --ease:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--c-bg);
  color:var(--c-text);
  font-family:var(--font-sans);
  overflow-x:hidden;
}

a{color:inherit}
img{max-width:100%; display:block}

.skip-link{
  position:absolute;
  left:1rem;
  top:1rem;
  padding:.8rem 1rem;
  background:rgba(0,0,0,.85);
  border:1px solid rgba(184,148,98,.55);
  border-radius:999px;
  text-decoration:none;
  transform:translateY(-120%);
  transition:transform .25s var(--ease);
  z-index:1000;
}
.skip-link:focus{transform:translateY(0)}

:focus-visible{
  outline:2px solid var(--c-gold);
  outline-offset:3px;
}

.noise-overlay{
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.06;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.3'/%3E%3C/svg%3E");
  z-index:2;
}

.swiss-grid-layout{
  display:flex;
  min-height:100vh;
  position:relative;
  z-index:3;
}

/* COL BRAND */
.col-brand{
  width:320px;
  min-width:320px;
  position:sticky;
  top:0;
  height:100vh;
  border-right:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.0));
  padding:var(--content-pad);
}

.brand-inner{
  height:100%;
  display:flex;
  flex-direction:column;
}

.brand-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
}

.logo{
  text-decoration:none;
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  gap:.95rem;
  letter-spacing:.04em;
}
.logo-mark{
  width:46px; height:46px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:rgba(184,148,98,.10);
  border:1px solid rgba(184,148,98,.35);
  font-family:var(--font-serif);
  font-weight:700;
  letter-spacing:.10em;
  font-size:1.05rem;
  line-height:1;
}
.logo-mark span:first-child{color:var(--c-gold)}
.logo-mark span:last-child{color:rgba(246,242,234,.92)}
.logo-stack{
  display:flex;
  flex-direction:column;
  gap:.10rem;
}

.logo-word{
  font-family:var(--font-serif);
  font-weight:400;
  font-size:1.32rem;
  line-height:1.05;
}

.nav-toggle{
  display:none;
  border:1px solid rgba(246,242,234,.14);
  background:rgba(255,255,255,.02);
  color:var(--c-text);
  border-radius:999px;
  padding:.6rem .85rem;
  gap:.5rem;
  align-items:center;
  cursor:pointer;
}

.nav-toggle__label{
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.nav-toggle__icon{
  width:18px;
  height:12px;
  position:relative;
  display:inline-block;
}
.nav-toggle__icon::before,
.nav-toggle__icon::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  height:2px;
  background:rgba(246,242,234,.9);
  border-radius:999px;
}
.nav-toggle__icon::before{top:0}
.nav-toggle__icon::after{bottom:0}

.brand-nav{margin-top:2.2rem}

.nav-list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:1.7rem;
}

.nav-item{
  display:grid;
  grid-template-columns:minmax(0,1fr) 10.5rem;
  align-items:center;
  column-gap:1.05rem;
}

.nav-link{
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  gap:.55rem;
  font-size:.86rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:rgba(246,242,234,.82);
  transition:color .2s var(--ease);
  min-width:0;
}
.nav-link::after{
  content:"▸";
  font-size:.9em;
  opacity:.35;
  transform:translateY(-1px);
  transition:transform .2s var(--ease), opacity .2s var(--ease);
}
.nav-item:first-child .nav-link::after{content:""}

.nav-item.active .nav-link{color:var(--c-gold)}
.nav-item:hover .nav-link::after,
.nav-item:focus-within .nav-link::after{
  opacity:.75;
  transform:translateY(-1px) rotate(90deg);
}

.sub-nav{
  justify-self:end;
  display:flex;
  flex-direction:column;
  gap:.38rem;
  border-left:1px solid rgba(184,148,98,.22);
  padding-left:1rem;
  opacity:0;
  transform:translateY(2px);
  pointer-events:none;
  transition:opacity .25s var(--ease), transform .25s var(--ease);
}
.sub-nav a{
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  text-decoration:none;
  color:rgba(246,242,234,.52);
  transition:color .2s var(--ease), transform .2s var(--ease), opacity .2s var(--ease);
  white-space:nowrap;
}
.sub-nav a:hover{
  color:var(--c-gold);
  transform:translateX(2px);
  opacity:1;
}
.nav-item:hover .sub-nav,
.nav-item:focus-within .sub-nav{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}

.brand-footer{
  margin-top:auto;
  display:flex;
  flex-direction:column;
  gap:.75rem;
}

.whats-cta{
  text-decoration:none;
  width:56px;
  height:56px;
  border-radius:999px;
  border:1px solid rgba(246,242,234,.14);
  background:rgba(255,255,255,.02);
  display:grid;
  place-items:center;
  transition:transform .2s var(--ease), border-color .2s var(--ease), background .2s var(--ease);
}
.whats-cta:hover{
  transform:translateY(-1px);
  background:rgba(184,148,98,.06);
  border-color:rgba(184,148,98,.35);
}
.whats-cta__icon{
  width:100%;
  height:100%;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:transparent;
  border:0;
  color:rgba(184,148,98,.95);
}
.whats-cta[href*="wa.me"] .whats-cta__icon{color:rgba(37,211,102,.95)}
.whats-cta[href*="wa.me"]:hover{
  background:rgba(37,211,102,.06);
  border-color:rgba(37,211,102,.34);
}

.brand-meta{display:none}

/* COL SPINE */
.col-spine{
  width:86px;
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:2rem 0;
  position:sticky;
  top:0;
  height:100vh;
}
.spine-timeline{
  position:relative;
  width:2px;
  height:55%;
  background:transparent;
  margin-top:1rem;
}
.timeline-line{
  position:absolute;
  inset:0;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(184,148,98,.3), rgba(246,242,234,.08));
}
.timeline-dot{
  position:absolute;
  left:50%;
  transform:translate(-50%,-50%);
  width:10px;
  height:10px;
  border-radius:999px;
  background:var(--c-gold);
  box-shadow:0 0 0 7px rgba(184,148,98,.13);
}

.spine-chapter{
  margin-top:1.8rem;
  text-align:center;
}
.chapter-label{
  font-size:.7rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(246,242,234,.50);
}
.chapter-number{
  font-family:var(--font-serif);
  font-size:1.85rem;
  margin-top:.15rem;
  color:rgba(246,242,234,.90);
}

.spine-metadata{
  margin-top:auto;
  writing-mode:vertical-rl;
  text-orientation:mixed;
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(246,242,234,.38);
}

/* COL CONTENT */
.col-content{
  flex:1;
  min-width:0;
}

.content-sticky-header{
  position:sticky;
  top:0;
  z-index:50;
  display:flex;
  gap:.8rem;
  align-items:center;
  padding:1.9rem var(--content-pad) 1rem;
  background:linear-gradient(180deg, rgba(6,7,9,.92), rgba(6,7,9,.45), transparent);
  backdrop-filter:blur(10px);
  pointer-events:none;
}
#header-page-tag{
  font-size:.78rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(246,242,234,.74);
}
.header-line{
  height:1px;
  flex:1;
  background:linear-gradient(90deg, rgba(184,148,98,.5), transparent);
}

.narrative-section{
  min-height:100vh;
  padding:var(--section-pad-y) var(--content-pad);
  display:flex;
  align-items:center;
}

.section-wrap{
  width:min(1040px, 100%);
}

.section-tag{
  display:inline-block;
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:rgba(184,148,98,.9);
}

.section-title{
  font-family:var(--font-serif);
  font-weight:400;
  font-size:clamp(2rem, 3.6vw, 3.2rem);
  margin:1rem 0 .9rem;
}

.line-deco{
  width:140px;
  height:2px;
  background:linear-gradient(90deg, rgba(184,148,98,.7), transparent);
  border-radius:999px;
  margin:.4rem 0 1.6rem;
}

.lead-paragraph{
  margin:0;
  font-size:1.05rem;
  color:rgba(246,242,234,.70);
  line-height:1.75;
}

/* HERO */
.hero-wrap{width:100%}
.hero-top{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:2rem;
}
.hero-kicker{
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:rgba(184,148,98,.95);
}
.hero-manifesto{
  margin:0;
  max-width:520px;
  text-align:right;
  color:rgba(246,242,234,.58);
  line-height:1.5;
}

.hero-stage{margin-top:2.4rem}

.news-card{
  border-radius:var(--radius-lg);
  border:1px solid rgba(246,242,234,.10);
  background:rgba(255,255,255,.02);
  box-shadow:var(--shadow-lg);
  overflow:hidden;
}

.news-viewport{
  position:relative;
  min-height:320px;
}

.news-slide{
  position:absolute;
  inset:0;
  display:grid;
  grid-template-columns:1.1fr 1.3fr;
  opacity:0;
  pointer-events:none;
  transform:translateY(8px);
  transition:opacity .4s var(--ease), transform .45s var(--ease);
}
.news-slide.is-active{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}

.news-art{
  background-size:cover;
  background-position:center;
  position:relative;
}
.news-art::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.0), rgba(0,0,0,.55));
}

.art-1{
  background:
    radial-gradient(850px 650px at 0% 0%, rgba(184,148,98,.11), transparent 60%),
    radial-gradient(900px 800px at 65% 40%, rgba(13,42,42,.52), transparent 70%),
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.85));
}
.art-2{
  background:
    radial-gradient(900px 650px at 10% 30%, rgba(184,148,98,.10), transparent 62%),
    radial-gradient(800px 700px at 80% 10%, rgba(13,42,42,.52), transparent 70%),
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.86));
}
.art-3{
  background:
    radial-gradient(1000px 700px at 25% 0%, rgba(184,148,98,.09), transparent 58%),
    radial-gradient(800px 700px at 80% 65%, rgba(13,42,42,.55), transparent 72%),
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.86));
}
.art-4{
  background:
    radial-gradient(900px 650px at 18% 0%, rgba(184,148,98,.10), transparent 62%),
    radial-gradient(1000px 900px at 75% 35%, rgba(13,42,42,.46), transparent 70%),
    linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.86));
}

.news-body{
  padding:2.2rem 2.2rem 1.8rem;
  display:flex;
  flex-direction:column;
  gap:1rem;
}

.news-meta{
  display:flex;
  gap:.9rem;
  align-items:center;
  flex-wrap:wrap;
}
.news-tag{
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(184,148,98,.95);
}
.news-date{
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(246,242,234,.50);
}

.news-title{
  margin:0;
  font-family:var(--font-serif);
  font-weight:400;
  font-size:1.75rem;
  line-height:1.2;
}
.news-desc{
  margin:0;
  color:rgba(246,242,234,.74);
  line-height:1.65;
  font-size:.98rem;
  max-width:560px;
}

.news-actions{
  margin-top:auto;
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  align-items:center;
}
.news-actions .btn{
  padding:.78rem 1.05rem;
  font-size:.84rem;
  letter-spacing:.10em;
}

.news-controls{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1.15rem 1.35rem;
  border-top:1px solid rgba(246,242,234,.08);
}

.news-arrows{
  display:flex;
  gap:.6rem;
}
.nav-arrow{
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(246,242,234,.14);
  background:rgba(0,0,0,.18);
  color:rgba(246,242,234,.92);
  cursor:pointer;
  transition:transform .2s var(--ease), border-color .2s var(--ease), background .2s var(--ease);
}
.nav-arrow:hover{
  transform:translateY(-1px);
  border-color:rgba(184,148,98,.35);
  background:rgba(184,148,98,.06);
}

.news-progress{
  display:flex;
  gap:.7rem;
  align-items:center;
}
.progress-dot{
  position:relative;
  width:22px;
  height:22px;
  border-radius:999px;
  border:1px solid rgba(246,242,234,.16);
  background:rgba(0,0,0,.12);
  cursor:pointer;
  overflow:hidden;
}
.progress-dot .fill{
  position:absolute;
  inset:0;
  width:0%;
  background:rgba(184,148,98,.85);
}
.progress-dot.is-active{border-color:rgba(184,148,98,.55)}

.news-note{
  margin:.95rem 0 0;
  font-size:.92rem;
  color:rgba(246,242,234,.50);
  line-height:1.55;
}

.hero-bottom{margin-top:3.3rem}

.hero-bottom-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:2.4rem;
  align-items:flex-start;
}
.hero-title{
  font-family:var(--font-serif);
  font-weight:400;
  font-size:clamp(2.1rem, 4vw, 3.1rem);
  line-height:1.08;
  margin:0;
}
.hero-bottom-copy{display:flex; flex-direction:column; gap:1.1rem}

.hero-lead{
  margin:0;
  color:rgba(246,242,234,.68);
  line-height:1.75;
  font-size:1.02rem;
}

.hero-actions{
  display:flex;
  gap:.9rem;
  flex-wrap:wrap;
  margin-top:.35rem;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.95rem 1.15rem;
  border-radius:999px;
  text-decoration:none;
  font-size:.92rem;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-weight:600;
  font-family:var(--font-sans);
  line-height:1;
  cursor:pointer;
  user-select:none;
  transition:transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease), box-shadow .25s var(--ease);
  border:1px solid transparent;
  background:transparent;
  appearance:none;
}

.btn-primary{
  background:linear-gradient(180deg, rgba(184,148,98,1), rgba(184,148,98,.92));
  color:#0b0d12;
  border-color:rgba(184,148,98,.65);
  box-shadow:0 14px 34px rgba(0,0,0,.22);
}
.btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 48px rgba(0,0,0,.28);
  filter:brightness(1.04);
}

.btn-ghost{
  background:rgba(255,255,255,.02);
  border-color:rgba(246,242,234,.14);
  color:var(--c-text);
}
.btn-ghost:hover{
  transform:translateY(-1px);
  border-color:rgba(184,148,98,.35);
  background:rgba(184,148,98,.06);
}

/* SECTION 02 */
.bento-grid{
  margin-top:2.8rem;
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1.2rem;
}

.bento-card{
  border-radius:var(--radius-md);
  border:1px solid rgba(246,242,234,.07);
  background:rgba(255,255,255,.02);
  padding:0;
  transition:border-color .25s var(--ease), background .25s var(--ease), transform .25s var(--ease);
  position:relative;
  overflow:hidden;
}

/* Accordion */
.bento-card > summary{
  list-style:none;
  cursor:pointer;
  padding:2.4rem;
  outline:none;
}
.bento-card > summary::-webkit-details-marker{display:none}
.bento-card > summary:focus-visible{
  outline:2px solid var(--c-gold);
  outline-offset:6px;
  border-radius:14px;
}
.bento-card > summary::after{
  content:"＋";
  position:absolute;
  top:1.85rem;
  right:1.85rem;
  width:36px;
  height:36px;
  display:grid;
  place-items:center;
  border-radius:999px;
  border:1px solid rgba(246,242,234,.14);
  background:rgba(0,0,0,.18);
  color:rgba(246,242,234,.86);
  font-size:1.05rem;
  transition:transform .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
}
.bento-card[open] > summary::after{
  content:"—";
  transform:translateY(-1px);
  border-color:rgba(184,148,98,.40);
  background:rgba(184,148,98,.10);
  color:var(--c-text);
}
.bento-card[open]{
  border-color:rgba(184,148,98,.32);
  background:rgba(255,255,255,.03);
}
.bento-card[open] > summary{padding-bottom:1.55rem}

.bento-summary{
  margin:0 0 1.15rem;
  color:rgba(246,242,234,.64);
  line-height:1.7;
  font-size:.98rem;
}

.bento-expand{
  padding:0 2.4rem 2.4rem;
  border-top:1px solid rgba(246,242,234,.08);
}

.bento-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg, rgba(184,148,98,.22), rgba(0,0,0,0));
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  pointer-events:none;
}

.bento-card:hover{
  transform:translateY(-2px);
  border-color:rgba(184,148,98,.32);
  background:rgba(255,255,255,.03);
}

.bento-card h3{
  margin:0 0 1.05rem;
  font-family:var(--font-serif);
  font-weight:400;
  font-size:1.55rem;
  line-height:1.2;
}
.bento-card p{
  margin:0 0 1.15rem;
  color:rgba(246,242,234,.62);
  line-height:1.7;
}

.card-meta{
  margin-top:auto;
  padding-top:1.1rem;
  border-top:1px solid rgba(246,242,234,.08);
}
.meta-title{
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(184,148,98,.95);
  display:block;
  margin-bottom:.35rem;
}
.meta-text{
  display:block;
  color:rgba(246,242,234,.60);
  line-height:1.5;
  font-size:.92rem;
}

.expand-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.25rem;
  margin-top:1.6rem;
}
.expand-col{
  border:1px solid rgba(246,242,234,.08);
  background:rgba(0,0,0,.12);
  border-radius:var(--radius-md);
  padding:1.35rem 1.35rem;
}
.expand-title{
  margin:0 0 .85rem;
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--c-gold);
  font-weight:600;
}
.expand-list{
  margin:0;
  padding-left:1.1rem;
  color:rgba(246,242,234,.68);
  line-height:1.65;
  font-size:.95rem;
}
.expand-list li{margin:.35rem 0}

.expand-links{
  margin-top:1.45rem;
  padding-top:1.25rem;
  border-top:1px solid rgba(246,242,234,.10);
}
.expand-kicker{
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--c-gold);
  font-weight:600;
  margin-bottom:.75rem;
}
.ref-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:.55rem;
}
.ref-list a{
  text-decoration:none;
  color:rgba(246,242,234,.80);
  border-bottom:1px solid rgba(184,148,98,.22);
  padding-bottom:.1rem;
  transition:color .2s var(--ease), border-color .2s var(--ease), transform .2s var(--ease);
}
.ref-list a:hover{
  color:var(--c-gold);
  border-color:rgba(184,148,98,.65);
  transform:translateX(2px);
}

.expand-actions{
  margin-top:1.45rem;
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  align-items:center;
}

/* SECTION 03 */
.process-panel{
  margin-top:2.6rem;
  border-radius:var(--radius-lg);
  border:1px solid rgba(246,242,234,.08);
  background:linear-gradient(135deg, rgba(13,42,42,.42), rgba(0,0,0,.0));
  padding:2.6rem;
  box-shadow:var(--shadow-md);
}
.process-header{
  display:flex;
  justify-content:space-between;
  gap:2rem;
  align-items:flex-end;
}
.process-kicker{
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:rgba(184,148,98,.95);
}
.process-title{
  font-family:var(--font-serif);
  font-weight:400;
  font-size:1.7rem;
  max-width:520px;
  text-align:right;
  color:rgba(246,242,234,.92);
}

.process-steps{
  list-style:none;
  padding:0;
  margin:2.3rem 0 0;
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1.2rem;
}
.step{
  border-radius:var(--radius-md);
  border:1px solid rgba(246,242,234,.08);
  background:rgba(0,0,0,.14);
  padding:1.4rem;
  display:flex;
  gap:1.1rem;
}
.step-num{
  width:44px;
  height:44px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:rgba(184,148,98,.12);
  border:1px solid rgba(184,148,98,.35);
  color:var(--c-gold);
  font-weight:600;
  letter-spacing:.1em;
}
.step-title{
  font-weight:600;
  letter-spacing:.04em;
  margin-bottom:.25rem;
}
.step-desc{
  color:rgba(246,242,234,.62);
  line-height:1.6;
  font-size:.95rem;
}

.stats-row{
  margin-top:2.6rem;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1rem;
}
.stat-item{
  border-radius:var(--radius-md);
  border:1px solid rgba(246,242,234,.08);
  background:rgba(255,255,255,.02);
  padding:1.35rem;
}
.stat-val{
  display:block;
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(184,148,98,.95);
  margin-bottom:.6rem;
}
.stat-item p{
  margin:0;
  color:rgba(246,242,234,.62);
  line-height:1.65;
  font-size:.95rem;
}

/* SECTION 04 */
.contact-panel{
  margin-top:2.6rem;
  border-radius:var(--radius-lg);
  border:1px solid rgba(246,242,234,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
  padding:2.6rem;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:2.2rem;
  align-items:start;
}

.contact-actions{
  margin-top:1.35rem;
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}

.contact-meta{margin-top:1.15rem}
.contact-note{
  margin:.55rem 0 0;
  color:rgba(246,242,234,.52);
  line-height:1.55;
  font-size:.92rem;
}

/* FORM */
.contact-form{
  border-radius:var(--radius-md);
  border:1px solid rgba(246,242,234,.10);
  background:rgba(0,0,0,.12);
  padding:1.9rem;
}

.form-head{margin-bottom:1.15rem}
.form-kicker{
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--c-gold);
  opacity:.92;
}
.form-title{
  margin-top:.45rem;
  font-family:var(--font-serif);
  font-size:1.55rem;
  font-weight:400;
  color:rgba(246,242,234,.94);
}

.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem 1rem;
}

.field{display:flex; flex-direction:column; gap:.45rem}
.field-full{grid-column:1 / -1}

.field label{
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(246,242,234,.70);
}

.field input,
.field select,
.field textarea{
  width:100%;
  border-radius:14px;
  border:1px solid rgba(246,242,234,.14);
  background:rgba(255,255,255,.02);
  color:var(--c-text);
  padding:.95rem 1rem;
  font-family:var(--font-sans);
  font-size:1rem;
  outline:none;
  transition:border-color .2s var(--ease), background .2s var(--ease), transform .2s var(--ease);
}

.field textarea{resize:vertical; min-height:130px}

.field input:focus,
.field select:focus,
.field textarea:focus{
  border-color:rgba(184,148,98,.55);
  background:rgba(184,148,98,.06);
}

.check{
  display:flex;
  align-items:flex-start;
  gap:.65rem;
  margin-top:1.05rem;
  font-size:.92rem;
  color:rgba(246,242,234,.65);
  line-height:1.45;
}
.check input{
  margin-top:.2rem;
  width:18px; height:18px;
  accent-color:var(--c-gold);
}
.check a{
  color:rgba(246,242,234,.90);
  text-decoration:none;
  border-bottom:1px solid rgba(184,148,98,.28);
  padding-bottom:.1rem;
}
.check a:hover{color:var(--c-gold); border-color:rgba(184,148,98,.65)}

.form-help{
  margin:.9rem 0 0;
  color:rgba(246,242,234,.48);
  line-height:1.55;
  font-size:.92rem;
}

.form-actions{
  margin-top:1.15rem;
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}

.contact-mail{
  display:inline-block;
  margin-top:1.2rem;
  text-decoration:none;
  font-size:1.02rem;
  color:rgba(246,242,234,.86);
}
.contact-mail:hover{color:var(--c-gold)}

.addr-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
  width:100%;
  margin-top:1.6rem;
}
.addr-card{
  border-radius:var(--radius-md);
  border:1px solid rgba(246,242,234,.08);
  background:rgba(255,255,255,.02);
  padding:1.2rem 1.35rem;
}
.addr-city{
  font-weight:600;
  letter-spacing:.02em;
}
.addr-line{
  margin-top:.25rem;
  color:rgba(246,242,234,.60);
  line-height:1.55;
  font-size:.95rem;
}

.mini-footer{
  margin-top:3.0rem;
  color:rgba(246,242,234,.40);
  font-size:.92rem;
}

/* LEGAL */
.legal-section{
  padding:4.6rem var(--content-pad);
  border-top:1px solid var(--border);
}
.legal-wrap{
  width:min(1040px, 100%);
}
.legal-wrap h3{
  margin:0 0 .9rem;
  font-family:var(--font-serif);
  font-weight:400;
  font-size:2rem;
}
.legal-wrap p{
  margin:0;
  color:rgba(246,242,234,.60);
  line-height:1.7;
}

.legal-grid{
  margin-top:1.6rem;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.1rem;
}
.legal-card{
  border-radius:var(--radius-md);
  border:1px solid rgba(246,242,234,.10);
  background:rgba(0,0,0,.12);
  padding:1.35rem 1.35rem;
}
.legal-card h4{
  margin:0 0 .55rem;
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--c-gold);
  font-weight:600;
}
.legal-card p{
  margin:0;
  color:rgba(246,242,234,.62);
  line-height:1.65;
  font-size:.95rem;
}
.legal-card a{
  color:rgba(246,242,234,.90);
  text-decoration:none;
  border-bottom:1px solid rgba(184,148,98,.28);
  padding-bottom:.1rem;
}
.legal-card a:hover{
  color:var(--c-gold);
  border-color:rgba(184,148,98,.65);
}

/* FOOTER */
.site-footer{
  padding:2.4rem var(--content-pad);
  border-top:1px solid var(--border);
}
.footer-inner{
  width:min(1040px, 100%);
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:1.2rem;
  align-items:center;
}
.footer-brand{
  font-family:var(--font-serif);
  font-size:1.2rem;
}
.footer-oab{
  margin-top:.3rem;
  color:rgba(246,242,234,.55);
  font-size:.92rem;
}
.footer-links{
  display:flex;
  justify-content:flex-end;
  gap:.8rem;
  align-items:center;
  flex-wrap:wrap;
}
.footer-links a{
  text-decoration:none;
  color:rgba(246,242,234,.70);
  font-size:.9rem;
}
.footer-links a:hover{color:var(--c-gold)}
.footer-sep{color:rgba(246,242,234,.35)}
.footer-copy{
  grid-column:1 / -1;
  color:rgba(246,242,234,.40);
  font-size:.9rem;
  margin-top:.8rem;
}

/* RESPONSIVO */
@media (max-width:1200px){
  .col-spine{display:none}
  .hero-bottom-grid{grid-template-columns:1fr}
  .news-slide{grid-template-columns:1fr}
  .news-art{min-height:190px}
  .news-art::after{background:linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.62))}
}

@media (max-width:900px){
  .swiss-grid-layout{flex-direction:column}

  .col-brand{
    position:sticky;
    top:0;
    width:100%;
    height:auto;
    min-width:unset;
    border-right:0;
    border-bottom:1px solid var(--border);
    z-index:200;
    backdrop-filter:blur(12px);
    padding:0;
  }
  .brand-inner{height:auto; padding:1.25rem 1.1rem}
  .nav-toggle{display:inline-flex}

  .brand-nav{
    margin-top:.8rem;
    max-height:0;
    overflow:hidden;
    transition:max-height .35s var(--ease);
  }
  .col-brand.is-open .brand-nav{max-height:60vh}

  .nav-item{grid-template-columns:1fr}
  .nav-list{gap:1.25rem; padding-bottom:.75rem}
  .sub-nav{display:none}

  .col-content{width:100%; margin-left:0}
  .content-sticky-header{padding:1.5rem 1.2rem .8rem}
  .narrative-section{padding:var(--section-pad-y) 1.2rem; min-height:auto}

  .bento-grid,
  .stats-row{grid-template-columns:1fr}

  .process-steps{grid-template-columns:1fr}

  .contact-panel{grid-template-columns:1fr; padding:2.0rem}
  .form-grid{grid-template-columns:1fr}
  .expand-grid{grid-template-columns:1fr}
  .addr-grid{grid-template-columns:1fr}
  .legal-grid{grid-template-columns:1fr}
  .logo-mark{width:42px; height:42px}

  .footer-inner{grid-template-columns:1fr}
  .footer-links{justify-content:flex-start}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{transition:none !important; animation:none !important}
}

/* === PATCH v2.0 → v2.1 (ajustes solicitados) ============================ */
:root{ color-scheme: dark; }

/* Âncoras: alinhar scroll com o header fixo */
main [id]{ scroll-margin-top: 7.25rem; }

/* Logo: SA empilhado como iniciais e alinhado aos nomes */
.logo{ gap:.42rem; align-items:flex-start; }
.logo-mark{
  width:auto;
  height:auto;
  padding:0;
  border-radius:0;
  background:transparent;
  border:0;
  font-size:2.05rem;
  line-height:1;
  gap:.02rem;
  align-items:flex-start;
}
.logo-stack{ gap:.06rem; margin-top:.12rem; }
.logo-word{ font-size:1.34rem; line-height:1.02; }

@media (max-width: 900px){
  main [id]{ scroll-margin-top: 6.6rem; }
  .logo-mark{ font-size:1.85rem; }
  .logo-word{ font-size:1.22rem; }
}

/* Menu: submenus abaixo (não à direita) + escalas estáveis */
.nav-item{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:.55rem;
}

.nav-link::after{ content:""; }

.nav-item[data-has-sub="true"] > .nav-link::after{
  content:"▾";
  margin-left:.45rem;
  opacity:.55;
  font-size:.9em;
  transform:translateY(-1px);
}

.sub-nav{
  width:100%;
  border-left:0;
  padding-left:0;
  border-top:1px solid rgba(184,148,98,.22);
  padding-top:.55rem;
  margin-top:-.2rem;

  opacity:0;
  max-height:0;
  overflow:hidden;
  transform:translateY(-2px);
  pointer-events:none;
}

.nav-item:hover .sub-nav,
.nav-item:focus-within .sub-nav,
.nav-item.open .sub-nav{
  opacity:1;
  max-height:460px;
  overflow:visible;
  transform:translateY(0);
  pointer-events:auto;
}

@media (max-width: 900px){
  .sub-nav{
    opacity:1;
    max-height:none;
    overflow:visible;
    transform:none;
    pointer-events:auto;
    margin-top:-.35rem;
  }
}

/* Hero: centralização e hierarquia (manifesto acima + compromisso abaixo) */
.hero-top{
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.65rem;
}

.hero-manifesto{
  max-width: 52rem;
  text-align:center;
  margin:0 auto;
}

.hero-kicker--bottom{
  margin-top:1.05rem;
  text-align:center;
}

.hero-bottom-grid{
  grid-template-columns:1fr;
  gap:1.4rem;
  justify-items:center;
  text-align:center;
}

.hero-bottom-copy{
  align-items:center;
  max-width: 56rem;
  margin:0 auto;
  text-align:center;
}

.hero-actions{ justify-content:center; }

/* Escritório: cabeçalho do fluxo centralizado */
.process-header{
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:1rem;
}

.process-title{
  text-align:center;
  max-width: 54rem;
  margin:0 auto;
}

/* Contato: meta (WhatsApp/E-mail) + endereços encaixados no painel */
.contact-meta .contact-mail{ display:block; margin-top:.85rem; }
.contact-meta .contact-mail + .contact-mail{ margin-top:.35rem; }

.contact-left .addr-grid{
  grid-template-columns:1fr;
  margin-top:1.4rem;
}

@media (max-width: 900px){
  .contact-left .addr-grid{ margin-top:1.15rem; }
}

/* Formulário: dropdowns com contraste (evita lista branca em alguns browsers) */
.field select{ color-scheme: dark; }
.field select option{ background: var(--c-surface); color: var(--c-text); }

/* Skip link: visível no foco, mas totalmente fora da tela em repouso */
.skip-link{ transform: translateY(-220%); }
.skip-link:focus{ transform: translateY(0); }

/* Legais: colapsáveis (details) com pouco espaço quando fechados */
.legal-section{ padding:1.35rem var(--content-pad); }
.legal-section[open]{ padding:4.6rem var(--content-pad); }

.legal-section > summary{
  cursor:pointer;
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  font-family:var(--font-sans);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.78rem;
  color:rgba(229,233,238,.86);
}

.legal-section > summary::-webkit-details-marker{ display:none; }

.legal-section > summary::after{
  content:"＋";
  font-size:1.05rem;
  opacity:.65;
}

.legal-section[open] > summary::after{ content:"－"; opacity:.75; }

/* Destaques: imagens por área (SVG inline) */
.art-1{ background-image: url("data:image/svg+xml,%3Csvg%20xmlns=%27http:%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20width=%27800%27%20height=%27600%27%20viewBox=%270%200%20800%20600%27%3E%20%3Cdefs%3E%20%3ClinearGradient%20id=%27g%27%20x1=%270%27%20y1=%270%27%20x2=%270%27%20y2=%271%27%3E%20%3Cstop%20offset=%270%27%20stop-color=%27#0b131d%27%2F%3E%20%3Cstop%20offset=%271%27%20stop-color=%27#060b11%27%2F%3E%20%3C%2FlinearGradient%3E%20%3C%2Fdefs%3E%20%3Crect%20width=%27800%27%20height=%27600%27%20fill=%27url(#g)%27%2F%3E%20%3Cpath%20d=%27M0%20420%20C160%20360%20320%20460%20480%20420%20C620%20380%20700%20420%20800%20380%20L800%20600%20L0%20600%20Z%27%20fill=%27#0f2d2a%27%20opacity=%270.9%27%2F%3E%20%3Cpath%20d=%27M0%20470%20C180%20410%20320%20520%20520%20470%20C650%20435%20720%20470%20800%20445%20L800%20600%20L0%20600%20Z%27%20fill=%27#123a32%27%20opacity=%270.75%27%2F%3E%20%3Cpath%20d=%27M120%20410%20L180%20360%20L240%20410%20L240%20470%20L120%20470%20Z%27%20fill=%27#b89462%27%20opacity=%270.85%27%2F%3E%20%3Crect%20x=%27145%27%20y=%27430%27%20width=%2725%27%20height=%2740%27%20fill=%27#0b131d%27%20opacity=%270.9%27%2F%3E%20%3Cpath%20d=%27M560%20390%20C610%20340%20690%20340%20740%20390%27%20stroke=%27#b89462%27%20stroke-width=%278%27%20opacity=%270.8%27%20fill=%27none%27%2F%3E%20%3Cpath%20d=%27M560%20410%20C610%20360%20690%20360%20740%20410%27%20stroke=%27#b89462%27%20stroke-width=%276%27%20opacity=%270.55%27%20fill=%27none%27%2F%3E%20%3C%2Fsvg%3E"); }
.art-2{ background-image: url("data:image/svg+xml,%3Csvg%20xmlns=%27http:%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20width=%27800%27%20height=%27600%27%20viewBox=%270%200%20800%20600%27%3E%20%3Cdefs%3E%20%3ClinearGradient%20id=%27g%27%20x1=%270%27%20y1=%270%27%20x2=%270%27%20y2=%271%27%3E%20%3Cstop%20offset=%270%27%20stop-color=%27#0b131d%27%2F%3E%20%3Cstop%20offset=%271%27%20stop-color=%27#060b11%27%2F%3E%20%3C%2FlinearGradient%3E%20%3C%2Fdefs%3E%20%3Crect%20width=%27800%27%20height=%27600%27%20fill=%27url(#g)%27%2F%3E%20%3Crect%20x=%27120%27%20y=%27220%27%20width=%27140%27%20height=%27280%27%20fill=%27#0f2d2a%27%20opacity=%270.9%27%2F%3E%20%3Crect%20x=%27290%27%20y=%27160%27%20width=%27170%27%20height=%27340%27%20fill=%27#123a32%27%20opacity=%270.8%27%2F%3E%20%3Crect%20x=%27490%27%20y=%27240%27%20width=%27190%27%20height=%27260%27%20fill=%27#0f2d2a%27%20opacity=%270.85%27%2F%3E%20%3Cg%20fill=%27#b89462%27%20opacity=%270.75%27%3E%20%3Crect%20x=%27150%27%20y=%27260%27%20width=%2720%27%20height=%2722%27%2F%3E%20%3Crect%20x=%27185%27%20y=%27260%27%20width=%2720%27%20height=%2722%27%2F%3E%20%3Crect%20x=%27150%27%20y=%27295%27%20width=%2720%27%20height=%2722%27%2F%3E%20%3Crect%20x=%27185%27%20y=%27295%27%20width=%2720%27%20height=%2722%27%2F%3E%20%3Crect%20x=%27330%27%20y=%27200%27%20width=%2722%27%20height=%2724%27%2F%3E%20%3Crect%20x=%27365%27%20y=%27200%27%20width=%2722%27%20height=%2724%27%2F%3E%20%3Crect%20x=%27400%27%20y=%27200%27%20width=%2722%27%20height=%2724%27%2F%3E%20%3C%2Fg%3E%20%3Cpath%20d=%27M120%20220%20L260%20220%20L260%20500%20L120%20500%20Z%27%20stroke=%27#b89462%27%20stroke-width=%276%27%20opacity=%270.35%27%20fill=%27none%27%2F%3E%20%3C%2Fsvg%3E"); }
.art-3{ background-image: url("data:image/svg+xml,%3Csvg%20xmlns=%27http:%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20width=%27800%27%20height=%27600%27%20viewBox=%270%200%20800%20600%27%3E%20%3Cdefs%3E%20%3ClinearGradient%20id=%27g%27%20x1=%270%27%20y1=%270%27%20x2=%270%27%20y2=%271%27%3E%20%3Cstop%20offset=%270%27%20stop-color=%27#0b131d%27%2F%3E%20%3Cstop%20offset=%271%27%20stop-color=%27#060b11%27%2F%3E%20%3C%2FlinearGradient%3E%20%3C%2Fdefs%3E%20%3Crect%20width=%27800%27%20height=%27600%27%20fill=%27url(#g)%27%2F%3E%20%3Cpath%20d=%27M170%20250%20L400%20150%20L630%20250%27%20stroke=%27#b89462%27%20stroke-width=%2710%27%20fill=%27none%27%20opacity=%270.9%27%2F%3E%20%3Crect%20x=%27210%27%20y=%27250%27%20width=%27380%27%20height=%27260%27%20fill=%27#0f2d2a%27%20opacity=%270.85%27%2F%3E%20%3Cg%20fill=%27#0b131d%27%20opacity=%270.9%27%3E%20%3Crect%20x=%27255%27%20y=%27270%27%20width=%2750%27%20height=%27220%27%2F%3E%20%3Crect%20x=%27335%27%20y=%27270%27%20width=%2750%27%20height=%27220%27%2F%3E%20%3Crect%20x=%27415%27%20y=%27270%27%20width=%2750%27%20height=%27220%27%2F%3E%20%3Crect%20x=%27495%27%20y=%27270%27%20width=%2750%27%20height=%27220%27%2F%3E%20%3C%2Fg%3E%20%3Crect%20x=%27190%27%20y=%27500%27%20width=%27420%27%20height=%2728%27%20fill=%27#b89462%27%20opacity=%270.65%27%2F%3E%20%3C%2Fsvg%3E"); }
.art-4{ background-image: url("data:image/svg+xml,%3Csvg%20xmlns=%27http:%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20width=%27800%27%20height=%27600%27%20viewBox=%270%200%20800%20600%27%3E%20%3Cdefs%3E%20%3ClinearGradient%20id=%27g%27%20x1=%270%27%20y1=%270%27%20x2=%270%27%20y2=%271%27%3E%20%3Cstop%20offset=%270%27%20stop-color=%27#0b131d%27%2F%3E%20%3Cstop%20offset=%271%27%20stop-color=%27#060b11%27%2F%3E%20%3C%2FlinearGradient%3E%20%3C%2Fdefs%3E%20%3Crect%20width=%27800%27%20height=%27600%27%20fill=%27url(#g)%27%2F%3E%20%3Crect%20x=%27210%27%20y=%27140%27%20width=%27380%27%20height=%27420%27%20rx=%2718%27%20fill=%27#0f2d2a%27%20opacity=%270.85%27%2F%3E%20%3Crect%20x=%27250%27%20y=%27200%27%20width=%27300%27%20height=%2718%27%20fill=%27#b89462%27%20opacity=%270.65%27%2F%3E%20%3Crect%20x=%27250%27%20y=%27240%27%20width=%27260%27%20height=%2714%27%20fill=%27#b89462%27%20opacity=%270.45%27%2F%3E%20%3Crect%20x=%27250%27%20y=%27275%27%20width=%27280%27%20height=%2714%27%20fill=%27#b89462%27%20opacity=%270.45%27%2F%3E%20%3Ccircle%20cx=%27540%27%20cy=%27460%27%20r=%2756%27%20fill=%27#b89462%27%20opacity=%270.75%27%2F%3E%20%3Cpath%20d=%27M540%20420%20V500%27%20stroke=%27#0b131d%27%20stroke-width=%2710%27%20opacity=%270.85%27%2F%3E%20%3Cpath%20d=%27M510%20460%20H570%27%20stroke=%27#0b131d%27%20stroke-width=%2710%27%20opacity=%270.85%27%2F%3E%20%3C%2Fsvg%3E"); }
.art-5{ background-image: url("data:image/svg+xml,%3Csvg%20xmlns=%27http:%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20width=%27800%27%20height=%27600%27%20viewBox=%270%200%20800%20600%27%3E%20%3Cdefs%3E%20%3ClinearGradient%20id=%27g%27%20x1=%270%27%20y1=%270%27%20x2=%270%27%20y2=%271%27%3E%20%3Cstop%20offset=%270%27%20stop-color=%27#0b131d%27%2F%3E%20%3Cstop%20offset=%271%27%20stop-color=%27#060b11%27%2F%3E%20%3C%2FlinearGradient%3E%20%3C%2Fdefs%3E%20%3Crect%20width=%27800%27%20height=%27600%27%20fill=%27url(#g)%27%2F%3E%20%3Cpath%20d=%27M400%20140%20C480%20180%20560%20170%20600%20200%20V330%20C600%20420%20520%20470%20400%20520%20C280%20470%20200%20420%20200%20330%20V200%20C240%20170%20320%20180%20400%20140%20Z%27%20fill=%27#0f2d2a%27%20opacity=%270.85%27%20stroke=%27#b89462%27%20stroke-width=%2710%27%20%2F%3E%20%3Cpath%20d=%27M310%20330%20L370%20390%20L500%20260%27%20stroke=%27#b89462%27%20stroke-width=%2712%27%20fill=%27none%27%20opacity=%270.9%27%2F%3E%20%3Ccircle%20cx=%27260%27%20cy=%27250%27%20r=%276%27%20fill=%27#b89462%27%20opacity=%270.8%27%2F%3E%20%3Ccircle%20cx=%27540%27%20cy=%27250%27%20r=%276%27%20fill=%27#b89462%27%20opacity=%270.8%27%2F%3E%20%3Ccircle%20cx=%27260%27%20cy=%27420%27%20r=%276%27%20fill=%27#b89462%27%20opacity=%270.6%27%2F%3E%20%3Ccircle%20cx=%27540%27%20cy=%27420%27%20r=%276%27%20fill=%27#b89462%27%20opacity=%270.6%27%2F%3E%20%3C%2Fsvg%3E"); }


/* === PATCH v3.0 — LEGAL SHEET (rodapé) + logo-only ====================== */

.sr-only{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.footer-brand{ font-size:.9rem; font-family:var(--font-sans); color:rgba(246,242,234,.68); }
.footer-links a{ font-size:.9rem; font-family:var(--font-sans); }

:root{
  --brand-w:320px;
  --spine-w:86px;
}

@media (max-width:1200px){
  :root{ --spine-w:0px; }
}
@media (max-width:900px){
  :root{ --brand-w:0px; --spine-w:0px; }
}

.legal-sheet{
  position:fixed;
  left:calc(var(--brand-w) + var(--spine-w));
  right:0;
  bottom:0;
  max-height:min(78vh, 760px);
  overflow:auto;
  background:rgba(6,7,9,.96);
  backdrop-filter:blur(14px);
  border-top:1px solid var(--border);
  transform:translateY(110%);
  transition:transform .35s var(--ease);
  z-index:500;
  box-shadow:0 -22px 70px rgba(0,0,0,.70);
}
.legal-sheet.is-open{ transform:translateY(0); }

.legal-sheet__header{
  position:sticky;
  top:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1.25rem var(--content-pad);
  background:linear-gradient(180deg, rgba(6,7,9,.98), rgba(6,7,9,.70));
  border-bottom:1px solid rgba(246,242,234,.08);
}

.legal-sheet__title{
  font-size:.78rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(246,242,234,.82);
}

.legal-sheet__close{
  width:42px; height:42px;
  border-radius:999px;
  border:1px solid rgba(246,242,234,.14);
  background:rgba(0,0,0,.18);
  color:rgba(246,242,234,.92);
  cursor:pointer;
  transition:transform .2s var(--ease), border-color .2s var(--ease), background .2s var(--ease);
}
.legal-sheet__close:hover{
  transform:translateY(-1px);
  border-color:rgba(184,148,98,.35);
  background:rgba(184,148,98,.06);
}

.legal-sheet__body{
  padding:1.75rem var(--content-pad) 2.4rem;
}
.legal-sheet .legal-wrap{
  width:min(1040px, 100%);
  margin:0 auto;
}



/* === PATCH v3.1 — alinhamento premium (conteúdo central no col-content) === */
.narrative-section{
  justify-content:center;
}

.section-wrap{
  width:min(1180px, 100%);
  margin:0 auto;
}

/* Logo: somente imagem, maior e proporcional */
.logo{
  display:flex;
  align-items:center;
  gap:0;
  letter-spacing:normal;
  grid-template-columns:unset;
}

.site-logo{
  height:92px;
  width:auto;
  max-width:240px;
  object-fit:contain;
  filter:drop-shadow(0 10px 26px rgba(0,0,0,.45));
}

@media (max-width:900px){
  .site-logo{ height:70px; max-width:200px; }
}



/* === PATCH v3.2 — ajustes solicitados (cores, menu, logo, + do accordion) === */

/* Logo no menu lateral: aumentar escala (quase 4x) sem quebrar layout */
.site-logo{
  height:160px !important;
  max-width:300px !important;
}

@media (max-width:900px){
  .site-logo{
    height:120px !important;
    max-width:260px !important;
  }
}

/* Menu lateral: espaçamento mais uniforme */
.brand-nav{ margin-top:1.8rem; }
.nav-list{ gap:1.25rem; }
.nav-link{ padding:.15rem 0; }

/* Botões do bloco Contato: cores iguais aos ícones do menu lateral */
.btn-wa{
  background:linear-gradient(180deg, rgba(37,211,102,1), rgba(37,211,102,.88));
  border-color:rgba(37,211,102,.70);
  color:#07110b;
  box-shadow:0 14px 34px rgba(0,0,0,.22);
}
.btn-wa:hover{
  transform:translateY(-1px);
  filter:brightness(1.02);
  box-shadow:0 18px 48px rgba(0,0,0,.28);
}

.btn-mail{
  background:linear-gradient(180deg, rgba(184,148,98,1), rgba(184,148,98,.92));
  border-color:rgba(184,148,98,.70);
  color:#0b0d12;
  box-shadow:0 14px 34px rgba(0,0,0,.22);
}
.btn-mail:hover{
  transform:translateY(-1px);
  filter:brightness(1.03);
  box-shadow:0 18px 48px rgba(0,0,0,.28);
}

/* Accordion (Áreas de atuação): evitar sobreposição do título com o botão "+" */
.bento-card > summary{
  padding-right:4.9rem;
}
.bento-card > summary::after{
  top:1.55rem;
  right:1.55rem;
}



/* === PATCH v3.3 — ajustes pontuais (logo central, espaçamento menu, whatsapp verde, + overlap) === */

/* Header do menu lateral: centralizar logo; manter botão menu no topo direito */
.brand-header{
  position:relative;
  align-items:center;
  justify-content:center;
}
.brand-header .nav-toggle{
  position:absolute;
  right:0;
  top:0;
}

/* Logo centralizada */
.logo{
  width:100%;
  justify-content:center;
}
.site-logo{
  display:block;
  margin:0 auto;
  height:220px !important;
  max-width:280px !important;
  object-fit:contain;
}

/* Ajuste responsivo */
@media (max-width:900px){
  .site-logo{
    height:150px !important;
    max-width:240px !important;
  }
}

/* Menu lateral: espaçamento uniforme entre itens principais */
.nav-list{
  gap:1.15rem;
}

/* Submenus não devem alterar o espaçamento entre itens (painel flutuante) */
.nav-item{ position:relative; }
.sub-nav{
  position:absolute;
  left:0;
  top:calc(100% + .55rem);
  width:max-content;
  min-width:12.5rem;

  border-left:0;
  padding-left:0;
  padding:.7rem .85rem;
  border:1px solid rgba(184,148,98,.22);
  border-radius:14px;

  background:rgba(6,7,9,.92);
  backdrop-filter:blur(10px);
  box-shadow:0 22px 60px rgba(0,0,0,.55);

  opacity:0;
  transform:translateY(2px);
  pointer-events:none;
  max-height:none;
  overflow:visible;
}
.nav-item:hover .sub-nav,
.nav-item:focus-within .sub-nav,
.nav-item.open .sub-nav{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}

/* Mobile: subnav segue acessível via foco */
@media (max-width:900px){
  .sub-nav{
    position:static;
    width:100%;
    min-width:unset;
    margin-top:.55rem;
    opacity:1;
    transform:none;
    pointer-events:auto;
    box-shadow:none;
    background:transparent;
    border:0;
    padding:.25rem 0 0;
    display:none;
  }
  .nav-item:focus-within .sub-nav{ display:flex; }
}

/* Form: botão WhatsApp verde, consistente */
.btn-wa{
  background:linear-gradient(180deg, rgba(37,211,102,1), rgba(37,211,102,.88));
  border-color:rgba(37,211,102,.70);
  color:#07110b;
}

/* Accordion (Áreas de atuação): mais respiro à direita para evitar sobreposição do título com o botão */
.bento-card > summary{
  padding-right:5.6rem;
}
.bento-card > summary::after{
  top:1.45rem;
  right:1.45rem;
}



/* === PATCH v3.4 — logo maior, sub-nav opaco + z-index, botão WA corrigido === */

/* Logo (menu lateral): aumentar 2-3x e manter centralizado */
.site-logo{
  height:360px !important;
  max-width:320px !important;
}

@media (max-width:900px){
  .site-logo{
    height:220px !important;
    max-width:280px !important;
  }
}

/* Submenu (ATUAÇÃO/CONTATO): não ficar transparente e não ser coberto pelos itens abaixo */
.brand-nav,
.nav-list{ overflow:visible; }

.nav-item{
  position:relative;
  z-index:1;
}

.nav-item:hover,
.nav-item:focus-within,
.nav-item.open{
  z-index:30;
}

.sub-nav{
  z-index:50;
  background:#060709 !important;
  border-color:rgba(184,148,98,.28) !important;
}



/* === PATCH v3.5 — logo central, submenu sem “sumir”, grid sem esticar cards === */

/* 1) Logo: centralizar visualmente (ajuste fino por offset) */
:root{
  --logo-offset-x: -14px; /* ajuste fino do “centro ótico” da marca */
}

.logo{ justify-content:center; }
.site-logo{
  margin:0 auto;
  object-position:center;
  transform:translateX(var(--logo-offset-x));
}

/* 2) Submenu: evitar “gap” entre link e sub-nav (hover-bridge) */
.nav-item[data-has-sub="true"]{
  padding-bottom:.35rem; /* amplia área de hover */
}
.nav-item[data-has-sub="true"]::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:100%;
  height:.55rem; /* ponte para o mouse */
  background:transparent;
}

/* reduzir o gap para facilitar navegação */
.sub-nav{
  top:100%;
  margin-top:.35rem;
}

/* 3) Bento grid: impedir que o card “ao lado” estique quando outro abre */
.bento-grid{
  align-items:start;
}
.bento-card{
  align-self:start;
}



/* === PATCH v3.6 — rodapé alinhado ao conteúdo (posição) =================== */
.site-footer{
  display:flex;
  justify-content:center;
}

.footer-inner{
  margin:0 auto;
  padding:0 var(--content-pad);
}



/* === PATCH v3.7 — expansão sem “empurrar” o card abaixo (grid) ============ */
/* Objetivo: ao abrir um card (ex.: Consignados), o conteúdo expande em overlay,
   sem aumentar a altura da célula do grid e sem deslocar o card abaixo (ex.: Direito Digital). */

.bento-grid{ position:relative; }

/* quando aberto, permitir overlay sair do card */
.bento-card[open]{ 
  overflow:visible; 
  z-index:80;
}

/* conteúdo expandido vira overlay, não participa do fluxo */
.bento-card[open] > .bento-expand{
  position:absolute;
  left:0;
  right:0;
  top:100%;
  margin-top:.9rem;

  border-top:0;
  border:1px solid rgba(246,242,234,.10);
  background:rgba(6,7,9,.96);
  backdrop-filter:blur(10px);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-md);
}

/* manter separação visual entre summary e overlay */
.bento-card[open] > summary{
  border-bottom:1px solid rgba(246,242,234,.08);
}

/* === IMAGENS DO SLIDER (quadrado à esquerda) ==============================
   Coloque os 5 arquivos PNG em: /img
   Nomes (exatos): ART-1.png, ART-2.png, ART-3.png, ART-4.png, ART-5.png
   (mantém o restante do site imutável) */

.news-art{
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.art-1{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.86)),
    url("img/art-1.png");
}

.art-2{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.86)),
    url("img/art-2.png");
}

.art-3{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.86)),
    url("img/art-3.png");
}

.art-4{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.86)),
    url("img/art-4.png");
}

.art-5{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.86)),
    url("img/art-5.png");
}



/* === PATCH v3.9b — centralização real do menu lateral em desktop =========
   Mantém HTML/JS intactos. Em desktop, posiciona o bloco de navegação
   no centro vertical da coluna esquerda, independentemente da altura útil. */
@media (min-width:901px){
  .brand-inner{
    position:relative;
  }

  .brand-nav{
    position:absolute;
    left:0;
    right:0;
    top:50%;
    transform:translateY(-50%);
    margin-top:0;
    max-height:none;
    overflow:visible;
  }

  .nav-list{
    width:100%;
  }

  /* mantém os ícones no rodapé */
  .brand-footer{
    margin-top:auto;
  }
}

/* === PATCH v4.2 — harmonização final do topo e da seção Sobre nós ========= */

/* Topo: mais respiro entre "COMPROMISSO • ÉTICA • EVIDÊNCIA"
   e o bloco institucional abaixo, evitando redundância visual. */
.hero-kicker--bottom{
  margin-top: 1.45rem;
  margin-bottom: 1.4rem;
}

.hero-bottom{
  margin-top: 3.4rem;
}

.hero-bottom-copy{
  max-width: 50rem;
  gap: 1rem;
}

/* Se o label antigo existir em alguma versão, mantém discreto */
.hero-bottom-label{
  font-size: .68rem;
  letter-spacing: .30em;
  text-transform: uppercase;
  color: rgba(184,148,98,.88);
  margin-bottom: .25rem;
  text-align: center;
}

/* Sobre nós: título principal institucional */
.office-intro{
  width:min(960px, 100%);
  margin: 2rem auto 0;
  display:grid;
  gap: 1.18rem;
}

.office-intro-copy{
  margin:0;
  color:rgba(246,242,234,.66);
  line-height:1.84;
  font-size:1rem;
  text-align:center;
}

.office-intro-copy--support{
  color:rgba(246,242,234,.72);
}

/* Transformar "Método, prova e execução" em subtítulo de verdade,
   mais presente e mais harmônico antes do quadro do fluxo */
.office-method-head{
  width:min(920px, 100%);
  margin: 3rem auto 0;
  display:grid;
  gap: .95rem;
}

.office-method-kicker{
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(1.45rem, 2.1vw, 2rem);
  letter-spacing: .02em;
  text-transform: none;
  color: rgba(246,242,234,.92);
  text-align: center;
}

.office-lead{
  max-width: 50rem;
  margin: 0 auto;
  text-align: center;
  color: rgba(246,242,234,.74);
}

.process-panel{
  margin-top: 2.5rem;
}

@media (max-width:900px){
  .hero-bottom{
    margin-top: 2.6rem;
  }

  .office-method-head{
    margin-top: 2.25rem;
  }
}

/* === PATCH v6.1 — organização final: atuação técnica + escritório institucional === */

/* INÍCIO: retirar repetição institucional e manter posicionamento mais elegante */
.hero-bottom-grid--single{
  display:block;
}

.hero-bottom-copy--center{
  max-width:52rem;
  margin:0 auto;
  align-items:center;
  text-align:center;
  gap:1rem;
}

.hero-lead--intro{
  max-width:50rem;
  color:rgba(246,242,234,.84);
  font-size:clamp(1.08rem, 1.28vw, 1.18rem);
  line-height:1.8;
}

.hero-note{
  margin:0;
  max-width:46rem;
  color:rgba(246,242,234,.56);
  font-size:.96rem;
  line-height:1.74;
}

.hero-kicker--bottom{
  margin-top:1.35rem;
  margin-bottom:1.55rem;
  text-align:center;
}

/* ATUAÇÃO: método/fluxo passam a morar aqui */
.atuacao-method-head{
  width:min(1040px, 100%);
  margin:3rem 0 0;
  display:grid;
  gap:.8rem;
}

.atuacao-method-kicker{
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:rgba(184,148,98,.95);
}

.atuacao-method-title{
  margin:0;
  font-family:var(--font-serif);
  font-weight:400;
  font-size:clamp(1.85rem, 2.5vw, 2.55rem);
  line-height:1.12;
  color:rgba(246,242,234,.94);
}

.atuacao-method-note{
  max-width:58rem;
}

/* ESCRITÓRIO: seção apenas institucional, mais sóbria e mais limpa */
#sec-03{
  min-height:auto;
}

#sec-03 .section-wrap{
  width:min(920px, 100%);
}

.office-intro{
  width:min(920px, 100%);
  margin:2rem 0 0;
  display:grid;
  gap:1rem;
}

.office-intro-copy{
  margin:0;
  color:rgba(246,242,234,.68);
  line-height:1.84;
  font-size:1rem;
  text-align:left;
}

@media (max-width:900px){
  .hero-bottom-copy--center{
    align-items:flex-start;
    text-align:left;
    margin:0;
  }

  .hero-kicker--bottom{
    text-align:left;
  }

  .atuacao-method-head{
    margin-top:2.2rem;
  }

  .office-intro{
    margin-top:1.6rem;
  }
}


/* === PATCH v6.2 — consolidação final do escritório e fluidez editorial ==== */
.hero-bottom-copy--center{
  max-width:54rem;
}

.hero-note{
  max-width:48rem;
}

#sec-03{
  min-height:auto;
}

#sec-03 .section-wrap{
  width:min(1040px, 100%);
}

.office-intro{
  width:min(980px, 100%);
  margin:2rem auto 0;
  gap:1.05rem;
}

.office-intro-copy{
  text-align:center;
}

.office-method-head{
  width:min(980px, 100%);
}

.office-lead{
  max-width:56rem;
}

#sec-03 .process-panel,
#sec-03 .stats-row{
  width:min(1040px, 100%);
  margin-left:auto;
  margin-right:auto;
}

#sec-03 .stats-row{
  margin-top:2rem;
}

#sec-03 .stat-item{
  min-height:100%;
}

@media (max-width:900px){
  .office-intro-copy{
    text-align:left;
  }

  #sec-03 .section-wrap,
  #sec-03 .process-panel,
  #sec-03 .stats-row{
    width:100%;
  }
}


/* === PATCH v6.3 — autonomia visual do slider sem dependência externa ===== */
.art-1{
  background-image:
    radial-gradient(850px 650px at 0% 0%, rgba(184,148,98,.11), transparent 60%),
    radial-gradient(900px 800px at 65% 40%, rgba(13,42,42,.52), transparent 70%),
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.85));
}

.art-2{
  background-image:
    radial-gradient(900px 650px at 10% 30%, rgba(184,148,98,.10), transparent 62%),
    radial-gradient(800px 700px at 80% 10%, rgba(13,42,42,.52), transparent 70%),
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.86));
}

.art-3{
  background-image:
    radial-gradient(1000px 700px at 25% 0%, rgba(184,148,98,.09), transparent 58%),
    radial-gradient(800px 700px at 80% 65%, rgba(13,42,42,.55), transparent 72%),
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.86));
}

.art-4{
  background-image:
    radial-gradient(900px 650px at 18% 0%, rgba(184,148,98,.10), transparent 62%),
    radial-gradient(1000px 900px at 75% 35%, rgba(13,42,42,.46), transparent 70%),
    linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.86));
}

.art-5{
  background-image:
    radial-gradient(900px 700px at 12% 10%, rgba(184,148,98,.11), transparent 58%),
    radial-gradient(1000px 900px at 82% 24%, rgba(13,42,42,.48), transparent 72%),
    linear-gradient(180deg, rgba(0,0,0,.24), rgba(0,0,0,.86));
}


/* === PATCH FINAL MASTER — arquitetura editorial, imagens reais e acabamento boutique === */

/* Slider com imagens reais enviadas pelo cliente */
.art-1{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.78)),
    url("art-1.png") !important;
  background-position:center center;
}

.art-2{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.14), rgba(0,0,0,.80)),
    url("art-2.png") !important;
  background-position:center center;
}

.art-3{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.16), rgba(0,0,0,.82)),
    url("art-3.png") !important;
  background-position:center center;
}

.art-4{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.78)),
    url("art-4.png") !important;
  background-position:center center;
}

.art-5{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.82)),
    url("art-5.png") !important;
  background-position:center center;
}

/* Logo com presença premium, sem desequilibrar a coluna */
.site-logo{
  height:290px !important;
  max-width:300px !important;
  object-fit:contain;
  transform:none !important;
}

@media (max-width:900px){
  .site-logo{
    height:165px !important;
    max-width:220px !important;
  }
}

/* Hero mais enxuto e mais alinhado ao posicionamento do escritório */
.hero-bottom-copy--center{
  max-width:56rem;
}

.hero-lead--intro{
  max-width:54rem;
  color:rgba(246,242,234,.88);
}

.hero-note{
  max-width:50rem;
  color:rgba(246,242,234,.60);
}

/* Fluxo de atuação em ATUAÇÃO */
.atuacao-method-head{
  width:min(1040px, 100%);
  margin:3.2rem auto 0;
  display:grid;
  gap:.85rem;
}

.atuacao-method-kicker{
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:rgba(184,148,98,.95);
  text-align:center;
}

.atuacao-method-title{
  margin:0;
  font-family:var(--font-serif);
  font-weight:400;
  font-size:clamp(1.9rem, 2.7vw, 2.7rem);
  line-height:1.12;
  color:rgba(246,242,234,.95);
  text-align:center;
}

.atuacao-method-note{
  max-width:56rem;
  margin:0 auto;
  text-align:center;
}

.process-panel--atuacao{
  margin-top:2rem;
}

/* Escritório mais institucional e menos repetitivo */
#sec-03{
  min-height:auto;
}

#sec-03 .section-wrap{
  width:min(1040px, 100%);
}

.office-method-head--institutional{
  width:min(940px, 100%);
  margin:2.6rem auto 0;
}

.office-method-head--institutional .office-method-kicker{
  font-size:clamp(1.3rem, 2.1vw, 1.9rem);
}

.stats-row--office{
  margin-top:2.55rem;
}

.stats-row--office .stat-item{
  min-height:100%;
}

/* Contato: reforco de acabamento */
.contact-panel{
  box-shadow:var(--shadow-md);
}

.addr-card{
  min-height:100%;
}

/* Mobile */
@media (max-width:900px){
  .atuacao-method-head{
    margin-top:2.35rem;
  }

  .atuacao-method-kicker,
  .atuacao-method-title,
  .atuacao-method-note{
    text-align:left;
  }

  .office-method-head--institutional{
    margin-top:2rem;
  }
}


/* === PATCH v7.0 — ajustes finos finais (sidebar, menu ativo e acabamento) === */
@media (min-width:901px){
  .brand-inner{
    position:relative;
    min-height:100%;
  }

  .brand-header{
    position:relative;
    justify-content:center;
    align-items:flex-start;
    padding-top:.15rem;
  }

  .brand-header .nav-toggle{
    position:absolute;
    right:0;
    top:0;
  }

  .logo{
    width:100%;
    justify-content:center;
  }

  .site-logo{
    height:122px !important;
    max-width:184px !important;
    margin:0 auto;
  }

  .brand-nav{
    position:static !important;
    left:auto !important;
    right:auto !important;
    top:auto !important;
    transform:none !important;
    margin-top:2.4rem !important;
    max-height:none !important;
    overflow:visible !important;
  }

  .nav-list{
    gap:1rem !important;
  }

  .nav-link{
    padding:.14rem 0;
  }

  .brand-footer{
    margin-top:auto !important;
    padding-top:2rem;
  }
}

@media (max-width:900px){
  .site-logo{
    height:92px !important;
    max-width:156px !important;
  }

  .brand-nav{
    margin-top:1.45rem !important;
  }
}

.hero-bottom{
  margin-top:2.65rem;
}

.hero-lead--intro{
  max-width:58rem;
}

.hero-note{
  max-width:53rem;
}

.office-intro{
  width:min(1020px, 100%);
}

.office-intro-copy{
  max-width:62rem;
  margin-left:auto;
  margin-right:auto;
}

.stats-row--office .stat-item p{
  text-wrap:pretty;
}

/* === PATCH v7.1 — menu lateral centralizado + legal acima do rodapé ===== */
:root{
  --footer-h: 78px;
}

/* Desktop: mantém a logo no topo e centraliza os itens principais no miolo útil */
@media (min-width:901px){
  .brand-inner{
    min-height:100%;
    display:flex;
    flex-direction:column;
  }

  .brand-header{
    flex:0 0 auto;
  }

  .brand-nav{
    flex:1 1 auto;
    display:flex;
    align-items:center;
    justify-content:center;
    margin-top:0 !important;
    padding:1.25rem 0 1.15rem;
  }

  .nav-list{
    width:100%;
    max-width:240px;
    margin:0 auto;
  }

  .brand-footer{
    flex:0 0 auto;
    margin-top:0 !important;
    padding-top:1.25rem;
  }
}

/* Rodapé fixo e sempre visível */
.col-content{
  padding-bottom:calc(var(--footer-h) + 1.2rem);
}

.site-footer{
  position:fixed;
  left:calc(var(--brand-w) + var(--spine-w));
  right:0;
  bottom:0;
  min-height:var(--footer-h);
  z-index:540;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  background:rgba(6,7,9,.96);
  backdrop-filter:blur(14px);
  border-top:1px solid var(--border);
  box-shadow:0 -12px 32px rgba(0,0,0,.28);
}

.site-footer .footer-inner{
  width:min(1040px, 100%);
  margin:0 auto;
  padding:1.1rem var(--content-pad);
}

/* Painel legal sobe acima do rodapé e não o cobre */
.legal-sheet{
  left:calc(var(--brand-w) + var(--spine-w));
  right:0;
  bottom:var(--footer-h);
  max-height:calc(100vh - var(--footer-h) - 1rem);
  z-index:530;
  border-top:1px solid var(--border);
}

/* Remover o título pequeno repetido do cabeçalho do painel; manter apenas o X */
.legal-sheet__header{
  justify-content:flex-end;
  padding:1rem var(--content-pad) .6rem;
  background:linear-gradient(180deg, rgba(6,7,9,.98), rgba(6,7,9,.72));
  border-bottom:0;
}

.legal-sheet__title{
  position:absolute !important;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.legal-sheet__body{
  padding-top:.5rem;
}

@media (max-width:900px){
  :root{
    --footer-h: 92px;
  }

  .col-content{
    padding-bottom:calc(var(--footer-h) + 1rem);
  }

  .site-footer{
    left:0;
  }

  .legal-sheet{
    left:0;
    bottom:var(--footer-h);
    max-height:calc(100vh - var(--footer-h) - .5rem);
  }

  .site-footer .footer-inner{
    width:100%;
  }
}


/* === PATCH v4.0 — refinamentos cirúrgicos de a11y e leitura ============== */
.news-slide[aria-hidden="true"]{
  visibility:hidden;
}
.news-slide.is-active{
  visibility:visible;
}

.news-progress .progress-dot[aria-current="true"]{
  border-color:rgba(184,148,98,.55);
  box-shadow:0 0 0 4px rgba(184,148,98,.10);
}

.legal-sheet[aria-hidden="true"]{
  visibility:hidden;
}
.legal-sheet.is-open{
  visibility:visible;
}

@media (prefers-reduced-motion:reduce){
  .progress-dot .fill{ width:100% !important; }
}


/* === PATCH v4.1 — refinamento editorial e respiro tipográfico ============ */
.section-title{
  margin:1.12rem 0 1.08rem;
}

.form-head{
  display:grid;
  gap:.65rem;
  margin-bottom:1.35rem;
}

.form-title{
  margin-top:0;
  line-height:1.18;
}

.atuacao-method-head{
  gap:1.05rem;
}

.office-method-head--institutional{
  gap:1.08rem;
}

.process-panel--atuacao .process-header{
  gap:2.35rem;
}

.process-panel--atuacao .process-title{
  line-height:1.18;
}

@media (max-width:900px){
  .form-head{
    gap:.58rem;
  }

  .atuacao-method-head,
  .office-method-head--institutional{
    gap:.92rem;
  }

  .process-panel--atuacao .process-header{
    gap:1.12rem;
  }
}


/* === PATCH v7.2 — ajustes finais mobile, slider e fluidez editorial ===== */

/* Slider: escala contida, controles mais limpos e dots apenas no item ativo */
.news-viewport{
  min-height:clamp(360px, 40vw, 430px);
}

.news-slide{
  grid-template-columns:minmax(0,1.04fr) minmax(0,1.22fr);
  align-items:stretch;
}

.news-art{
  min-height:100%;
  background-size:cover !important;
  background-position:center center !important;
  background-repeat:no-repeat !important;
}

.news-body{
  padding:2.15rem 2.15rem 1.9rem;
}

.news-controls{
  padding:1rem 1.2rem;
}

.news-progress{
  gap:.58rem;
}

.progress-dot{
  width:18px;
  height:18px;
  border:1px solid rgba(246,242,234,.22);
  background:transparent;
  box-shadow:none;
}

.progress-dot .fill{
  width:0%;
  background:rgba(184,148,98,.88);
  border-radius:999px;
}

.progress-dot.is-active,
.news-progress .progress-dot[aria-current="true"]{
  border-color:rgba(184,148,98,.58);
  background:rgba(184,148,98,.08);
  box-shadow:none;
}

.news-progress .progress-dot[aria-current="false"] .fill,
.progress-dot:not(.is-active) .fill{
  width:0 !important;
}

@media (prefers-reduced-motion:reduce){
  .progress-dot .fill{
    width:0 !important;
  }

  .progress-dot[aria-current="true"] .fill{
    width:100% !important;
  }
}

/* Hero: texto inicial mais limpo e menos listativo */
.hero-lead--intro{
  max-width:57rem;
}

.hero-note{
  max-width:51rem;
}

/* Menu mobile: topo mais compacto; WhatsApp/E-mail aparecem apenas ao abrir o menu */
@media (max-width:900px){
  .col-brand{
    padding:0;
  }

  .brand-inner{
    padding:.78rem 1rem .82rem;
  }

  .brand-header{
    justify-content:space-between;
    align-items:center;
    min-height:0;
  }

  .brand-header .nav-toggle{
    position:static;
    right:auto;
    top:auto;
  }

  .logo{
    width:auto;
    justify-content:flex-start;
  }

  .site-logo{
    height:62px !important;
    max-width:168px !important;
    margin:0;
  }

  .brand-nav{
    margin-top:.8rem !important;
    max-height:0 !important;
    overflow:hidden !important;
  }

  .col-brand.is-open .brand-nav{
    max-height:58vh !important;
    overflow:auto !important;
    padding-bottom:.25rem;
  }

  .nav-list{
    gap:.95rem !important;
    padding-bottom:0;
  }

  .nav-item{
    gap:.38rem;
  }

  .nav-link{
    font-size:.82rem;
    letter-spacing:.22em;
  }

  .sub-nav{
    display:flex;
    flex-direction:column;
    gap:.42rem;
  }

  .brand-footer{
    max-height:0;
    overflow:hidden;
    opacity:0;
    pointer-events:none;
    margin-top:0 !important;
    padding-top:0 !important;
    flex-direction:row;
    gap:.75rem;
    transition:max-height .28s var(--ease), opacity .25s var(--ease), padding-top .25s var(--ease);
  }

  .col-brand.is-open .brand-footer{
    max-height:72px;
    opacity:1;
    pointer-events:auto;
    margin-top:.8rem !important;
    padding-top:.12rem !important;
  }

  .whats-cta{
    width:48px;
    height:48px;
  }

  .content-sticky-header{
    padding:1rem 1rem .55rem;
  }

  main [id]{
    scroll-margin-top:5.5rem;
  }

  .narrative-section{
    padding-top:calc(var(--section-pad-y) - .8rem);
  }

  .news-viewport{
    min-height:unset;
  }

  .news-slide{
    grid-template-columns:1fr;
  }

  .news-art{
    min-height:220px;
  }

  .news-body{
    padding:1.45rem 1.35rem 1.3rem;
  }

  .news-controls{
    padding:.82rem 1rem;
  }

  .news-progress{
    margin-left:auto;
    gap:.5rem;
  }

  .progress-dot{
    width:16px;
    height:16px;
  }

  .contact-panel{
    padding:1.5rem;
  }

  .contact-form{
    padding:1.3rem;
  }

  .form-actions{
    display:grid;
    grid-template-columns:1fr;
    gap:.78rem;
  }

  .form-actions .btn{
    width:100%;
  }
}


/* === PATCH v7.2.4 — toggle real dos submenus + rodapé central no mobile === */
.nav-item.open > .nav-link::after{
  opacity:.75;
  transform:translateY(-1px) rotate(90deg);
}
.nav-item.manual-closed > .nav-link::after{
  opacity:.35 !important;
  transform:translateY(-1px) rotate(0deg) !important;
}
.nav-item.manual-closed > .sub-nav{
  opacity:0 !important;
  max-height:0 !important;
  overflow:hidden !important;
  transform:translateY(-2px) !important;
  pointer-events:none !important;
  display:flex;
}

@media (max-width:900px){
  .nav-item[data-has-sub="true"] > .nav-link::after{
    content:"▾";
    margin-left:.45rem;
    opacity:.55;
    font-size:.9em;
    transform:translateY(-1px);
    transition:transform .2s var(--ease), opacity .2s var(--ease);
  }

  .nav-item.open > .nav-link::after{
    transform:translateY(-1px) rotate(180deg);
  }

  .nav-item .sub-nav{
    position:static !important;
    width:100% !important;
    min-width:unset !important;
    display:none !important;
    flex-direction:column;
    gap:.42rem;
    margin-top:.28rem !important;
    padding:.38rem 0 0 !important;
    border:0 !important;
    border-top:1px solid rgba(184,148,98,.16) !important;
    border-left:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    opacity:1 !important;
    max-height:none !important;
    overflow:visible !important;
    transform:none !important;
    pointer-events:auto !important;
  }

  .nav-item.open > .sub-nav{
    display:flex !important;
  }

  .nav-item.manual-closed > .sub-nav{
    display:none !important;
  }

  .site-footer{
    display:flex;
    justify-content:center;
  }

  .footer-inner{
    grid-template-columns:1fr;
    justify-items:center;
    text-align:center;
    gap:.85rem;
  }

  .footer-left,
  .footer-brand,
  .footer-links{
    width:100%;
    text-align:center;
    justify-content:center;
  }

  .footer-links{
    gap:.6rem;
  }
}

/* === PATCH v7.2.5 — correção pontual do slider mobile (corte no início) === */
.news-viewport{
  transition:height .3s var(--ease);
}

@media (max-width:900px){
  .news-viewport{
    min-height:0;
  }
}

/* === PATCH v7.2.7 — ajustes pontuais mobile (legal sheet + kicker) === */
.legal-sheet{
  --legal-footer-offset:0px;
}

.legal-sheet__title{
  cursor:pointer;
}

@media (max-width:900px){
  .legal-sheet.legal-sheet--above-footer{
    bottom:calc(var(--legal-footer-offset) + env(safe-area-inset-bottom, 0px));
    max-height:calc(100vh - var(--legal-footer-offset) - env(safe-area-inset-top, 0px) - .75rem);
  }

  .hero-kicker--bottom{
    width:100%;
    display:block;
    margin-left:auto;
    margin-right:auto;
    text-align:center !important;
  }
}


/* === PATCH v7.2.8 — rodapé ao final + legal acima do rodapé ============== */
.col-content{
  padding-bottom:0;
}

.site-footer{
  position:static;
  left:auto;
  right:auto;
  bottom:auto;
  min-height:0;
  z-index:auto;
  padding:2.4rem var(--content-pad);
  background:transparent;
  backdrop-filter:none;
  box-shadow:none;
}

.site-footer .footer-inner{
  padding:0 var(--content-pad);
}

.legal-sheet{
  bottom:0;
  max-height:min(78vh, 760px);
}

.legal-sheet.legal-sheet--above-footer{
  bottom:calc(var(--legal-footer-offset) + env(safe-area-inset-bottom, 0px));
  max-height:calc(100vh - var(--legal-footer-offset) - env(safe-area-inset-top, 0px) - .75rem);
}

@media (max-width:900px){
  .col-content{
    padding-bottom:0;
  }

  .site-footer{
    left:auto;
  }

  .legal-sheet{
    left:0;
    bottom:0;
    max-height:min(78vh, 760px);
  }
}


/* === PATCH v6.4 — header acima do accordion aberto no desktop ============ */
@media (min-width:901px){
  .content-sticky-header{
    z-index:120;
  }
}

/* === PATCH v6.5 — divisória visível com legal sheet no desktop ========= */
@media (min-width:901px){
  .legal-sheet{
    border-left:1px solid var(--border);
  }
}


/* === PATCH v7.2.9 — submenu do desktop apenas por clique ================ */
@media (min-width:901px){
  .nav-item[data-has-sub="true"]:not(.open):hover > .sub-nav,
  .nav-item[data-has-sub="true"]:not(.open):focus-within > .sub-nav{
    opacity:0 !important;
    max-height:0 !important;
    overflow:hidden !important;
    transform:translateY(-2px) !important;
    pointer-events:none !important;
  }

  .nav-item[data-has-sub="true"]:not(.open):hover > .nav-link::after,
  .nav-item[data-has-sub="true"]:not(.open):focus-within > .nav-link::after{
    opacity:.55 !important;
    transform:translateY(-1px) rotate(0deg) !important;
  }
}



/* === PATCH v7.3 / v7.3.1 — atuação desktop consolidada =================== */
@media (min-width:901px){
  .bento-grid{
    position:static;
    align-items:stretch;
  }

  .bento-card[open]{
    grid-column:1 / -1;
    overflow:hidden;
    z-index:1;
  }

  .bento-card[open] > .bento-expand{
    position:static;
    left:auto;
    right:auto;
    top:auto;
    margin-top:0;
    border:0;
    border-top:1px solid rgba(246,242,234,.08);
    background:transparent;
    backdrop-filter:none;
    border-radius:0;
    box-shadow:none;
  }

  .bento-card:not([open]){
    align-self:stretch;
    height:100%;
  }

  .bento-card:not([open]) > summary{
    height:100%;
    display:flex;
    flex-direction:column;
  }
}

/* === PATCH v7.3.5 — mobile: accordion em fluxo, sem sobreposição ======== */
@media (max-width:900px){
  .bento-grid{
    position:static !important;
  }

  .bento-card[open]{
    overflow:hidden !important;
    z-index:1 !important;
  }

  .bento-card[open] > .bento-expand{
    position:static !important;
    inset:auto !important;
    left:auto !important;
    right:auto !important;
    top:auto !important;
    margin-top:0 !important;
    border:0 !important;
    border-top:1px solid rgba(246,242,234,.08) !important;
    background:transparent !important;
    backdrop-filter:none !important;
    border-radius:0 !important;
    box-shadow:none !important;
  }
}

/* === PATCH v7.3.6 — mobile: redução pontual do espaçamento entre seções === */
@media (max-width:900px){
  .narrative-section{
    padding-top:calc(var(--section-pad-y) * 0.6);
    padding-bottom:calc(var(--section-pad-y) * 0.6);
  }
}
/* === PATCH v7.3.7 — slider mais claro + mobile com respiro mais curto ==== */

/* Destaques: imagens com leitura mais nítida e clara, preservando o layout */
.news-art{
  filter:brightness(1.08) contrast(1.06) saturate(1.04);
}

.news-art::after{
  background:linear-gradient(90deg, rgba(0,0,0,.0), rgba(0,0,0,.22));
}

.art-1{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.52)),
    url("art-1.png") !important;
}

.art-2{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.03), rgba(0,0,0,.54)),
    url("art-2.png") !important;
}

.art-3{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.56)),
    url("art-3.png") !important;
}

.art-4{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.03), rgba(0,0,0,.52)),
    url("art-4.png") !important;
}

.art-5{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.56)),
    url("art-5.png") !important;
}

@media (max-width:1200px){
  .news-art::after{
    background:linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.28));
  }
}

/* Mobile: reduzir mais o vazio preto entre blocos principais, sem mexer no desktop */
@media (max-width:900px){
  .narrative-section{
    padding-top:calc(var(--section-pad-y) * 0.55);
    padding-bottom:calc(var(--section-pad-y) * 0.55);
  }
}


/* === PATCH v7.3.8 — slider sem subtítulo + imagens mais fiéis ============ */
.news-meta{
  display:none !important;
}

.news-body{
  padding-top:2.45rem;
}

.news-art{
  filter:brightness(1.18) contrast(1.08) saturate(1.06);
}

.news-art::after{
  background:linear-gradient(90deg, rgba(0,0,0,.0), rgba(0,0,0,.12));
}

.art-1{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.26)),
    url("art-1.png") !important;
}

.art-2{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.28)),
    url("art-2.png") !important;
}

.art-3{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.30)),
    url("art-3.png") !important;
}

.art-4{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.26)),
    url("art-4.png") !important;
}

.art-5{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.30)),
    url("art-5.png") !important;
}

@media (max-width:1200px){
  .news-art::after{
    background:linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.18));
  }
}


/* === PATCH v7.3.9 — legal sheet em fluxo acima do rodapé + links ativos == */
.footer-links a.is-active,
.check a.is-active{
  color:var(--c-gold) !important;
}

.check a.is-active{
  border-bottom-color:rgba(184,148,98,.65);
}

.legal-sheet{
  position:relative !important;
  left:auto !important;
  right:auto !important;
  bottom:auto !important;
  z-index:auto !important;
  width:min(1040px, calc(100% - (var(--content-pad) * 2)));
  margin:0 auto;
  max-height:0;
  overflow:hidden;
  opacity:0;
  pointer-events:none;
  transform:none !important;
  border:1px solid transparent;
  border-radius:var(--radius-lg);
  box-shadow:none;
  transition:
    max-height .35s var(--ease),
    opacity .25s var(--ease),
    margin-bottom .35s var(--ease),
    border-color .35s var(--ease),
    box-shadow .35s var(--ease);
}

.legal-sheet.is-open{
  max-height:min(78vh, 760px);
  overflow:auto;
  opacity:1;
  pointer-events:auto;
  margin:0 auto 1rem;
  border-color:var(--border);
  box-shadow:var(--shadow-md);
}

.legal-sheet__title{
  cursor:default;
}

@media (max-width:900px){
  .legal-sheet{
    width:calc(100% - 2.4rem);
  }

  .legal-sheet.is-open{
    margin-bottom:.9rem;
  }
}
