/* =====================================================================
   Raízes — Folha de estilo única do site
   Fonte da verdade visual: design-system-raizes.html (NÃO alterar lá).
   Este arquivo é a extração 1:1 do <style> do design system + alguns
   componentes de página (carrossel "5 portas", FAQ) construídos no
   mesmo traço da marca. Não inventar estilos fora dos tokens abaixo.
   As fontes do Google são carregadas em partials/head.html.
   ===================================================================== */

:root{
  --creme:#F2EBDD; --grafite:#1A1E1C; --laranja:#FF9E00;
  --papel:#FBF7EF; --creme2:#ECE3D1; --areia:#E2D6BE; --areia-escura:#D6C7A8; --linha:#DDD0B8;
  --g900:#111413; --g700:#262B28; --g400:#5A625D; --g300:#89918C;
  --brico:'Bricolage Grotesque',sans-serif; --plex:'IBM Plex Sans',sans-serif; --inst:'Instrument Serif',serif;
  --r-sm:14px; --r-md:20px; --r-lg:28px; --r-pill:50px;
  --wrap:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--creme);color:var(--grafite);font-family:var(--plex);font-size:18px;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:clip}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
section[id]{scroll-margin-top:90px}

/* ---------- Typography ---------- */
.h1{font-family:var(--brico);font-weight:800;font-size:clamp(56px,8.5vw,104px);line-height:.98;letter-spacing:-.03em;margin:0}
.h2{font-family:var(--brico);font-weight:800;font-size:clamp(40px,6vw,64px);line-height:1.02;letter-spacing:-.02em;margin:0}
.h3{font-family:var(--brico);font-weight:700;font-size:44px;line-height:1.1;letter-spacing:-.01em;margin:0}
.sub1{font-family:var(--brico);font-weight:700;font-size:32px;line-height:1.2;margin:0}
.sub2{font-family:var(--brico);font-weight:600;font-size:24px;line-height:1.3;margin:0}
.sub3{font-family:var(--brico);font-weight:600;font-size:20px;line-height:1.35;margin:0}
.bodyL{font-size:20px;line-height:1.6}
.bodyM{font-size:18px;line-height:1.6}
.bodyS{font-size:16px;line-height:1.6}
.boldM{font-size:18px;line-height:1.6;font-weight:600}
.caption{font-size:14px;line-height:1.45}
.eyebrow{font-family:var(--plex);font-weight:600;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--laranja)}
.accent{color:var(--laranja)}
.muted{color:var(--g400)}

/* ---------- Layout ---------- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 32px}
.section{padding:104px 0}
.section-tight{padding:72px 0}
.sec-head{max-width:760px;margin-bottom:56px}
.sec-head .h2{margin:14px 0 0}
.sec-head .lead{margin:18px 0 0;font-size:20px;line-height:1.6;color:var(--g400)}
.block-title{margin:56px 0 24px}
.divider{height:1px;background:var(--linha);border:0;margin:0}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:100;background:rgba(242,235,221,.82);backdrop-filter:saturate(140%) blur(10px)}
.nav-in{max-width:var(--wrap);margin:0 auto;padding:14px 32px;display:flex;align-items:center;gap:24px}
.nav-logo{height:30px;width:auto;margin-right:auto}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:16px;font-weight:500;color:var(--g700);transition:color .2s}
.nav-links a:hover{color:var(--grafite)}
.nav-links .nav-cta-mobile{display:none}
.nav-toggle{display:none;align-items:center;justify-content:center;flex-direction:column;gap:5px;width:46px;height:46px;border:none;border-radius:13px;background:var(--grafite);cursor:pointer;justify-self:end}
.nav-toggle span{display:block;width:19px;height:2px;background:var(--creme);border-radius:2px;transition:transform .3s cubic-bezier(.5,0,.2,1),opacity .2s}
@media(max-width:920px){
  .nav .nav-in{display:flex;justify-content:space-between;align-items:center}
  .nav .nav-in>.btn{display:none}
  .nav-toggle{display:flex}
  .nav-links{
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
    position:fixed;left:10px;right:10px;top:74px;
    height:calc(100dvh - 84px);z-index:120;
    background:var(--papel);border:1.5px solid var(--linha);border-radius:var(--r-lg);
    box-shadow:0 24px 48px -28px rgba(26,30,28,.5);
    padding:32px 24px;
    opacity:0;visibility:hidden;transform:translateY(-10px);
    transition:opacity .28s ease,transform .28s ease,visibility .28s
  }
  .nav.open .nav-links{opacity:1;visibility:visible;transform:none}
  .nav-links a{font-size:24px;color:var(--grafite);padding:18px 0;text-align:center;border:none}
  .nav-links .nav-cta-mobile{display:inline-flex;justify-content:center;margin-top:24px}
  .nav.open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.open .nav-toggle span:nth-child(2){opacity:0}
  .nav.open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ---------- Buttons (text-slide hover, like the reference) ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--plex);font-weight:600;font-size:16px;
  border-radius:var(--r-pill);padding:18px 30px;cursor:pointer;border:1.5px solid var(--grafite);
  background:var(--grafite);color:var(--creme);transition:transform .25s,box-shadow .25s,background .2s,color .2s}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 0 -4px rgba(26,30,28,.15)}
.btn .slide{display:block;height:1.4em;overflow:hidden;position:relative}
.btn .slide span{display:block;height:1.4em;transition:transform .32s cubic-bezier(.5,0,.2,1)}
.btn:hover .slide span{transform:translateY(-100%)}
.btn-orange{background:var(--laranja);border-color:var(--laranja);color:var(--grafite)}
.btn-outline{background:transparent;color:var(--grafite)}
.btn-cream{background:var(--creme);border-color:var(--creme);color:var(--grafite)}
.btn .leaf{width:15px;height:16px}
.read-more{display:inline-flex;align-items:center;gap:10px;background:transparent;border:0;padding:0;
  font-family:var(--plex);font-weight:600;font-size:18px;color:var(--grafite);cursor:pointer}
.read-more .leaf{width:16px;height:17px;transition:transform .3s}
.read-more:hover .leaf{transform:translateX(5px) rotate(8deg)}

/* ---------- Hero ---------- */
.hero{position:relative;text-align:center;padding:52px 0 56px;overflow:visible}
.hero .wrap{position:relative;z-index:1}
.hero .eyebrow{display:block;margin-bottom:18px}
.hero .h1{max-width:14ch;margin:0 auto;color:var(--grafite)}
.hero .lead{max-width:540px;margin:22px auto 34px;font-size:20px;color:var(--g400)}
.hero-leaves{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:visible}
.leaf-deco{position:absolute}
.leaf-deco svg{display:block;width:100%;height:auto;fill:#E7DBC6}
.hl1{width:148px;top:9%;left:4%;transform:rotate(-18deg)}
.hl1 svg{animation:rz-float 6s ease-in-out infinite}
.hl2{width:96px;bottom:-10%;left:9%;transform:rotate(13deg)}
.hl2 svg{animation:rz-float 7.5s ease-in-out 1.1s infinite}
.hl3{width:210px;bottom:-22%;right:5%;transform:rotate(23deg)}
.hl3 svg{animation:rz-float 6.5s ease-in-out .5s infinite}
.hl4{width:104px;top:12%;right:7%;transform:rotate(-33deg)}
.hl4 svg{animation:rz-float 8s ease-in-out 1.6s infinite}
@media(max-width:820px){.hero-leaves{display:none}}

@keyframes rz-sprout{0%{opacity:0;transform:translateY(34px) scale(.6) rotate(-6deg)}100%{opacity:1;transform:translateY(0) scale(1) rotate(0)}}
@keyframes rz-sway{0%,100%{transform:rotate(-6deg)}50%{transform:rotate(6deg)}}
@keyframes rz-pulse{0%,100%{transform:scale(.85);opacity:.9}50%{transform:scale(1.12);opacity:.4}}
@keyframes rz-float{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-18px) rotate(4deg)}}

/* ---------- Cards / swatches / chips ---------- */
.grid{display:grid;gap:24px}
.cards-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.card{background:var(--papel);border:1.5px solid var(--grafite);border-radius:var(--r-lg);padding:30px;box-shadow:8px 8px 0 0 var(--grafite);transition:transform .25s,box-shadow .25s}
.card:hover{transform:translate(4px,4px);box-shadow:0 0 0 0 var(--grafite)}
.card .sub2{margin-bottom:10px}
.card .tag{color:var(--laranja);font-weight:600;font-size:14px;letter-spacing:.04em}

.swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:20px}
.sw-chip{height:118px;border-radius:var(--r-sm);border:1px solid rgba(26,30,28,.12)}
.sw-name{font-weight:600;font-size:16px;margin-top:14px}
.sw-hex{font-size:13px;color:var(--g400);font-family:var(--plex);letter-spacing:.02em}
.sw-use{font-size:13px;color:var(--g400);margin-top:2px}

.chips{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.chip{border:1px solid var(--grafite);border-radius:var(--r-pill);padding:8px 20px;font-size:14px;font-weight:500}
.chip-solid{background:var(--grafite);color:var(--creme);border-color:var(--grafite)}
.chip-orange{background:var(--laranja);border-color:var(--laranja);color:var(--grafite)}

/* surfaces */
.surface{height:120px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:15px;border:1px solid rgba(26,30,28,.10)}
.surf-dark{background:var(--grafite);color:var(--creme)}
.surf-grad{background:linear-gradient(140deg,var(--grafite),var(--g700) 45%,var(--laranja) 145%);color:var(--creme)}

/* ---------- Typography spec list ---------- */
.type-list{border-top:1px solid var(--linha)}
.type-item{padding:28px 0;border-bottom:1px solid var(--linha)}
.type-head{display:flex;justify-content:space-between;align-items:baseline;gap:20px;margin-bottom:16px;flex-wrap:wrap}
.type-name{font-weight:600;font-size:15px}
.type-spec{font-size:13px;color:var(--g400);white-space:nowrap}
.type-class{display:inline-block;margin-top:16px;font-size:12px;color:var(--g300)}

/* ---------- Layout rulers ---------- */
.ruler-row{margin-top:18px}
.ruler-label{font-size:13px;color:var(--g400);margin-bottom:6px}
.track{background:rgba(26,30,28,.07);border-radius:8px;width:100%}
.bar{height:32px;border-radius:8px;background:rgba(255,158,0,.20);border:1px dashed var(--laranja)}
.pad-track{background:rgba(26,30,28,.07);border-radius:8px;overflow:hidden;margin-top:6px}
.pad-fill{background:rgba(255,158,0,.28)}

/* ---------- Motion gallery ---------- */
.motion-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}
.m-card{background:var(--papel);border:1.5px solid var(--grafite);border-radius:var(--r-lg);padding:26px;min-height:200px;display:flex;flex-direction:column;box-shadow:6px 6px 0 0 var(--grafite)}
.m-demo{margin-top:auto;padding-top:22px;display:flex;align-items:center;justify-content:center;min-height:80px}
.lift{width:84px;height:84px;border-radius:var(--r-md);background:var(--areia);border:1.5px solid var(--grafite);display:flex;align-items:center;justify-content:center;box-shadow:7px 7px 0 0 var(--grafite);transition:transform .25s,box-shadow .25s}
.lift:hover{transform:translate(4px,4px);box-shadow:0 0 0 0 var(--grafite)}
.counter{font-family:var(--brico);font-weight:800;font-size:64px;line-height:1;color:var(--grafite)}
.marquee{overflow:hidden;border-top:1px solid var(--linha);border-bottom:1px solid var(--linha);padding:26px 0;margin-top:8px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;gap:56px;width:max-content;animation:rz-marq 22s linear infinite}
.marquee-track .h3{color:var(--g400);white-space:nowrap}
.marquee-track .dot{color:var(--laranja)}
@keyframes rz-marq{to{transform:translateX(-50%)}}

/* ---------- Icons ---------- */
.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:32px 20px}
.icon-cell{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}
.icon-cell svg{width:72px;height:72px;border-radius:50%;box-shadow:5px 5px 0 0 var(--grafite);transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s}
.icon-cell:nth-child(4n+1) svg{transform:rotate(-7deg)}
.icon-cell:nth-child(4n+2) svg{transform:rotate(5deg)}
.icon-cell:nth-child(4n+3) svg{transform:rotate(-3deg)}
.icon-cell:nth-child(4n) svg{transform:rotate(6deg)}
.icon-cell:hover svg{transform:rotate(0deg) translateY(-4px) scale(1.05);box-shadow:8px 10px 0 0 var(--grafite)}
.icon-cell span{font-size:13px;color:var(--g400);font-weight:500;transition:color .3s}
.icon-cell:hover span{color:var(--grafite)}
.gl-cream{stroke:var(--creme);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.gl-dark{stroke:var(--grafite);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.gl-acc{fill:var(--laranja);stroke:none}
.gl-acc-s{stroke:var(--laranja);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.gl-cream-f{fill:var(--creme);stroke:none}
.gl-dark-f{fill:var(--grafite);stroke:none}
.brand-symbols{display:flex;gap:20px;flex-wrap:wrap;margin-top:8px}
.brand-symbols .bs{flex:1;min-width:150px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;height:150px}
.brand-symbols img{height:96px;width:auto}

/* ---------- Process cards + focus list (detalhes do index.html) ---------- */
.line-rule{height:1.5px;background:var(--grafite);width:100%;border:0}
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:40px 28px}
.feature-card{background:var(--papel);border:1.5px solid var(--grafite);border-radius:var(--r-lg);padding:32px 26px;box-shadow:8px 8px 0 0 var(--grafite);transition:transform .25s,box-shadow .25s}
.feature-card:hover{transform:translate(4px,4px);box-shadow:0 0 0 0 var(--grafite)}
.feat-icon{width:62px;height:62px;margin-bottom:24px;border:1.5px solid var(--grafite);border-radius:50%;background:var(--laranja);display:flex;align-items:center;justify-content:center;box-shadow:5px 5px 0 0 var(--grafite);transition:transform .25s,box-shadow .25s}
.feature-card:hover .feat-icon{transform:translate(-2px,-2px);box-shadow:7px 7px 0 0 var(--grafite)}
.feat-icon svg{width:30px;height:30px}
.feat-step{font-family:var(--plex);font-weight:600;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--g400);margin-bottom:6px}
.feat-list{list-style:none;margin:18px 0 0;padding:0;display:flex;flex-direction:column;gap:11px}
.feat-list li{position:relative;padding-left:26px;font-size:15px;color:var(--g400);line-height:1.5}
.feat-list li::before{content:"";position:absolute;left:0;top:6px;width:12px;height:12px;background:var(--laranja);border:1.3px solid var(--grafite);border-radius:50% 50% 50% 2px;transform:rotate(8deg)}
.svc-section{position:relative;background:var(--grafite);color:var(--creme);padding:152px 0;overflow:hidden}
.svc-inner{position:relative;max-width:1180px;margin:0 auto;padding:0 32px;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.svc-left{position:relative}
.svc-left .h3{color:var(--creme);margin:0}
.svc-left .lead{color:var(--g300);margin:18px 0 30px;max-width:380px}
.svc-list{display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.svc-link{font-family:var(--brico);font-weight:800;font-size:38px;line-height:1.12;color:var(--creme);cursor:pointer;transition:filter .35s,color .25s,transform .25s,opacity .35s}
.svc-link:hover{color:var(--laranja);filter:blur(0);opacity:1;transform:translateX(10px)}
.b3{filter:blur(3px);opacity:.85}.b6{filter:blur(6px);opacity:.6}.b12{filter:blur(12px);opacity:.45}
.svc-arrow{position:absolute;right:-1%;bottom:-10px;width:258px;height:auto;pointer-events:none}
.svc-arrow path{stroke:var(--laranja);stroke-width:3.2;fill:none;stroke-linecap:round;stroke-linejoin:round}
@media(max-width:820px){.svc-inner{grid-template-columns:1fr;gap:30px}.svc-link{font-size:28px}.svc-arrow{display:none}}

/* ---------- Heading accent (sticker no título) — documentação ---------- */
.acc-ex{display:flex;flex-direction:column;gap:24px;margin-top:8px}
.acc-ex .h3{display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;margin:0}
.kw-leaf{height:.6em;width:auto;transform:rotate(16deg)}
.kw-tag{font-family:var(--plex);font-weight:600;font-size:14px;letter-spacing:.06em;text-transform:uppercase;background:var(--laranja);color:var(--grafite);border:1.5px solid var(--grafite);border-radius:50px;padding:6px 15px;transform:rotate(-3deg);line-height:1}
.dodont{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;margin-top:36px}
.dd{display:flex;gap:14px;align-items:flex-start;padding:18px 20px;border:1.5px solid var(--grafite);border-radius:var(--r-md);background:var(--papel);box-shadow:5px 5px 0 0 var(--grafite)}
.dd-tag{font-family:var(--plex);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase;border:1.5px solid var(--grafite);border-radius:50px;padding:5px 13px;white-space:nowrap;flex:none}
.dd-do .dd-tag{background:var(--laranja);color:var(--grafite)}
.dd-dont .dd-tag{background:transparent;color:var(--g400)}
.dd p{margin:0;font-size:15px;line-height:1.5}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Footer ---------- */
.footer{background:var(--grafite);color:var(--creme);padding:80px 0 56px;margin-top:0}
.footer-logo{height:50px;width:auto;display:block;margin:0 0 48px}
.footer .cols{display:flex;justify-content:space-between;gap:32px;flex-wrap:wrap;align-items:center;border-top:1px solid var(--g700);padding-top:36px}
.footer .muted{color:var(--g300)}
.foot-mark{display:inline-flex;align-items:center;gap:10px;color:var(--g300);font-size:14px}
.foot-mark img{width:18px;height:18px}

@media(max-width:700px){
  .section{padding:72px 0}
  .wrap,.nav-in{padding-left:20px;padding-right:20px}
  .h3{font-size:34px}
}

/* =====================================================================
   COMPOSIÇÕES DE PÁGINA (home) — apenas o "encaixe" de layout que arruma
   os componentes do DS em seções. Sem estilo novo: cores/fontes/sombra
   offset vêm dos tokens. Pequenos incrementos só onde a copy autoriza.
   ===================================================================== */

/* ---------- Tira de confiança (faixa de números, slim) ----------
   Compõe o contador (.counter) do DS em blocos com a sombra offset. */
.trust{padding:48px 0 92px}
.trust-head{text-align:center;margin-top:40px}
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:24px}
.trust-item{background:var(--papel);border:1.5px solid var(--grafite);border-radius:var(--r-md);box-shadow:6px 6px 0 0 var(--grafite);padding:28px 22px;text-align:center;transition:transform .25s,box-shadow .25s}
.trust-item:hover{transform:translate(3px,3px);box-shadow:3px 3px 0 0 var(--grafite)}
.trust-num{font-family:var(--brico);font-weight:800;font-size:clamp(38px,4.4vw,52px);line-height:1;color:var(--grafite);margin:0}
.trust-num .counter{font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;color:inherit}
.trust-label{font-size:14px;line-height:1.45;color:var(--g400);margin:10px 0 0}

/* ---------- "Em foco" (serviços) — incremento sancionado pela copy:
   a descrição já ocupa o espaço dela (sem mudar o tamanho do bloco no
   hover); ao passar o mouse ela só faz fade-in. ---------- */
.svc-link .svc-desc{display:block;font-family:var(--plex);font-weight:400;font-size:15px;line-height:1.45;color:var(--g300);
  max-width:38ch;opacity:0;margin-top:8px;transition:opacity .3s ease}
.svc-link:hover .svc-desc{opacity:1}

/* ---------- FAQ / acordeão (extraído 1:1 do design system) ---------- */
.faq-list{display:flex;flex-direction:column;gap:16px;max-width:840px}
.faq-item{background:var(--papel);border:1.5px solid var(--grafite);border-radius:var(--r-md);box-shadow:6px 6px 0 0 var(--grafite)}
.faq-q{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px 24px;font-family:var(--brico);font-weight:700;font-size:20px;line-height:1.25;color:var(--grafite)}
.faq-q::-webkit-details-marker{display:none}
.faq-ic{flex:none;width:34px;height:34px;border-radius:50%;background:var(--laranja);border:1.5px solid var(--grafite);display:flex;align-items:center;justify-content:center;transition:transform .3s}
.faq-item[open] .faq-ic{transform:rotate(135deg)}
.faq-ic svg{width:16px;height:16px;display:block}
.faq-a{padding:0 24px 24px;font-size:16px;line-height:1.6;color:var(--g400);max-width:66ch}
.faq-item[open] .faq-a{animation:faqIn .3s ease}
@keyframes faqIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ---------- CTA final — faixa full-width ESCURA (grafite). Flui direto
   pro rodapé escuro (sem faixa creme no meio): vira uma região só. ---------- */
.cta-final{background:var(--grafite);color:var(--creme);text-align:center;padding:124px 0 96px}
.cta-final .h2{color:var(--creme);max-width:18ch;margin:0 auto}
.cta-final .lead{color:var(--g300);max-width:580px;margin:18px auto 34px}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta-symbol{width:72px;height:auto;margin:0 auto 24px;opacity:.95}

/* ---------- Contato no rodapé escuro ---------- */
.contact-rail{display:flex;gap:28px;flex-wrap:wrap;color:var(--g300);font-size:15px}
.contact-rail a{display:inline-flex;align-items:center;gap:8px;transition:color .2s}
.contact-rail a:hover{color:var(--creme)}

/* Navbar fiel à referência: logo à esquerda, links CENTRALIZADOS, botão
   à direita. Grid de 3 colunas (a coluna do meio é o auto). */
.nav-in{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px}
.nav-brand{justify-self:start;display:inline-flex;align-items:center}
.nav-links{justify-self:center}
.nav-in>.btn{justify-self:end}

/* Rótulo do hero em pill com borda (como o label do hero da referência). */
.hero-tag{display:inline-flex;align-items:center;gap:8px;border:1.5px solid var(--grafite);border-radius:var(--r-pill);padding:8px 18px;font-size:14px;font-weight:400;color:var(--grafite);margin-bottom:22px}
.hero-tag img{width:16px;height:16px}
/* H1 — "fruto" com realce marca-texto + itálico serifado (opção 3) */
.fruto-hl-mark{position:relative;display:inline-block;isolation:isolate}
.fruto-hl{position:absolute;left:50%;top:54%;width:112%;height:86%;transform:translate(-50%,-50%) rotate(-1.5deg);z-index:-1;overflow:visible;pointer-events:none;animation:fruto-wipe .7s cubic-bezier(.6,0,.25,1) .5s both}
.fruto-hl path{fill:#E7DBC6}
.fruto-ital{font-family:var(--inst);font-style:italic;font-weight:400;color:var(--grafite);letter-spacing:0;padding:0 .06em}
/* Símbolo da marca como arremate, depois de "fruto" */
.h1-symbol{display:inline-block;height:.95em;width:auto;margin-left:.14em;vertical-align:baseline;transform-origin:50% 82%;animation:h1sym 4.5s ease-in-out infinite}
@keyframes h1sym{0%,100%{transform:rotate(8deg)}50%{transform:rotate(18deg)}}
@keyframes fruto-wipe{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}
@media(prefers-reduced-motion:reduce){.fruto-hl{animation:none;clip-path:none}.h1-symbol{animation:none}}

/* Cabeçalho de seção centralizado (como a referência usa nos títulos). */
.sec-center{margin-left:auto;margin-right:auto;text-align:center}
.sec-center .lead{margin-left:auto;margin-right:auto}

/* Acento (sticker) no título: o leaf fica colado à palavra-chave (nunca
   pula sozinho pra outra linha) e alinhado com o texto. */
.kwx{white-space:nowrap}
/* o reset global img{display:block} fazia o leaf cair numa linha sozinho;
   inline-block prende ele à palavra-chave, no fluxo do texto. */
.kw-leaf{display:inline-block;vertical-align:baseline}

/* ---------- Segmentos: marquee animado de pills (substitui chips estáticos) ---------- */
.seg-marquee{overflow:hidden;padding:6px 0 16px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.seg-marquee:hover .seg-track{animation-play-state:paused}
.seg-track{display:flex;gap:18px;width:max-content;animation:rz-marq 42s linear infinite}
.seg-track.rev{animation-direction:reverse;margin-top:18px}
.seg-pill{display:inline-flex;align-items:center;gap:10px;white-space:nowrap;background:var(--papel);border:1.5px solid var(--grafite);
  border-radius:var(--r-pill);padding:12px 22px;font-weight:600;font-size:16px;box-shadow:5px 5px 0 0 var(--grafite)}
.seg-pill img{width:18px;height:18px}
.seg-pill.is-accent{background:var(--laranja)}

/* ---------- Cases: avatar-sticker (placeholder pra foto do cliente) ---------- */
.case-top{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.case-avatar{flex:none;width:54px;height:54px;border-radius:50%;background:var(--areia);border:1.5px solid var(--grafite);
  box-shadow:4px 4px 0 0 var(--grafite);display:flex;align-items:center;justify-content:center;overflow:hidden;transform:rotate(-4deg)}
.case-avatar img{width:100%;height:100%;object-fit:cover}
.case-avatar .ph{width:24px;height:24px;opacity:.55}

/* ---------- Método: linha de fluxo conectando as etapas (o funil) ---------- */
.metodo-flow{position:relative}
.metodo-flow::before{content:"";position:absolute;top:63px;left:8%;right:8%;height:2px;z-index:0;
  background:repeating-linear-gradient(90deg,var(--areia-escura) 0 9px,transparent 9px 18px)}
.metodo-flow .feature-card{position:relative;z-index:1}
@media(max-width:820px){.metodo-flow::before{display:none}}

/* ---------- Sobre: foto do Leandro lado a lado (layout editorial) ---------- */
.about{display:grid;grid-template-columns:.82fr 1.18fr;gap:76px;align-items:center}
.about-media{position:relative}
.about-photo{aspect-ratio:4/5;border:1.5px solid var(--grafite);border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(150deg,var(--areia),var(--areia-escura));box-shadow:12px 12px 0 0 var(--grafite);
  transform:rotate(-2deg);display:flex;align-items:center;justify-content:center}
.about-photo img.ph{width:42%;height:auto;opacity:.4}
.about-photo img.real{width:100%;height:100%;object-fit:cover}
.about-badge{position:absolute;bottom:-16px;left:26px;background:var(--laranja);border:1.5px solid var(--grafite);border-radius:var(--r-pill);
  padding:9px 20px;font-weight:600;font-size:14px;transform:rotate(-3deg);box-shadow:4px 4px 0 0 var(--grafite)}
.about-body .h3{margin:14px 0 0}
@media(max-width:820px){.about{grid-template-columns:1fr;gap:48px}.about-photo{transform:none}.about-badge{transform:rotate(-3deg)}}

/* =====================================================================
   POLIMENTO RESPONSIVO — não muda o desktop; só conserta telas estreitas.
   ===================================================================== */

/* "Em foco" (serviços): no touch/tablet não há hover, então a lista
   borrada fica ilegível. Aqui mostramos tudo nítido e com as descrições
   sempre visíveis — vira uma lista de serviços legível. */
@media(max-width:820px){
  .svc-list{gap:26px}
  .svc-link.b3,.svc-link.b6,.svc-link.b12{filter:none;opacity:1}
  .svc-link .svc-desc{max-height:none;opacity:1;margin-top:6px}
  .svc-left .lead{max-width:none}
}

/* Celular: títulos e respiros proporcionais à largura. */
@media(max-width:560px){
  .h1{font-size:clamp(40px,12.5vw,56px)}
  .h2{font-size:clamp(30px,8.5vw,44px)}
  .hero{padding:20px 0 48px}
  .hero-tag{font-size:12px;padding:6px 14px;margin-bottom:18px}
  .hero .lead{margin:16px auto 26px;font-size:17px}
  .btn{padding:15px 28px;font-size:15px}
  .section{padding:64px 0}
  .svc-section{padding:72px 0}
  .cta-final{padding:84px 0}
  .trust{padding:32px 0 64px}
  .footer{padding:72px 0 48px}
  .footer .cols{flex-direction:column;align-items:flex-start;gap:24px}
  .card{padding:26px}
  .feat-grid{gap:24px}
}
