/* ============================================================
   FALCHET E MARQUES — PÁGINA "O ESCRITÓRIO"
   Reusa home.css (nav, footer, btn, bgword, eyebrow, link-arrow,
   wall, pad, reveal, wa-fab). Aqui só o específico da página.
   ============================================================ */

/* ---------- NAV sólido desde o topo (hero claro) ---------- */
.page-solidnav .nav { background: rgba(255,255,255,.94); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom-color: var(--fm-ink-100); color: var(--fm-ink-900); }
.page-solidnav .nav__logo--white { opacity: 0; }
.page-solidnav .nav__logo--black { opacity: 1; }

/* ============================================================
   HERO
   ============================================================ */
.ab-hero { position: relative; overflow: hidden; padding-top: clamp(190px, 19vw, 256px); padding-bottom: clamp(60px, 8vw, 110px); }
.ab-hero .bgword { top: clamp(78px, 9vw, 104px); right: clamp(12px, 3vw, 40px); font-size: clamp(48px, 7vw, 120px); }
.ab-hero__grid { display: grid; grid-template-columns: 1.25fr .75fr; gap: clamp(40px, 6vw, 90px); align-items: end; }
.ab-hero h1 { font-weight: 800; font-size: clamp(40px, 6.4vw, 92px); line-height: .98; letter-spacing: -.03em; margin: 22px 0 0; max-width: 14ch; }
.ab-hero h1 b { color: var(--fm-blue-700); font-weight: 800; }
.ab-hero__sub { font-size: clamp(16px, 1.5vw, 20px); font-weight: 300; line-height: 1.6; color: var(--fm-ink-600); max-width: 44ch; margin: 26px 0 0; }
.ab-meta { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--fm-ink-200); }
.ab-meta__item { display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: start; padding: 18px 0; border-bottom: 1px solid var(--fm-ink-100); }
.ab-meta__item .d { width: 10px; height: 10px; background: var(--fm-blue-700); transform: rotate(45deg); margin-top: 6px; }
.ab-meta__item b { font-size: 16px; font-weight: 600; color: var(--fm-ink-900); display: block; letter-spacing: -.005em; }
.ab-meta__item span { font-size: 13.5px; font-weight: 300; color: var(--fm-ink-500); line-height: 1.5; }

/* ============================================================
   MANIFESTO (parede azul)
   ============================================================ */
.ab-manifesto { position: relative; overflow: hidden; }
.ab-manifesto .bgword { -webkit-text-stroke-color: rgba(255,255,255,.12); top: clamp(20px, 3vw, 32px); bottom: auto; right: clamp(12px, 3vw, 40px); font-size: clamp(50px, 7.5vw, 124px); }
.ab-manifesto__inner { max-width: 1000px; position: relative; z-index: 1; }
.ab-manifesto p { font-weight: 300; font-size: clamp(26px, 3.8vw, 56px); line-height: 1.2; letter-spacing: -.02em; color: #fff; margin: 22px 0 0; }
.ab-manifesto p b { font-weight: 800; }
.ab-manifesto p .accent { color: #fff; border-bottom: 3px solid rgba(255,255,255,.4); padding-bottom: 2px; }
.ab-manifesto__sign { margin-top: 44px; display: inline-flex; align-items: center; gap: 14px; font-size: 14px; letter-spacing: .04em; color: rgba(255,255,255,.78); }
.ab-manifesto__sign .d { width: 9px; height: 9px; background: #fff; transform: rotate(45deg); }

/* ============================================================
   PRINCÍPIOS — Missão / Visão + Valores
   ============================================================ */
.ab-mv { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 5vw, 80px); margin-bottom: clamp(60px, 8vw, 110px); }
.ab-mv__item { position: relative; }
.ab-mv__item .eyebrow { margin-bottom: 16px; }
.ab-mv__item p { font-weight: 300; font-size: clamp(22px, 2.6vw, 34px); line-height: 1.22; letter-spacing: -.015em; color: var(--fm-ink-900); margin: 0; }
.ab-mv__item p b { font-weight: 700; color: var(--fm-blue-700); }

.ab-values__head { margin-bottom: clamp(28px, 4vw, 46px); }
.ab-values__head h2 { font-weight: 700; font-size: clamp(26px, 3.4vw, 46px); letter-spacing: -.02em; line-height: 1.06; margin: 14px 0 0; }
.ab-values { border-top: 1px solid var(--fm-ink-200); }
.ab-vrow { display: grid; grid-template-columns: 70px minmax(210px, 1fr) 1.4fr; gap: clamp(20px, 4vw, 56px); align-items: center;
  padding: clamp(20px, 2.6vw, 32px) 0; border-bottom: 1px solid var(--fm-ink-100);
  transition: padding-left var(--dur-base) var(--ease-standard); }
.ab-vrow:hover { padding-left: 12px; }
.ab-vrow__num { font-size: 15px; font-weight: 500; letter-spacing: .12em; color: var(--fm-blue-700);
  display: inline-grid; place-items: center; width: 52px; height: 52px; position: relative; }
.ab-vrow__num::before { content: ""; position: absolute; inset: 8px; border: 1px solid var(--fm-ink-300); transform: rotate(45deg); transition: transform .5s var(--ease-standard), border-color var(--dur-base); }
.ab-vrow:hover .ab-vrow__num::before { transform: rotate(135deg); border-color: var(--fm-blue-700); }
.ab-vrow__name { font-size: clamp(24px, 3vw, 40px); font-weight: 800; letter-spacing: -.025em; line-height: 1; }
.ab-vrow__gloss { font-size: 15px; font-weight: 300; line-height: 1.55; color: var(--fm-ink-600); max-width: 42ch; }
@media (max-width: 820px){
  .ab-vrow { grid-template-columns: 52px 1fr; grid-template-areas: "num name" "num gloss"; row-gap: 10px; }
  .ab-vrow__num { grid-area: num; } .ab-vrow__name { grid-area: name; } .ab-vrow__gloss { grid-area: gloss; }
}

/* ============================================================
   SÓCIOS — faixas grandes alternadas, fotos em losango
   ============================================================ */
/* ---------- SÓCIOS — faixas grandes alternadas, fotos em losango ---------- */
#socios .bgword { font-size: clamp(50px, 7.5vw, 124px); top: clamp(22px, 3vw, 36px); }
.ab-prow { position: relative; overflow: hidden; }
.ab-prow .wrap { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(40px, 6vw, 96px); align-items: center; }
.ab-prow--rev .wrap { grid-template-columns: 1.1fr .9fr; }
.ab-prow--rev .ab-pphoto { order: 2; }
.ab-prow--rev .ab-pbody { order: 1; }

.ab-pphoto { position: relative; display: grid; place-items: center; padding: clamp(16px, 3vw, 40px); }
.ab-pphoto__frame { position: relative; width: min(440px, 92%); aspect-ratio: 1; }
.ab-pphoto__frame::before { content: ""; position: absolute; inset: 0; background: var(--fm-blue-100);
  clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%); transform: translate(18px, 18px); transition: transform .5s var(--ease-standard); }
.ab-prow--rev .ab-pphoto__frame::before { transform: translate(-18px, 18px); }
.ab-pphoto:hover .ab-pphoto__frame::before { transform: translate(24px, 24px); }
.ab-prow--rev .ab-pphoto:hover .ab-pphoto__frame::before { transform: translate(-24px, 24px); }
.ab-pphoto__dia { position: absolute; inset: 0; clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%); overflow: hidden; }
.ab-pphoto__dia img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.03);
  transition: filter var(--dur-slow) var(--ease-standard), transform 1.2s var(--ease-standard); }
.ab-pphoto:hover .ab-pphoto__dia img { filter: grayscale(0); transform: scale(1.04); }

.ab-pbody .eyebrow { margin-bottom: 12px; }
.ab-pbody h2 { font-weight: 800; font-size: clamp(30px, 4vw, 56px); letter-spacing: -.025em; line-height: 1; margin: 0; }
.ab-pbody__role { font-size: 12.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--fm-ink-500); margin-top: 12px; display: block; }
.ab-pbody__areas { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 500; letter-spacing: .04em;
  color: var(--fm-blue-700); margin-top: 14px; }
.ab-pbody__areas .d { width: 8px; height: 8px; background: var(--fm-blue-700); transform: rotate(45deg); }
.ab-pbody__bio { font-size: clamp(15px, 1.3vw, 17px); font-weight: 300; line-height: 1.65; color: var(--fm-ink-700); max-width: 48ch; margin: 22px 0 0; }
.ab-pbody__bio p { margin: 0 0 14px; }
.ab-pbody__cta { margin-top: 12px; }

/* ============================================================
   LOCALIZAÇÃO
   ============================================================ */
.ab-local .wrap { display: grid; grid-template-columns: .95fr 1.05fr; gap: clamp(40px, 6vw, 90px); align-items: center; }
.ab-local h2 { font-weight: 300; font-size: clamp(28px, 3.8vw, 52px); line-height: 1.08; letter-spacing: -.02em; margin: 16px 0 0; }
.ab-local h2 b { font-weight: 800; }
.ab-local__addr { font-size: 16px; line-height: 1.9; color: var(--fm-ink-700); margin: 26px 0 0; }
.ab-local__addr b { color: var(--fm-ink-900); font-weight: 600; }
.ab-local__list { list-style: none; padding: 0; margin: 26px 0 0; display: grid; gap: 12px; }
.ab-local__list li { display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: start; font-size: 14.5px; color: var(--fm-ink-700); line-height: 1.5; }
.ab-local__list li::before { content: ""; width: 8px; height: 8px; background: var(--fm-blue-700); transform: rotate(45deg); margin-top: 6px; }
.ab-local__list li.ab-local__link::before { margin-top: 10px; }
.ab-local__list a { color: var(--fm-blue-700); font-weight: 500; border-bottom: none; text-decoration: none;
  display: inline-flex; align-items: center; gap: 8px; transition: color var(--dur-base); }
.ab-local__list a:hover { color: var(--fm-blue-800); text-decoration: underline; text-underline-offset: 3px; }
.ab-local__list a .arr { transition: transform var(--dur-base) var(--ease-standard); }
.ab-local__list a:hover .arr { transform: translateX(4px); }
.ab-local__actions { margin-top: 30px; display: flex; gap: 14px; flex-wrap: wrap; }
.ab-map { position: relative; aspect-ratio: 4/3.4; overflow: hidden; background: var(--fm-blue-900); box-shadow: var(--shadow-lg); }
.ab-map image-slot, .ab-map__slot { display: block; width: 100%; height: 100%; }
.ab-map__frame { width: 100%; height: 100%; border: 0; display: block; }
.ab-map__pin { position: absolute; left: 50%; top: 46%; z-index: 2; transform: translate(-50%, -50%); pointer-events: none; }
.ab-map__pin .dot { width: 18px; height: 18px; background: var(--fm-blue-700); border: 3px solid #fff; transform: rotate(45deg); box-shadow: 0 6px 18px rgba(6,9,54,.4); }

/* ============================================================
   CTA (azul)
   ============================================================ */
.ab-cta { text-align: center; position: relative; overflow: hidden; }
.ab-cta .bgword { -webkit-text-stroke-color: rgba(255,255,255,.12); top: clamp(20px, 3vw, 32px); right: clamp(12px, 3vw, 40px); font-size: clamp(50px, 7.5vw, 124px); }
.ab-cta__inner { max-width: 720px; margin-inline: auto; position: relative; z-index: 1; }
.ab-cta h2 { font-weight: 300; font-size: clamp(28px, 3.6vw, 50px); line-height: 1.08; letter-spacing: -.02em; margin: 16px 0 14px; color: #fff; }
.ab-cta h2 b { font-weight: 800; }
.ab-cta p { color: rgba(255,255,255,.82); font-size: 17px; font-weight: 300; margin: 0 0 30px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 940px){
  .ab-hero__grid { grid-template-columns: 1fr; gap: 44px; }
  .ab-mv { grid-template-columns: 1fr; gap: 36px; }
  .ab-prow .wrap, .ab-prow--rev .wrap { grid-template-columns: 1fr; gap: 40px; }
  .ab-prow--rev .ab-pphoto, .ab-prow--rev .ab-pbody { order: 0; }
  .ab-local .wrap { grid-template-columns: 1fr; gap: 40px; }
  .ab-map { order: 2; }
}
@media (max-width: 680px){
  .ab-local__actions .btn { width: 100%; justify-content: center; }
}
