/* ============================================================
   PILARES DA SAÚDE — Terapia Capilar · Landing Page
   Design system: clean clinical-premium
   Palette from the logo · Montserrat (geometric, no serifs)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300&display=swap');

:root{
  /* Brand palette — drawn from the logo */
  --blue:        #3F7DA1;
  --blue-deep:   #2C5C79;
  --blue-tint:   #EAF1F5;
  --olive:       #9B9856;
  --olive-deep:  #7C7A41;
  --olive-tint:  #F2F1E6;
  --charcoal:    #2E3338;

  /* Neutrals */
  --ink:    #232A2E;
  --body:   #4E575C;
  --muted:  #828B8F;
  --line:   #E6E9E5;
  --line-2: #D8DCD7;
  --bg:     #FFFFFF;
  --bg-soft:#F5F7F4;
  --white:  #FFFFFF;

  --max: 1280px;
  --pad: clamp(20px, 5vw, 56px);
  --r:   14px;
  --shadow-sm: 0 2px 8px rgba(38,46,50,.05), 0 1px 2px rgba(38,46,50,.04);
  --shadow:    0 18px 50px -22px rgba(38,52,60,.30);
  --shadow-lg: 0 40px 90px -40px rgba(30,46,56,.42);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
body{
  font-family:'Montserrat', system-ui, sans-serif;
  color:var(--body);
  background:var(--bg);
  font-size:17px;
  line-height:1.72;
  font-weight:400;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--blue); color:#fff; }

/* ---------- layout primitives ---------- */
.wrap{ width:100%; max-width:var(--max); margin:0 auto; padding-inline:var(--pad); }
.section{ position:relative; padding-block:clamp(72px,9vw,128px); }
.section--soft{ background:var(--bg-soft); }

.eyebrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-size:12.5px; font-weight:600; letter-spacing:.2em; text-transform:uppercase;
  color:var(--blue); margin-bottom:22px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--olive); display:inline-block; }
.eyebrow--olive{ color:var(--olive-deep); }
.eyebrow--olive::before{ background:var(--blue); }
.eyebrow--center{ }

h1,h2,h3{ color:var(--ink); font-weight:300; line-height:1.08; letter-spacing:-.015em; }
.h-display{ font-size:clamp(38px,5vw,60px); }
.h-display b{ font-weight:600; }
.h-section{ font-size:clamp(30px,4vw,46px); }
.h-section b{ font-weight:600; color:var(--blue-deep); }
.lead{ font-size:clamp(18px,2vw,21px); line-height:1.65; color:var(--body); font-weight:400; }
.measure{ max-width:54ch; }
.dim{ color:var(--muted); }

/* ---------- buttons ---------- */
.btn{
  position:relative; overflow:hidden; isolation:isolate; white-space:nowrap;
  --g1:var(--blue); --g2:var(--blue-deep); --fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:.7em;
  font-family:inherit; font-size:14px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:var(--fg);
  background:linear-gradient(118deg, var(--g1), var(--g2));
  background-size:200% 100%; background-position:0 0;
  border:none; border-radius:999px;
  padding:18px 34px; cursor:pointer;
  box-shadow:0 14px 30px -14px rgba(47,92,121,.7);
  transition:transform .45s var(--ease), box-shadow .45s var(--ease), background-position .6s var(--ease);
}
.btn > *{ position:relative; z-index:2; }
.btn::after{ /* sheen sweep */
  content:""; position:absolute; top:0; left:-65%; width:48%; height:100%; z-index:1;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.4), transparent);
  transform:skewX(-18deg); pointer-events:none;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 24px 48px -16px rgba(47,92,121,.82); background-position:100% 0; }
.btn:hover::after{ animation:sheen .85s var(--ease); }
@keyframes sheen{ from{ left:-65%; } to{ left:135%; } }
.btn:active{ transform:translateY(0); }
.btn svg{ width:18px; height:18px; transition:transform .4s var(--ease); }
.btn:hover .ico-wa{ transform:scale(1.14) rotate(-7deg); }
.btn:hover svg:not(.ico-wa){ transform:translateX(3px); }
.btn[data-hero-cta]:hover svg{ transform:translateY(3px); }
.btn--ghost{ --fg:var(--ink); background:transparent; border:1px solid var(--line-2); box-shadow:none; }
.btn--ghost::after{ display:none; }
.btn--ghost:hover{ border-color:var(--blue); color:var(--blue-deep); box-shadow:none; }
.btn--olive{ --g1:var(--olive); --g2:var(--olive-deep); box-shadow:0 14px 30px -14px rgba(124,122,65,.6); }
.btn--olive:hover{ box-shadow:0 24px 48px -16px rgba(124,122,65,.72); }
.btn--lg{ padding:21px 42px; font-size:15px; }
.btn--sm{ padding:13px 24px; font-size:12.5px; box-shadow:0 9px 22px -13px rgba(47,92,121,.7); }
.btn--light{ --g1:#ffffff; --g2:#e9f1f6; --fg:var(--blue-deep); box-shadow:0 14px 34px -16px rgba(0,0,0,.5); }
.btn--light::after{ background:linear-gradient(100deg, transparent, rgba(63,125,161,.22), transparent); }

/* ---------- header ---------- */
.header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
  padding-block:18px;
}
.header.scrolled{ background:rgba(255,255,255,.88); backdrop-filter:blur(14px); box-shadow:0 1px 0 var(--line), 0 8px 30px -22px rgba(0,0,0,.4); padding-block:11px; }
.header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.header-actions{ display:flex; align-items:center; gap:26px; }
.header-loc{ display:flex; align-items:center; gap:9px; font-size:13.5px; color:var(--body); font-weight:500; }
.header-loc svg{ width:16px; height:16px; color:var(--olive-deep); flex:none; }
.header .btn{ padding:13px 26px; font-size:12.5px; box-shadow:none; }
.header .btn:hover{ box-shadow:0 14px 28px -16px rgba(47,92,121,.7); }

/* ---------- logo ---------- */
.logo{ display:flex; align-items:center; }
.logo__img{ height:54px; width:auto; display:block; transition:height .4s var(--ease); }
.header.scrolled .logo__img{ height:44px; }
.footer__logo{ display:inline-flex; background:#fff; padding:15px 22px; border-radius:14px; box-shadow:0 14px 36px -18px rgba(0,0,0,.6); }
.footer__logo img{ height:48px; width:auto; display:block; }
.logo__mark{ width:46px; height:46px; flex:none; }
.logo__type{ display:flex; flex-direction:column; line-height:1; }
.logo__name{ font-weight:400; font-size:18px; letter-spacing:.16em; color:var(--charcoal); }
.logo__name b{ font-weight:400; }
.logo__sub{ font-size:8.5px; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); margin-top:4px; font-weight:500; }
.logo--light .logo__name{ color:#fff; }
.logo--light .logo__sub{ color:rgba(255,255,255,.6); }

/* ============================================================
   HERO  — 50/50
   ============================================================ */
.hero{ position:relative; padding-top:clamp(124px,16vh,180px); padding-bottom:clamp(60px,8vw,96px); overflow:hidden; }
@media (min-width:769px){
  .hero{
    background-image:url("assets/background.png");
    background-repeat:no-repeat;
    background-position:center center;
    background-size:cover;
  }
}
.hero__grid{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,76px); align-items:center;
}
.hero__copy{ max-width:560px; }
.hero h1{ margin-bottom:24px; }
.hero h1 b{ color:var(--blue-deep); }
.hero .lead{ margin-bottom:38px; max-width:48ch; }
.hero__cta{ display:flex; align-items:center; gap:22px; flex-wrap:wrap; }
.hero__scroll{ display:inline-flex; align-items:center; gap:10px; font-size:13px; letter-spacing:.04em; color:var(--muted); font-weight:500; }
.hero__trust{
  display:flex; align-items:center; gap:26px; margin-top:46px; padding-top:30px;
  border-top:1px solid var(--line); flex-wrap:wrap;
}
.trust-item{ }
.trust-item .n{ font-size:30px; font-weight:300; color:var(--blue-deep); letter-spacing:-.02em; }
.trust-item .l{ font-size:12.5px; color:var(--muted); letter-spacing:.04em; line-height:1.4; }

/* hero media */
.hero__media{ position:relative; }
.hero__photo{
  width:100%; aspect-ratio:4/5; border-radius:24px; overflow:hidden;
  box-shadow:var(--shadow-lg); position:relative; z-index:2;
}
.hero__photo image-slot{ width:100%; height:100%; }
.hero__blob{ position:absolute; border-radius:50%; filter:blur(2px); z-index:1; }
.hero__blob--blue{ width:62%; aspect-ratio:1; right:-10%; top:-8%; background:radial-gradient(circle at 35% 35%, var(--blue) , var(--blue-deep)); opacity:.14; }
.hero__blob--olive{ width:46%; aspect-ratio:1; left:-12%; bottom:4%; background:var(--olive); opacity:.13; }
.hero__badge{
  position:absolute; z-index:3; left:-26px; bottom:42px;
  background:#fff; border-radius:16px; padding:16px 20px; box-shadow:var(--shadow);
  display:flex; align-items:center; gap:14px; max-width:248px;
}
.hero__badge .ic{ width:42px; height:42px; border-radius:11px; background:var(--olive-tint); display:grid; place-items:center; flex:none; }
.hero__badge .ic svg{ width:22px; height:22px; color:var(--olive-deep); }
.hero__badge .t{ font-size:13.5px; line-height:1.45; color:var(--ink); font-weight:500; }
.hero__badge .t b{ font-weight:700; }

/* big soft brand watermark behind hero */
.hero__wm{ position:absolute; right:-6%; top:8%; width:520px; opacity:.05; z-index:0; pointer-events:none; }

/* ============================================================
   SECTION: SINAIS
   ============================================================ */
.split-head{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,72px); align-items:end; margin-bottom:clamp(40px,5vw,60px); }
.split-head .lead{ padding-bottom:6px; }
@media(max-width:860px){ .split-head{ grid-template-columns:1fr; gap:20px; } }

.sign-list{ display:grid; grid-template-columns:1fr 1fr; gap:0 56px; border-top:1px solid var(--line-2); }
.sign-row{ display:grid; grid-template-columns:auto auto 1fr; align-items:center; gap:22px; padding:26px 4px; border-bottom:1px solid var(--line-2); transition:padding .4s var(--ease); }
.sign-row__no{ font-size:13px; font-weight:700; color:var(--olive-deep); letter-spacing:.08em; }
.sign-row__ic{ width:56px; height:56px; border-radius:15px; background:#fff; border:1px solid var(--line); display:grid; place-items:center; color:var(--blue); flex:none; transition:.45s var(--ease); }
.sign-row__ic svg{ width:27px; height:27px; }
.sign-row__tx{ font-size:17px; color:var(--ink); font-weight:500; line-height:1.45; }
.sign-row:hover{ padding-left:14px; }
.sign-row:hover .sign-row__ic{ background:linear-gradient(135deg,var(--blue),var(--blue-deep)); color:#fff; border-color:transparent; transform:rotate(-4deg) scale(1.04); box-shadow:0 12px 26px -12px rgba(47,92,121,.6); }
@media(min-width:861px){ .sign-list .sign-row:nth-last-child(-n+2){ border-bottom:none; } }

/* CASOS REAIS — 2 imagens */
.cases__head{ text-align:center; max-width:780px; margin:0 auto clamp(34px,4vw,52px); }
.cases__head .eyebrow{ justify-content:center; }
.cases{ display:grid; grid-template-columns:1fr 1fr; gap:28px; max-width:900px; margin:0 auto; }
.case-card{ position:relative; border-radius:20px; overflow:hidden; box-shadow:var(--shadow); aspect-ratio:4/5; }
.case-card img{ width:100%; height:100%; object-fit:cover; object-position:center 40%; }
.case-card figcaption{ position:absolute; inset:auto 0 0 0; padding:20px; background:linear-gradient(to top, rgba(35,42,46,.55), transparent); }
.case-card__tag{ display:inline-block; white-space:nowrap; background:rgba(255,255,255,.94); color:var(--ink); font-size:11px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; padding:7px 14px; border-radius:999px; }
.cases__cta{ text-align:center; margin-top:clamp(34px,4vw,48px); }

/* RESULTADOS — 2 antes/depois */
.results__head{ text-align:center; max-width:780px; margin:0 auto clamp(34px,4vw,52px); }
.results__head .eyebrow{ justify-content:center; }
.results-grid{ display:grid; grid-template-columns:1fr 1fr; gap:28px; max-width:1040px; margin:0 auto; }
.results-grid .ba-card{ width:auto; }
.results__cta{ text-align:center; margin-top:clamp(34px,4vw,48px); }

.causes{ margin-top:clamp(52px,6vw,76px); display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,64px); align-items:center; }
.causes__col p{ margin-bottom:22px; }
.causes__col p:last-child{ margin-bottom:0; }
.causes__col p b{ color:var(--ink); font-weight:600; }
.causes__panel{
  background:var(--charcoal); color:#fff; border-radius:20px; padding:clamp(30px,4vw,46px);
  position:relative; overflow:hidden; box-shadow:var(--shadow);
}
.causes__panel h3{ color:#fff; font-size:23px; font-weight:400; margin-bottom:24px; letter-spacing:-.01em; }
.causes__panel h3 b{ font-weight:600; color:#fff; }
.origins{ list-style:none; display:flex; flex-direction:column; gap:0; }
.origins li{ display:flex; align-items:center; gap:14px; padding:13px 0; border-bottom:1px solid rgba(255,255,255,.12); font-size:15.5px; color:rgba(255,255,255,.88); }
.origins li:last-child{ border-bottom:none; }
.origins .dot{ width:7px; height:7px; border-radius:50%; background:var(--olive); flex:none; }
.causes__panel .deco{ position:absolute; right:-40px; bottom:-50px; width:200px; opacity:.08; }

/* ============================================================
   CAROUSEL (shared)
   ============================================================ */
.carousel{ position:relative; margin-top:clamp(38px,4vw,52px); }
.carousel__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:26px; }
.carousel__nav{ display:flex; gap:10px; flex:none; }
.cbtn{
  width:50px; height:50px; border-radius:50%; border:1px solid var(--line-2); background:#fff;
  display:grid; place-items:center; cursor:pointer; color:var(--ink);
  transition:.3s var(--ease);
}
.cbtn:hover{ background:var(--blue); color:#fff; border-color:var(--blue); transform:translateY(-2px); }
.cbtn:disabled{ opacity:.35; cursor:default; transform:none; background:#fff; color:var(--ink); border-color:var(--line-2); }
.cbtn svg{ width:20px; height:20px; }

.track-mask{ overflow:hidden; }
.track{ display:flex; gap:22px; transition:transform .6s var(--ease); will-change:transform; }
.slide{ flex:0 0 auto; }

/* before/after card */
.ba-card{
  background:#fff; border:1px solid var(--line); border-radius:18px; overflow:hidden;
  box-shadow:var(--shadow-sm); width:min(560px,82vw);
}
.ba-card__img{ position:relative; }
.ba-card__img img{ width:100%; aspect-ratio:1.9/1; object-fit:cover; }
.ba-tags{ position:absolute; inset:auto 0 0 0; display:flex; justify-content:space-between; padding:0; }
.ba-tag{ flex:1; text-align:center; font-size:11.5px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; padding:9px; color:#fff; backdrop-filter:blur(3px); }
.ba-tag--before{ background:rgba(46,51,56,.62); }
.ba-tag--after{ background:rgba(63,125,161,.78); }
.ba-card__foot{ padding:18px 24px; display:flex; align-items:center; justify-content:space-between; gap:16px; }
.ba-card__foot .who{ font-size:15px; color:var(--ink); font-weight:600; }
.ba-card__foot .when{ font-size:13px; color:var(--muted); }

/* antes-only card */
.antes-card{ width:min(330px,72vw); border-radius:16px; overflow:hidden; position:relative; box-shadow:var(--shadow-sm); border:1px solid var(--line); background:#fff; }
.antes-card img{ width:100%; aspect-ratio:3/4; object-fit:cover; }
.antes-card image-slot{ width:100%; aspect-ratio:3/4; }
.antes-card__lbl{ position:absolute; left:14px; top:14px; background:rgba(46,51,56,.66); backdrop-filter:blur(4px); color:#fff; font-size:11px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; padding:7px 13px; border-radius:999px; }

/* ============================================================
   SECTION: PROTOCOLO
   ============================================================ */
.proto-intro{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,72px); align-items:start; }
.proto-points{ display:flex; gap:14px 26px; flex-wrap:wrap; margin-top:30px; }
.proto-points span{ display:inline-flex; align-items:center; gap:9px; white-space:nowrap; font-size:14px; font-weight:600; color:var(--blue-deep); }
.proto-points svg{ width:22px; height:22px; padding:4px; background:var(--blue-tint); border-radius:50%; color:var(--blue-deep); }

.device-note{
  background:linear-gradient(152deg, var(--blue) -8%, var(--blue-deep) 72%);
  color:#fff; border-radius:22px; padding:clamp(30px,3.5vw,46px); align-self:start;
  position:relative; overflow:hidden; box-shadow:0 32px 72px -34px rgba(44,92,121,.75);
}
.device-note__chip{ display:inline-flex; align-items:center; gap:8px; font-size:11.5px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:#fff; background:rgba(255,255,255,.15); padding:8px 16px; border-radius:999px; margin-bottom:22px; }
.device-note__chip svg{ width:16px; height:16px; }
.device-note h3{ font-size:24px; font-weight:400; color:#fff; margin-bottom:14px; line-height:1.32; position:relative; z-index:1; }
.device-note h3 b{ font-weight:700; }
.device-note p{ font-size:15.5px; color:rgba(255,255,255,.9); position:relative; z-index:1; }
.device-note__wm{ position:absolute; right:-34px; bottom:-44px; width:210px; opacity:.12; z-index:0; }

.features{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:clamp(46px,5vw,68px); }
.feature{ position:relative; padding:34px 28px 30px; border-radius:var(--r); background:#fff; border:1px solid var(--line); transition:.45s var(--ease); overflow:hidden; }
.feature::before{ content:""; position:absolute; inset:0 0 auto 0; height:3px; background:linear-gradient(90deg,var(--blue),var(--olive)); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.feature:hover{ transform:translateY(-5px); box-shadow:var(--shadow); border-color:transparent; }
.feature:hover::before{ transform:scaleX(1); }
.feature__no{ position:absolute; top:22px; right:26px; font-size:13px; font-weight:700; letter-spacing:.06em; color:var(--line-2); transition:.4s var(--ease); }
.feature:hover .feature__no{ color:var(--olive-deep); }
.feature__ic{ width:54px; height:54px; border-radius:15px; display:grid; place-items:center; margin-bottom:22px; background:var(--blue-tint); color:var(--blue-deep); transition:.45s var(--ease); }
.feature:nth-child(even) .feature__ic{ background:var(--olive-tint); color:var(--olive-deep); }
.feature:hover .feature__ic{ background:linear-gradient(135deg,var(--blue),var(--blue-deep)); color:#fff; transform:scale(1.06) rotate(-3deg); }
.feature:nth-child(even):hover .feature__ic{ background:linear-gradient(135deg,var(--olive),var(--olive-deep)); }
.feature__ic svg{ width:26px; height:26px; }
.feature h4{ font-size:17px; font-weight:600; color:var(--ink); margin-bottom:10px; letter-spacing:-.01em; }
.feature p{ font-size:14.5px; line-height:1.6; color:var(--body); }

/* ============================================================
   SECTION: PARA QUEM
   ============================================================ */
.forwhom__head{ max-width:780px; margin-bottom:clamp(34px,4vw,52px); }
.indica-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.indica{ position:relative; overflow:hidden; background:#fff; border:1px solid var(--line); border-radius:16px; padding:30px 28px; transition:.45s var(--ease); }
.indica:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:transparent; }
.indica__ic{ width:50px; height:50px; border-radius:14px; background:var(--olive-tint); color:var(--olive-deep); display:grid; place-items:center; margin-bottom:18px; transition:.45s var(--ease); }
.indica:hover .indica__ic{ background:linear-gradient(135deg,var(--olive),var(--olive-deep)); color:#fff; transform:rotate(-4deg) scale(1.05); }
.indica__ic svg{ width:26px; height:26px; }
.indica h4{ font-size:17px; font-weight:600; color:var(--ink); margin-bottom:8px; letter-spacing:-.01em; }
.indica p{ font-size:14.5px; color:var(--body); line-height:1.55; }
.indica--cta{ background:linear-gradient(150deg,var(--blue),var(--blue-deep)); border-color:transparent; display:flex; flex-direction:column; justify-content:center; gap:24px; box-shadow:0 26px 60px -30px rgba(44,92,121,.7); }
.indica--cta:hover{ transform:translateY(-4px); box-shadow:0 34px 70px -30px rgba(44,92,121,.8); }
.indica--cta p{ color:#fff; font-size:18.5px; line-height:1.5; }
.indica--cta p b{ font-weight:700; }
.indica--cta .btn{ --g1:#ffffff; --g2:#e9f1f6; --fg:var(--blue-deep); align-self:flex-start; }

/* ============================================================
   SECTION: EQUIPA
   ============================================================ */
.team{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:center; }
.team__photo{ border-radius:22px; overflow:hidden; box-shadow:var(--shadow); position:relative; }
.team__photo img{ width:100%; object-fit:cover; }
.team__copy h2{ margin-bottom:10px; }
.team__copy .sub{ font-size:14px; letter-spacing:.04em; color:var(--olive-deep); font-weight:600; margin-bottom:26px; }
.team__copy p{ margin-bottom:32px; max-width:46ch; }

/* ============================================================
   SECTION: CLOSING CTA
   ============================================================ */
.closing{ position:relative; background:var(--blue-deep); color:#fff; overflow:hidden; }
.closing::before{ content:""; position:absolute; inset:0; background:
   radial-gradient(60% 80% at 85% 20%, rgba(155,152,86,.30), transparent 60%),
   radial-gradient(50% 70% at 10% 90%, rgba(63,125,161,.55), transparent 60%); }
.closing .wrap{ position:relative; z-index:2; text-align:center; max-width:820px; }
.closing h2{ color:#fff; font-size:clamp(30px,4.4vw,50px); margin-bottom:22px; }
.closing h2 b{ font-weight:600; }
.closing p{ color:rgba(255,255,255,.85); font-size:clamp(17px,2vw,20px); max-width:60ch; margin:0 auto 40px; }
.closing__deco{ position:absolute; opacity:.10; z-index:1; }

/* ============================================================
   FOOTER / LOCALIZAÇÃO
   ============================================================ */
.footer{ background:var(--charcoal); color:rgba(255,255,255,.72); padding-block:clamp(56px,6vw,84px) 34px; }
.footer__grid{ display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:clamp(32px,5vw,64px); }
.footer__brand p{ font-size:14.5px; line-height:1.7; margin-top:22px; max-width:34ch; color:rgba(255,255,255,.6); }
.footer h5{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--olive); font-weight:600; margin-bottom:20px; }
.footer__addr{ font-size:15px; line-height:1.7; color:rgba(255,255,255,.82); }
.footer__addr .row{ display:flex; gap:12px; margin-bottom:16px; align-items:flex-start; }
.footer__addr svg{ width:18px; height:18px; color:var(--olive); flex:none; margin-top:3px; }
.footer__services{ font-size:14.5px; line-height:1.9; color:rgba(255,255,255,.72); }
.footer__bar{ margin-top:clamp(44px,5vw,64px); padding-top:26px; border-top:1px solid rgba(255,255,255,.12); display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; font-size:13px; color:rgba(255,255,255,.45); }

/* ---------- reveal on scroll ----------
   Content is ALWAYS opaque (never hidden) so it can never render blank;
   the entrance is a pure slide-up motion layered on top. */
@keyframes revealUp{ from{ transform:translateY(28px); } to{ transform:none; } }
.reveal{ opacity:1; }
.reveal.in{ animation:revealUp .8s var(--ease); }
.reveal.in[data-d="1"]{ animation-delay:.09s; }
.reveal.in[data-d="2"]{ animation-delay:.18s; }
.reveal.in[data-d="3"]{ animation-delay:.27s; }
.reveal.in[data-d="4"]{ animation-delay:.36s; }
@media (prefers-reduced-motion: reduce){ .reveal.in{ animation:none; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1080px){
  .features{ grid-template-columns:repeat(2,1fr); }
  .proto-intro{ grid-template-columns:1fr; }
  .indica-grid{ grid-template-columns:repeat(2,1fr); }
}
@media(max-width:900px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero__media{ order:-1; max-width:460px; }
  .sign-list{ grid-template-columns:1fr; }
  .causes{ grid-template-columns:1fr; }
  .team{ grid-template-columns:1fr; }
  .team__photo{ order:-1; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
  .header-loc{ display:none; }
}
@media(max-width:680px){
  .cases{ grid-template-columns:1fr; max-width:420px; }
  .results-grid{ grid-template-columns:1fr; max-width:520px; }
  .indica-grid{ grid-template-columns:1fr; }
}
@media(max-width:560px){
  body{ font-size:16px; }
  .features{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; }
  .hero__badge{ left:0; }
  .btn{ padding:14px 18px; font-size:11.5px; letter-spacing:.06em; gap:.5em; }
  .btn--lg{ padding:15px 20px; font-size:12px; }
  .btn svg{ width:16px; height:16px; }
  .header .btn{ padding:11px 16px; font-size:10.5px; letter-spacing:.05em; }
  .hero__trust{ gap:18px; }
}

/* ============================================================
   MOBILE — hero full-viewport, bg no topo, conteúdo no bottom
   ============================================================ */
@media(max-width:768px){
  /* header escondido até passar da hero */
  .header.header--mobile-hidden{
    transform:translateY(-100%);
    opacity:0; pointer-events:none;
    transition:transform .35s var(--ease), opacity .35s var(--ease), background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
  }
  .header.header--mobile-hidden.header--reveal{
    transform:translateY(0); opacity:1; pointer-events:auto;
  }

  /* hero ocupa o viewport, bg no topo, conteúdo no bottom */
  .hero{
    min-height:100svh; min-height:100dvh;
    padding-top:0; padding-bottom:clamp(24px,6vw,40px);
    display:flex; align-items:flex-end;
    background-image:url("assets/background-mobile.png");
    background-repeat:no-repeat;
    background-position:top center;
    background-size:100% auto;
    background-color:#fff;
  }
  .hero .wrap{ width:100%; }
  .hero__grid{ grid-template-columns:1fr; gap:0; }
  .hero__copy{ max-width:none; }

  /* eyebrow da hero em 1 linha */
  .hero .eyebrow{
    font-size:10px; letter-spacing:.16em;
    white-space:nowrap; margin-bottom:14px;
  }
  .hero .eyebrow::before{ width:18px; }

  .hero h1{ margin-bottom:16px; }
  .h-display{ font-size:clamp(30px,8.5vw,40px); }
  .hero .lead{ margin-bottom:24px; font-size:16px; }
  .hero__trust{ margin-top:26px; padding-top:20px; gap:14px; }
  .trust-item .n{ font-size:24px; }
  .trust-item .l{ font-size:11px; }
  .hero__cta .btn{ width:100%; }

  /* revisão geral — espaçamento das secções */
  .section{ padding-block:clamp(56px,11vw,80px); }
  .h-section{ font-size:clamp(26px,6.5vw,34px); }

  /* sinais — ícone menor */
  .sign-row{ padding:18px 0; gap:14px; }
  .sign-row__no{ font-size:11px; }
  .sign-row__ic{ width:42px; height:42px; }
  .sign-row__ic svg{ width:22px; height:22px; }
  .sign-row__tx{ font-size:15px; }

  /* feature cards */
  .feature{ padding:24px; }
  .feature h4{ font-size:17px; }

  /* indica grid — cta card ocupa linha inteira */
  .indica-grid{ gap:14px; }
  .indica--cta{ padding:24px; }

  /* device-note / proto-intro */
  .device-note{ padding:28px 22px; }

  /* equipa */
  .team{ gap:32px; }
  .team__photo img{ border-radius:16px; }

  /* closing */
  .closing h2{ font-size:clamp(28px,7vw,36px); }
  .closing p{ font-size:15px; }

  /* footer */
  .footer{ padding-block:48px 32px; }
  .footer__bar{ flex-direction:column; gap:8px; text-align:center; font-size:12px; }

  /* helper: <br class="brk-desktop"> some no mobile */
  .brk-desktop{ display:none; }
}
