/* ===================================================================
   FAYMONT — Site (camada de layout, multipágina)
   Liga junto com styles.css (tokens + componentes da marca).
   Compartilhado por todas as páginas do site institucional.
   =================================================================== */

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-sans);color:var(--text-body);background:var(--surface-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:var(--lh-body)}

/* faixa 58/42 */
.bar{display:flex;height:6px;width:100%}
.bar i{display:block;height:100%}.bar i:first-child{width:58%;background:var(--azul-600)}.bar i:last-child{width:42%;background:var(--verde-600)}

/* layout base */
.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--gutter)}
.container--narrow{max-width:820px}
.section{padding:var(--section-y) 0}
.section--mist{background:var(--surface-subtle)}
.section--section{background:var(--surface-section)}
.section--brand{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--azul-600),var(--azul-900));color:#fff}
.sticky{position:sticky;top:0;z-index:50}

/* tipografia utilitária */
.eyebrow-row{margin-bottom:18px}
.h-display{font-family:var(--font-serif);font-size:4.6rem;font-weight:var(--weight-medium);line-height:1.12;letter-spacing:var(--tracking-tight);color:var(--azul-600);margin:0 0 .2em}
@media(max-width:1100px){.h-display{font-size:3.7rem}}
@media(max-width:600px){.h-display{font-size:2.7rem}}
.h2{font-family:var(--font-serif);font-size:var(--text-h2);font-weight:var(--weight-medium);line-height:var(--lh-snug);letter-spacing:var(--tracking-snug);color:var(--azul-600);margin:0}
.h2--light{color:#fff}
.lead{font-size:var(--text-body-lg);color:var(--text-muted);line-height:1.6;max-width:54ch;margin:18px 0 0}
.lead--light{color:var(--text-on-brand-soft)}
.muted{color:var(--text-muted)}
.center{text-align:center}
.section__head{max-width:60ch}
.section__head--center{margin:0 auto;text-align:center}

/* prosa de leitura */
.prose{max-width:65ch}
.prose p{font-size:1.05rem;color:var(--text-body);line-height:1.72;margin:1.05rem 0}
.prose p:first-child{margin-top:0}
.prose strong{color:var(--text-strong)}

/* ===== HOME hero (imagem) ===== */
.hero{position:relative;overflow:hidden;background:var(--surface-subtle);display:flex;align-items:center;min-height:clamp(560px,82vh,760px)}
.hero>.container{width:100%}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:70% 32%;filter:saturate(.97)}
.hero__scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(100deg,rgba(232,238,245,.98) 0%,rgba(232,238,245,.92) 28%,rgba(232,238,245,.55) 50%,rgba(232,238,245,.12) 70%,rgba(232,238,245,0) 86%),linear-gradient(0deg,rgba(232,238,245,.6) 0%,transparent 24%)}
.hero__inner{position:relative;z-index:2;padding:clamp(3rem,6vw,5rem) 0;max-width:44ch}
@media(max-width:760px){.hero{min-height:auto;align-items:stretch}.hero__media img{object-position:64% 22%}.hero__scrim{background:linear-gradient(180deg,rgba(232,238,245,.97) 0%,rgba(232,238,245,.88) 42%,rgba(232,238,245,.55) 72%,rgba(232,238,245,.2) 100%)}}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}
.hero__trust{display:flex;gap:30px;flex-wrap:wrap;margin-top:48px;padding-top:26px;border-top:1px solid var(--border-subtle)}
.trust__num{font-family:var(--font-serif);font-size:2rem;font-weight:var(--weight-semibold);color:var(--azul-600);line-height:1}
.trust__lbl{font-size:var(--text-caption);color:var(--text-muted);margin-top:5px;max-width:18ch}

/* ===== Page hero (páginas internas) ===== */
.page-hero{position:relative;overflow:hidden;background:var(--surface-subtle);padding:clamp(3rem,6vw,4.6rem) 0 clamp(2.6rem,5vw,3.6rem)}
.page-hero::before{content:"";position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(var(--veu-azul) 1px,transparent 1px),linear-gradient(90deg,var(--veu-azul) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(680px 460px at 88% -10%,#000,transparent 72%)}
.page-hero__wm{position:absolute;right:-4%;top:-30%;width:34%;max-width:430px;opacity:.06;transform:rotate(-8deg);pointer-events:none}
.page-hero__wm img{width:100%;display:block}
.page-hero .container{position:relative;z-index:1}
.page-hero__inner{max-width:50ch}
.page-title{font-family:var(--font-serif);font-size:clamp(2.6rem,4.6vw,3.7rem);font-weight:var(--weight-medium);line-height:1.1;letter-spacing:-.02em;color:var(--azul-600);margin:0 0 .12em}
.breadcrumb{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);margin-bottom:20px;display:flex;align-items:center;gap:9px}
.breadcrumb a{color:var(--azul-600);text-decoration:none}
.breadcrumb a:hover{color:var(--verde-700)}
.breadcrumb span{opacity:.5}

/* grids */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:42px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:42px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:42px}
@media(max-width:880px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}.grid-2{grid-template-columns:1fr}}
@media(max-width:560px){.grid-3,.grid-4{grid-template-columns:1fr}}

/* feature band (declaração) */
.feature__inner{position:relative;z-index:1;max-width:60ch}
.feature__quote{font-family:var(--font-serif);font-size:clamp(1.7rem,3.2vw,2.5rem);font-style:italic;line-height:1.32;margin:18px 0 0;color:#fff}
.feature__quote b{font-style:normal;font-weight:var(--weight-semibold);color:#fff}
.feature__wm{position:absolute;right:-40px;bottom:-70px;width:300px;opacity:.08;filter:brightness(3);transform:rotate(-8deg)}

/* CTA band reutilizável */
.cta-band__inner{position:relative;z-index:1;max-width:56ch;margin:0 auto;text-align:center}
.cta-band__inner .h2{margin-bottom:14px}
.cta-band__inner .hero__cta{justify-content:center;margin-top:28px}

/* ===== processo vertical (Como atuamos) ===== */
.process{margin-top:46px}
.process__step{position:relative;display:grid;grid-template-columns:60px 1fr;gap:26px;padding-bottom:36px}
.process__rail{display:flex;flex-direction:column;align-items:center}
.process__node{width:56px;height:56px;border-radius:50%;border:1.5px solid var(--azul-600);color:var(--azul-600);display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:1.4rem;font-weight:var(--weight-semibold);background:#fff;flex-shrink:0}
.process__line{flex:1;width:1.5px;background:var(--border-brand);margin-top:8px}
.process__step:last-child{padding-bottom:0}
.process__step:last-child .process__line{display:none}
.process__t{font-family:var(--font-serif);font-size:var(--text-h3);color:var(--azul-600);font-weight:var(--weight-medium);margin:10px 0 0}
.process__meta{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--bronze-600);margin-top:4px}
.process__d{color:var(--text-muted);font-size:1rem;line-height:1.62;margin:12px 0 0;max-width:56ch}
.process__tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}

/* listas com tique (Para quem é / não é) */
.split-list{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:36px}
@media(max-width:760px){.split-list{grid-template-columns:1fr}}
.list-card{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-soft)}
.list-card--no{background:var(--surface-subtle)}
.list-card__h{font-family:var(--font-serif);font-size:1.5rem;color:var(--azul-600);font-weight:var(--weight-medium);margin:0 0 4px;display:flex;align-items:center;gap:10px}
.list-card__sub{font-size:.9rem;color:var(--text-muted);margin:0 0 6px}
.ticklist{list-style:none;padding:0;margin:16px 0 0;display:flex;flex-direction:column;gap:13px}
.ticklist li{display:flex;gap:12px;align-items:flex-start;font-size:.96rem;color:var(--text-body);line-height:1.5}
.tick{width:22px;height:22px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px}
.tick--yes{background:rgba(0,137,60,.13);color:var(--verde-700)}
.tick--no{background:rgba(161,46,46,.10);color:#a12e2e}
.tick svg{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}

/* timeline (Sobre) */
.timeline{margin-top:42px;border-left:1.5px solid var(--border-brand);padding-left:32px;display:flex;flex-direction:column;gap:30px}
.timeline__item{position:relative}
.timeline__item::before{content:"";position:absolute;left:-39px;top:5px;width:11px;height:11px;background:var(--azul-600);border-radius:50%;box-shadow:0 0 0 3px #fff,0 0 0 6px var(--mist)}
.timeline__year{font-family:var(--font-mono);font-size:12px;color:var(--bronze-600);letter-spacing:.08em}
.timeline__t{font-family:var(--font-serif);font-size:1.4rem;color:var(--azul-600);font-weight:var(--weight-medium);margin:3px 0 6px}
.timeline__d{color:var(--text-muted);font-size:.98rem;line-height:1.6;max-width:58ch;margin:0}

/* sócios */
.socio{display:flex;gap:22px;align-items:center}
.socio__photo{width:124px;height:124px;border-radius:var(--radius-lg);flex-shrink:0;overflow:hidden;border:1px solid var(--border-subtle);box-shadow:var(--shadow-soft);background:var(--mist-claro)}
.socio__photo picture{display:block;width:100%;height:100%}
.socio__photo img{width:100%;height:100%;object-fit:cover;object-position:center 16%;display:block;filter:saturate(.96)}
.socio__name{font-family:var(--font-serif);font-size:var(--text-h3);color:var(--azul-600);font-weight:var(--weight-medium);margin:0}
.socio__role{font-size:var(--text-small);color:var(--text-muted);margin:5px 0 0;line-height:1.5}
.socio--lg{flex-direction:column;align-items:flex-start;gap:18px}
.socio--lg .socio__photo{width:100%;height:280px;border-radius:var(--radius-xl)}
.socio--lg .socio__photo img{object-position:center 14%}

/* client showcase */
.showcase{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:26px}
@media(max-width:760px){.showcase{grid-template-columns:1fr}}
.showcase__item{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);aspect-ratio:16/10}
.showcase__item picture{position:absolute;inset:0;display:block}
.showcase__item img{width:100%;height:100%;object-fit:cover;filter:saturate(.9)}
.showcase__cap{position:absolute;left:0;right:0;bottom:0;z-index:1;padding:30px 20px 17px;background:linear-gradient(0deg,rgba(2,13,42,.84) 5%,rgba(2,13,42,.35) 55%,transparent);color:#fff}
.showcase__cap b{font-family:var(--font-serif);font-size:1.3rem;font-weight:var(--weight-medium);display:block;line-height:1.15}
.showcase__cap span{font-size:.8rem;opacity:.88;display:block;margin-top:3px}

/* contato */
.contact-head{max-width:60ch;margin-bottom:38px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:stretch}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:24px}}
.contact-visual{position:relative;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-card);min-height:440px;display:flex}
.contact-visual picture{position:absolute;inset:0;display:block}
.contact-visual img{width:100%;height:100%;object-fit:cover;object-position:center 84%;filter:saturate(.92)}
.contact-visual__scrim{position:absolute;inset:0;background:linear-gradient(0deg,rgba(2,13,42,.94) 0%,rgba(2,13,42,.7) 32%,rgba(2,13,42,.32) 60%,rgba(0,65,102,.12) 100%)}
.contact-visual__body{position:relative;z-index:1;margin-top:auto;padding:28px;color:#fff;width:100%;text-shadow:0 1px 3px rgba(2,13,42,.55)}
.contact-visual__loc{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-on-brand-soft);margin:0 0 16px;display:flex;align-items:center;gap:9px}
.contact-visual__loc::before{content:"";width:22px;height:1px;background:currentColor}
.form-card{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:30px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:480px){.form-row{grid-template-columns:1fr}}
.channels{display:flex;flex-direction:column;gap:14px;margin-top:24px}
.channel{display:flex;align-items:center;gap:12px;color:var(--azul-600);text-decoration:none;font-weight:var(--weight-medium);font-size:var(--text-small)}
.channel svg{width:20px;height:20px;stroke:var(--verde-700);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.channels .channel--light{color:#fff}
.channels .channel--light svg{stroke:var(--text-on-brand-soft)}

/* divisor losango */
.divider-diamond{display:flex;align-items:center;gap:14px;max-width:280px;margin:0 auto}
.divider-diamond i{flex:1;height:1px;background:var(--border-brand)}
.divider-diamond b{width:8px;height:8px;background:var(--azul-600);transform:rotate(45deg)}

/* estados (404 / obrigado) */
.empty{min-height:78vh;display:flex;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden;background:var(--surface-subtle)}
.empty::before{content:"";position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(var(--veu-azul) 1px,transparent 1px),linear-gradient(90deg,var(--veu-azul) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(620px 480px at 50% 0,#000,transparent 70%)}
.empty__wm{position:absolute;right:-6%;bottom:-16%;width:42%;max-width:520px;opacity:.06;transform:rotate(-8deg);pointer-events:none}
.empty__wm img{width:100%;display:block}
.empty__inner{position:relative;z-index:1;max-width:54ch;padding:60px 24px}
.empty__code{font-family:var(--font-serif);font-size:clamp(5rem,14vw,9rem);color:var(--azul-600);line-height:1;font-weight:var(--weight-semibold);letter-spacing:-.03em}
.empty .hero__cta{justify-content:center;margin-top:30px}
.success-badge{width:84px;height:84px;border-radius:50%;background:rgba(0,137,60,.12);color:var(--verde-700);display:flex;align-items:center;justify-content:center;margin:0 auto 26px}
.success-badge svg{width:40px;height:40px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.next-steps{display:flex;flex-direction:column;gap:14px;margin:30px auto 0;max-width:420px;text-align:left}
.next-steps__item{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:14px 16px;box-shadow:var(--shadow-xs)}
.next-steps__n{font-family:var(--font-mono);font-size:12px;color:var(--bronze-600);font-weight:600;margin-top:2px}
.next-steps__t{font-size:.95rem;color:var(--text-body);line-height:1.5}

/* navbar — menu mobile */
.nav-mobile{display:none}
@media(max-width:860px){
  .nav-mobile{display:block;background:#fff;border-bottom:1px solid var(--border-subtle);padding:6px var(--gutter) 20px;animation:navdrop .25s var(--ease-out)}
  .nav-mobile a.nav-mobile__link{display:block;padding:13px 0;font-size:1.02rem;color:var(--azul-600);text-decoration:none;border-bottom:1px solid var(--border-subtle);font-weight:var(--weight-medium)}
  .nav-mobile a.nav-mobile__link:last-of-type{border-bottom:none}
  .nav-mobile__link--active{color:var(--verde-700)}
  .nav-mobile .fay-btn{margin-top:16px;width:100%}
}
@keyframes navdrop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* crédito de desenvolvimento */
.fay-footer__credit{display:block;margin-top:.55rem}
.fay-footer__credit a{display:inline;color:rgba(255,255,255,.7);text-decoration:none;letter-spacing:.04em}
.fay-footer__credit a:hover{color:#fff;text-decoration:underline}
