/* Fontes self-hosted (subsets latin + latin-ext) — Google Fonts, licença OFL.
   Variáveis: uma face por família/estilo/subset com font-weight em range. */
@font-face{font-family:'Bricolage Grotesque';font-style:normal;font-weight:400 800;font-display:swap;src:url(fonts/bricolage-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Bricolage Grotesque';font-style:normal;font-weight:400 800;font-display:swap;src:url(fonts/bricolage-latinext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url(fonts/fraunces-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url(fonts/fraunces-latinext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:500 600;font-display:swap;src:url(fonts/fraunces-italic-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:500 600;font-display:swap;src:url(fonts/fraunces-italic-latinext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url(fonts/hanken-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url(fonts/hanken-latinext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}

:root{
  --creme:#F4E7D1;--ocre:#C99A3F;--terracota:#A85C3C;--barro:#7B4A30;
  --madeira:#5A3A24;--cacau:#3B2418;--espresso:#26160F;--verde:#4D7A3A;
  --display:'Bricolage Grotesque','Arial Narrow',Arial,sans-serif;
  --serif:'Fraunces',Georgia,serif;
  --body:'Hanken Grotesk','Helvetica Neue',Arial,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
/* scroll suave só quando o usuário não pediu redução de movimento (regra #6) */
@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}
/* Guarda contra overflow horizontal no mobile (regra inegociável #3) */
html,body{overflow-x:hidden}
img{max-width:100%;height:auto}
/* Foco visível on-brand para navegação por teclado (acessibilidade) */
:focus-visible{outline:2px solid var(--ocre);outline-offset:3px;border-radius:4px}
body{font-family:var(--body);color:var(--cacau);background:var(--creme);-webkit-font-smoothing:antialiased;line-height:1.5;font-size:17px}
section{position:relative;overflow:hidden}
[id]{scroll-margin-top:84px}
.wrap{max-width:1180px;margin:0 auto;padding:0 40px;position:relative;z-index:2}
.dark{background:var(--espresso);color:var(--creme)}
.dark .muted{color:rgba(244,231,209,.62)}
.light{background:var(--creme);color:var(--cacau)}
.light .muted{color:var(--barro)}
.eyebrow{font-family:var(--body);font-weight:700;letter-spacing:.28em;text-transform:uppercase;font-size:12px;color:var(--ocre)}

.roots{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}
.roots img{position:absolute;height:auto}

/* NAV */
.nav{position:absolute;top:0;left:0;right:0;z-index:40}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:24px;padding-bottom:24px}
.brandmark{font-family:var(--display);font-weight:800;color:var(--creme);font-size:22px;letter-spacing:-.01em;line-height:1;text-decoration:none}
.brandmark small{display:block;font-size:11px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--ocre);margin-bottom:2px}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links a.link{font-family:var(--body);font-weight:600;font-size:14px;color:rgba(244,231,209,.82);text-decoration:none;transition:.2s}
.nav-links a.link:hover{color:var(--ocre)}
.nav a.cta{font-family:var(--body);font-weight:700;font-size:14px;color:var(--espresso);background:var(--creme);padding:11px 20px;border-radius:999px;text-decoration:none;transition:.2s;display:inline-flex;align-items:center;min-height:44px}
.nav a.cta:hover{background:var(--ocre)}

/* Hambúrguer + menu mobile (drawer) */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:0 9px;background:transparent;border:none;cursor:pointer;position:relative;z-index:50}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--creme);border-radius:2px;transition:transform .28s ease,opacity .2s ease}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;background:var(--espresso);display:flex;flex-direction:column;gap:2px;padding:104px 28px 40px;z-index:45;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .25s ease,transform .25s ease,visibility .25s}
.mobile-menu.open{opacity:1;visibility:visible;transform:none}
.mobile-menu .mlink{font-family:var(--display);font-weight:700;font-size:30px;color:var(--creme);text-decoration:none;padding:18px 0;border-bottom:1px solid rgba(244,231,209,.12)}
.mobile-menu .mlink:hover,.mobile-menu .mlink:active{color:var(--ocre)}
.mobile-menu .mcta{margin-top:28px;align-self:flex-start;background:var(--creme);color:var(--espresso);font-family:var(--body);font-weight:700;font-size:16px;padding:14px 26px;border-radius:999px;text-decoration:none;min-height:44px;display:inline-flex;align-items:center}
.mobile-menu .mcta:hover{background:var(--ocre)}
body.menu-open{overflow:hidden}
@media(prefers-reduced-motion:reduce){.mobile-menu,.nav-toggle span{transition:none}}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;padding:150px 0 90px}
.hero .logo{font-family:var(--display);font-weight:800;line-height:.86;letter-spacing:-.02em}
.hero .logo .the{display:block;font-size:clamp(20px,2.4vw,30px);color:var(--ocre);letter-spacing:.42em;margin-left:.4em;margin-bottom:.15em}
.hero .logo .word{display:block;font-size:clamp(72px,15vw,230px);color:var(--creme)}
.hero .tagline{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--ocre);font-size:clamp(28px,5vw,62px);text-align:right;margin-top:-.1em;line-height:1}
.hero .lead{margin-top:48px;max-width:660px}
.hero .lead p{font-size:18px;color:rgba(244,231,209,.75);max-width:620px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:38px}
.btn{font-family:var(--body);font-weight:700;font-size:15px;padding:14px 26px;border-radius:999px;text-decoration:none;transition:.2s;display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:none}
.btn-primary{background:var(--creme);color:var(--espresso)}
.btn-primary:hover{background:var(--ocre)}
.btn-outline{border:1.6px solid rgba(244,231,209,.4);color:var(--creme);background:transparent}
.btn-outline:hover{border-color:var(--ocre);color:var(--ocre)}
.btn-dark{background:var(--cacau);color:var(--creme);margin-top:34px}
.btn-dark:hover{background:var(--terracota)}

/* SECTIONS */
.sec{padding:120px 0}
.big-title{font-family:var(--display);font-weight:800;line-height:.95;letter-spacing:-.02em;font-size:clamp(42px,7vw,86px)}
.big-title .em{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--terracota)}
.dark .big-title .em{color:var(--ocre)}
.ponta .lead-copy{font-size:clamp(19px,2.2vw,24px);max-width:720px;margin-top:36px;color:var(--madeira);line-height:1.55}
.light .lead-copy{color:var(--madeira)}

/* SERVICES */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;margin-top:64px;background:rgba(244,231,209,.10);border:1px solid rgba(244,231,209,.10);border-radius:14px;overflow:hidden}
.svc{background:var(--espresso);padding:48px 44px;transition:.25s}
.svc:hover{background:rgba(244,231,209,.06)}
.svc .num{font-family:var(--serif);font-style:italic;font-size:44px;color:var(--ocre);line-height:1}
.svc h3{font-family:var(--display);font-weight:700;font-size:26px;color:var(--creme);margin:20px 0 12px}
.svc p{color:rgba(244,231,209,.6);font-size:16px;max-width:340px}

/* TEAM teaser */
.tavatars{display:flex;flex-wrap:wrap;margin-top:40px;padding-left:14px}
.tavatar{width:74px;height:74px;border-radius:50%;object-fit:cover;object-position:50% 22%;border:3px solid var(--creme);margin-left:-14px;box-shadow:0 2px 8px rgba(59,36,24,.14)}

/* MARCAS logo wall */
.logo-wall{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:18px;margin-top:52px;position:relative;z-index:2}
.logo-tile{border-radius:14px;height:128px;display:flex;align-items:center;justify-content:center;padding:26px;transition:transform .25s,box-shadow .25s}
.logo-tile.tile-light{background:var(--creme)}
.logo-tile.tile-dark{background:var(--cacau);border:1px solid rgba(244,231,209,.15)}
.logo-tile:hover{transform:translateY(-4px);box-shadow:0 12px 26px rgba(38,22,15,.30)}
.logo-tile img{max-width:100%;max-height:74px;width:auto;height:auto;object-fit:contain;display:block}

/* CTA FINAL */
.final{padding:130px 0 120px}
.final .kicker{font-family:var(--display);font-weight:800;line-height:.94;letter-spacing:-.02em;font-size:clamp(48px,10vw,140px);color:var(--creme)}
.final .kicker .em{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--ocre)}
.final p.sub{margin-top:30px;font-size:19px;color:rgba(244,231,209,.7);max-width:640px}
.final .actions{margin-top:46px;display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.btn-lg{font-family:var(--body);font-weight:700;font-size:17px;background:var(--creme);color:var(--espresso);padding:17px 34px;border-radius:999px;text-decoration:none;transition:.2s}
.btn-lg:hover{background:var(--ocre)}
.final .handle{font-family:var(--body);font-size:16px;color:rgba(244,231,209,.66)}
.final .handle a{color:var(--ocre);text-decoration:none}

/* FORMULÁRIO DE LEAD */
.lead-form{margin-top:44px;max-width:640px;display:grid;grid-template-columns:1fr 1fr;gap:16px}
.lead-form .field{display:flex;flex-direction:column;gap:6px}
.lead-form .field-full{grid-column:1 / -1}
.lead-form label{font-family:var(--body);font-weight:600;font-size:13px;letter-spacing:.02em;color:var(--ocre)}
.lead-form input,.lead-form textarea{font-family:var(--body);font-size:16px;color:var(--cacau);background:var(--creme);border:1.5px solid transparent;border-radius:10px;padding:13px 14px;width:100%;transition:border-color .2s}
.lead-form textarea{resize:vertical;min-height:112px}
.lead-form input:focus,.lead-form textarea:focus{outline:none;border-color:var(--ocre)}
.lead-form .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.lead-form button{grid-column:1 / -1;justify-self:start;border:none;cursor:pointer;min-height:44px}
.lead-form button[disabled]{opacity:.6;cursor:progress}
.lead-form .lf-status{grid-column:1 / -1;font-family:var(--body);font-size:15px;min-height:1.3em}
.lead-form .lf-status.ok{color:var(--creme)}
.lead-form .lf-status.err{color:var(--ocre)}
@media(max-width:560px){.lead-form{grid-template-columns:1fr}}

/* TEAM PAGE */
.team-hero{padding:170px 0 70px}
.team-hero .sub-intro{margin-top:26px;font-size:19px;color:rgba(244,231,209,.72);max-width:640px}
.team-bios{padding-top:68px}
.members-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.member-card{display:flex;gap:20px;align-items:flex-start;background:#FCF7EC;border:1px solid rgba(91,58,36,.14);border-radius:16px;padding:28px 30px;transition:transform .25s,box-shadow .25s}
.member-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(59,36,24,.12)}
.mc-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;object-position:50% 22%;flex:0 0 60px;box-shadow:0 2px 8px rgba(59,36,24,.16)}
.mc-body{flex:1;min-width:0}
.member-card .eyebrow{color:var(--terracota);font-size:11px}
.member-card h2{font-family:var(--display);font-weight:800;font-size:24px;line-height:1.05;margin-top:5px;color:var(--cacau)}
.member-card .sub{font-family:var(--serif);font-style:italic;color:var(--terracota);font-size:17px;margin:5px 0 12px}
.member-card p{color:var(--madeira);font-size:15px;line-height:1.55;margin-bottom:16px}
.tags{display:flex;flex-wrap:wrap;gap:8px}
.tag{display:inline-block;border:1.4px solid currentColor;border-radius:999px;padding:6px 12px;font-family:var(--body);font-weight:700;font-size:12px}
.member-card .tag{color:var(--terracota)}

/* Back to top */
.to-top{position:fixed;right:22px;bottom:22px;width:50px;height:50px;border-radius:50%;background:var(--ocre);color:var(--espresso);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(12px);transition:opacity .3s,transform .3s,visibility .3s,background .2s;z-index:60;box-shadow:0 6px 20px rgba(38,22,15,.38)}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.to-top:hover{background:var(--creme)}
.to-top svg{width:20px;height:20px}

/* Scroll reveal */
@media(prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}
}

footer{background:var(--cacau);color:rgba(244,231,209,.5);padding:34px 0}
footer .wrap{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:14px}
footer .brandmark{font-size:16px}
footer .brandmark small{margin-bottom:1px}

@media(max-width:820px){
  .wrap{padding:0 24px}
  .sec{padding:80px 0}
  .hero{padding:120px 0 70px;min-height:auto}
  .services-grid{grid-template-columns:1fr}
  .logo-wall{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}
  .final{padding:90px 0}
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .roots img{max-width:82vw}
  .members-grid{grid-template-columns:1fr;gap:16px}
  .member-card{padding:24px}
  .team-hero{padding:130px 0 50px}
}
@media(max-width:480px){
  .logo-wall{grid-template-columns:repeat(2,1fr)}
  .hero .tagline{text-align:left}
  .logo-tile{height:112px;padding:20px}
  /* evita a palavra "mandioca" encostar/cortar na borda em ~360px */
  .hero .logo .word{font-size:clamp(52px,15vw,72px)}
}
