/* ============================================================
   AUDPEX — Sistema Visual Compartilhado
   "Saúde Estratégica" · Teal Imersivo
   ============================================================ */

:root{
  /* Teal */
  --teal:#1A7A6E;
  --teal-dark:#0D5A51;
  --teal-deep:#0D3D38;
  --teal-light:#E8F5F3;
  --teal-ultra:#F4FAF9;
  /* Neutrals */
  --off:#FAFAF8;
  --surface:#FFFFFF;
  --border:#E8EAE6;
  --ink:#16302C;
  --muted:#5C6B67;
  --muted-light:#8A968F;
  /* Gold accent */
  --gold:#C4A55A;
  --gold-soft:#D8C290;
  /* WhatsApp */
  --wa-green:#25D366;
  /* Shadows */
  --shadow-card:0 4px 24px rgba(13,61,56,.06);
  --shadow-card-hover:0 16px 44px rgba(13,61,56,.12);
  --shadow-float:0 10px 30px rgba(13,61,56,.18);
  /* Layout */
  --maxw:1240px;
  --pad:clamp(24px,5vw,64px);
  --radius:12px;
  --radius-lg:18px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'DM Sans',system-ui,sans-serif;
  color:var(--ink);
  background:var(--off);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.6;
}
img{max-width:100%;display:block;}
a{color:inherit;}
.serif{font-family:'Playfair Display',Georgia,serif;}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);}
.section{padding-block:clamp(72px,9vw,128px);}
.section--ultra{background:var(--teal-ultra);}
.section--white{background:var(--surface);}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);margin:0 0 18px;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--gold);display:inline-block;}
.eyebrow.center{justify-content:center;}
.h2{
  font-family:'Playfair Display',serif;font-weight:500;
  font-size:clamp(30px,4vw,44px);line-height:1.12;letter-spacing:-.01em;
  color:var(--ink);margin:0;text-wrap:balance;
}
.h2 em{font-style:italic;color:var(--teal);}
.lead{font-size:clamp(17px,1.7vw,19px);line-height:1.7;color:var(--muted);max-width:60ch;text-wrap:pretty;}
.section-head{max-width:760px;margin:0 0 56px;}
.section-head.center{margin-inline:auto;text-align:center;}
.section-head .lead{margin-top:20px;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'DM Sans',sans-serif;font-size:15.5px;font-weight:600;
  padding:14px 26px;border-radius:9px;text-decoration:none;cursor:pointer;
  border:1.5px solid transparent;transition:background .2s,color .2s,border-color .2s,transform .2s,box-shadow .2s;
  white-space:nowrap;
}
.btn svg{width:17px;height:17px;flex:none;}
.btn--primary{background:var(--teal);color:#fff;border-color:var(--teal);}
.btn--primary:hover{background:var(--teal-dark);border-color:var(--teal-dark);transform:translateY(-1px);}
.btn--gold{background:var(--gold);color:var(--teal-deep);border-color:var(--gold);}
.btn--gold:hover{background:var(--gold-soft);border-color:var(--gold-soft);transform:translateY(-1px);}
.btn--outline{background:transparent;color:var(--teal);border-color:var(--teal);}
.btn--outline:hover{background:var(--teal);color:#fff;}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5);}
.btn--ghost-light:hover{background:rgba(255,255,255,.12);border-color:#fff;}
.btn--lg{padding:17px 32px;font-size:16.5px;}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .3s,box-shadow .3s,backdrop-filter .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
.site-header__inner{
  max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);
  height:78px;display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.site-header__logo{height:38px;width:auto;transition:opacity .2s;}
.site-header__logo.dark{display:none;}
.site-nav{display:flex;align-items:center;gap:34px;}
.site-nav a{
  font-size:15px;font-weight:500;text-decoration:none;color:#fff;
  letter-spacing:.005em;position:relative;padding-block:6px;transition:color .2s;
}
.site-nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--gold);transition:width .25s;
}
.site-nav a:hover::after,.site-nav a.active::after{width:100%;}
.site-header__cta{display:flex;align-items:center;gap:8px;}
.header-social{display:flex;align-items:center;gap:6px;margin-right:6px;}
.header-social__btn{
  width:36px;height:36px;border-radius:9px;flex:none;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.22);
  transition:background .2s,color .2s,border-color .2s,transform .2s;
}
.header-social__btn svg{width:18px;height:18px;}
.header-social__btn:hover{background:var(--gold);color:var(--teal-deep);border-color:var(--gold);transform:translateY(-1px);}
.header-wa{
  display:inline-flex;align-items:center;gap:9px;
  font-size:14.5px;font-weight:600;padding:11px 20px;border-radius:9px;text-decoration:none;
  background:var(--gold);color:var(--teal-deep);transition:background .2s,transform .2s;
}
.header-wa svg{width:16px;height:16px;}
.header-wa:hover{background:var(--gold-soft);transform:translateY(-1px);}

/* scrolled state -> light header */
.site-header.scrolled{
  background:rgba(255,255,255,.86);backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom-color:var(--border);box-shadow:0 6px 24px rgba(13,61,56,.05);
}
.site-header.scrolled .site-header__logo.light{display:none;}
.site-header.scrolled .site-header__logo.dark{display:block;}
.site-header.scrolled .site-nav a{color:var(--ink);}
.site-header.scrolled .site-nav a:hover{color:var(--teal);}
.site-header.scrolled .header-wa{background:var(--teal);color:#fff;}
.site-header.scrolled .header-social__btn{color:var(--teal-dark);border-color:var(--border);}
.site-header.scrolled .header-social__btn:hover{background:var(--teal);color:#fff;border-color:var(--teal);}
.site-header.scrolled .header-wa:hover{background:var(--teal-dark);}
.site-header.scrolled .nav-toggle span{background:var(--ink);}

/* pages with a light hero want the light header from the start */
.header-light .site-header:not(.scrolled){
  background:rgba(255,255,255,.9);backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);border-bottom-color:var(--border);
}
.header-light .site-header:not(.scrolled) .site-header__logo.light{display:none;}
.header-light .site-header:not(.scrolled) .site-header__logo.dark{display:block;}
.header-light .site-header:not(.scrolled) .site-nav a{color:var(--ink);}
.header-light .site-header:not(.scrolled) .header-wa{background:var(--teal);color:#fff;}
.header-light .site-header:not(.scrolled) .header-social__btn{color:var(--teal-dark);border-color:var(--border);}
.header-light .site-header:not(.scrolled) .header-social__btn:hover{background:var(--teal);color:#fff;border-color:var(--teal);}
.header-light .site-header:not(.scrolled) .nav-toggle span{background:var(--ink);}

/* mobile nav toggle */
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.nav-toggle span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.3s;}

/* ---------- Hero (teal immersive) ---------- */
.hero{
  position:relative;overflow:hidden;color:#fff;
  background:radial-gradient(125% 120% at 82% -10%, #1B8073 0%, var(--teal-dark) 52%, var(--teal-deep) 100%);
}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(40% 50% at 12% 100%, rgba(196,165,90,.10), transparent 70%),
    radial-gradient(30% 40% at 95% 30%, rgba(255,255,255,.06), transparent 70%);
}
.hero__inner{
  max-width:var(--maxw);margin:0 auto;padding:148px var(--pad) 110px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,5vw,72px);align-items:center;
  position:relative;z-index:2;
}
.hero__eyebrow{color:var(--gold-soft);}
.hero__eyebrow::before{background:var(--gold-soft);}
.hero h1{
  font-family:'Playfair Display',serif;font-weight:500;
  font-size:clamp(38px,4.6vw,60px);line-height:1.07;letter-spacing:-.012em;
  margin:0 0 24px;text-wrap:balance;
}
.hero h1 em{font-style:italic;color:var(--gold-soft);}
.hero__sub{font-size:clamp(17px,1.6vw,19px);line-height:1.72;color:rgba(255,255,255,.84);max-width:56ch;margin:0 0 34px;}
.hero__ctas{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:40px;}
.hero__cred{display:flex;flex-wrap:wrap;gap:0;border-top:1px solid rgba(255,255,255,.18);padding-top:24px;max-width:640px;}
.hero__cred span{
  font-size:14px;font-weight:500;color:rgba(255,255,255,.9);
  padding:4px 22px;border-right:1px solid rgba(255,255,255,.18);
}
.hero__cred span:first-child{padding-left:0;}
.hero__cred span:last-child{border-right:none;}
.hero__media{position:relative;height:clamp(420px,52vw,560px);}
.hero__media image-slot,.hero__media .photo{width:100%;height:100%;border-radius:var(--radius-lg);overflow:hidden;}
.hero__media img.photo,.founder__photo img.photo,img.photo{object-fit:cover;object-position:center 22%;display:block;}
.hero__media::after{
  content:"";position:absolute;inset:20px -20px -20px 20px;
  border:1.5px solid var(--gold);border-radius:var(--radius-lg);z-index:-1;
}
/* make the fillable slot read on the dark teal hero until a photo is dropped */
.hero__media image-slot::part(frame){background:rgba(255,255,255,.07);}
.hero__media image-slot::part(empty){color:rgba(255,255,255,.85);}
.hero__badge{
  position:absolute;left:-26px;bottom:46px;z-index:3;
  background:#fff;color:var(--ink);border-radius:14px;padding:16px 20px;
  display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-float);
}
.hero__badge .n{font-family:'Playfair Display',serif;font-weight:600;font-size:34px;color:var(--teal);line-height:1;}
.hero__badge .l{font-size:12.5px;line-height:1.35;color:var(--muted);}

/* ---------- Page hero (interior, light) ---------- */
.page-hero{
  background:linear-gradient(180deg,var(--teal-ultra),var(--off));
  padding:148px var(--pad) clamp(56px,7vw,84px);
  border-bottom:1px solid var(--border);position:relative;overflow:hidden;
}
.page-hero__inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2;}
.page-hero h1{
  font-family:'Playfair Display',serif;font-weight:500;
  font-size:clamp(34px,4.4vw,52px);line-height:1.1;letter-spacing:-.01em;
  margin:14px 0 0;max-width:18ch;text-wrap:balance;
}
.page-hero h1 em{font-style:italic;color:var(--teal);}
.page-hero .lead{margin-top:22px;}
.page-hero__deco{
  position:absolute;right:-120px;top:-80px;width:440px;height:440px;border-radius:50%;
  border:1.5px solid var(--teal-light);pointer-events:none;
}
.page-hero__deco::after{
  content:"";position:absolute;inset:60px;border-radius:50%;border:1.5px solid rgba(196,165,90,.3);
}
.breadcrumb{font-size:13.5px;color:var(--muted);display:flex;gap:8px;align-items:center;}
.breadcrumb a{color:var(--muted);text-decoration:none;}
.breadcrumb a:hover{color:var(--teal);}
.breadcrumb span{color:var(--gold);}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:24px;}
.grid--2{grid-template-columns:repeat(2,1fr);}
.grid--3{grid-template-columns:repeat(3,1fr);}
.grid--4{grid-template-columns:repeat(4,1fr);}

.card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow-card);
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover);border-color:var(--teal-light);}
.icon-badge{
  width:52px;height:52px;border-radius:13px;background:var(--teal-light);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;flex:none;
}
.icon-badge svg{width:26px;height:26px;stroke:var(--teal);fill:none;stroke-width:1.6;}
.card h3{font-family:'DM Sans',sans-serif;font-size:20px;font-weight:600;margin:0 0 10px;color:var(--ink);letter-spacing:-.01em;}
.card p{font-size:15.5px;line-height:1.65;color:var(--muted);margin:0;}
.card__tag{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);}

/* numbered list cards (differentials / process) */
.num-card{position:relative;}
.num-card .num{
  font-family:'Playfair Display',serif;font-size:18px;font-weight:600;color:var(--teal);
  width:44px;height:44px;border-radius:50%;border:1.5px solid var(--teal-light);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
}

/* ---------- Problem section list ---------- */
.checklist{list-style:none;padding:0;margin:0;display:grid;gap:14px;}
.checklist li{display:flex;gap:14px;align-items:flex-start;font-size:16.5px;color:var(--ink);}
.checklist li svg{width:22px;height:22px;flex:none;margin-top:2px;}
.x-mark{stroke:#C0654E;}
.check-mark{stroke:var(--teal);}

/* ---------- Founders ---------- */
.founder{display:grid;grid-template-columns:300px 1fr;gap:40px;align-items:center;}
.founder__photo image-slot,.founder__photo .photo{width:300px;height:360px;border-radius:var(--radius-lg);overflow:hidden;}
.founder__photo{position:relative;}
.founder__photo::after{content:"";position:absolute;inset:auto -16px -16px auto;width:120px;height:120px;border:1.5px solid var(--gold);border-radius:14px;z-index:-1;}
.founder h3{font-family:'Playfair Display',serif;font-weight:600;font-size:26px;margin:0;color:var(--ink);}
.founder .role{font-size:13.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin:8px 0 18px;}
.founder p{font-size:16px;line-height:1.72;color:var(--muted);margin:0;}

/* ---------- Process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;counter-reset:step;position:relative;}
.step{padding:0 26px;position:relative;}
.step:not(:last-child)::after{content:"";position:absolute;right:0;top:24px;width:1px;height:calc(100% - 24px);background:var(--border);}
.step__n{
  width:48px;height:48px;border-radius:50%;background:var(--teal);color:#fff;
  font-family:'Playfair Display',serif;font-size:20px;font-weight:600;
  display:flex;align-items:center;justify-content:center;margin-bottom:22px;
}
.step h3{font-size:18px;font-weight:600;margin:0 0 10px;color:var(--ink);}
.step p{font-size:15px;line-height:1.6;color:var(--muted);margin:0;}

/* ---------- Quote / credibility block ---------- */
.quote-block{
  background:linear-gradient(160deg,var(--teal) 0%,var(--teal-dark) 100%);
  border-radius:var(--radius-lg);padding:clamp(40px,5vw,68px);color:#fff;position:relative;overflow:hidden;
}
.quote-block::before{
  content:"\201C";position:absolute;top:-30px;left:30px;font-family:'Playfair Display',serif;
  font-size:200px;color:rgba(255,255,255,.08);line-height:1;
}
.quote-block p{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(22px,2.6vw,30px);line-height:1.4;margin:0;position:relative;text-wrap:balance;}
.quote-block .cite{margin-top:26px;font-family:'DM Sans',sans-serif;font-size:15px;color:var(--gold-soft);font-weight:600;letter-spacing:.02em;}

/* ---------- Final CTA ---------- */
.cta-final{
  background:radial-gradient(120% 130% at 50% 0%, #1B8073 0%, var(--teal-dark) 55%, var(--teal-deep) 100%);
  color:#fff;text-align:center;position:relative;overflow:hidden;
}
.cta-final::after{
  content:"";position:absolute;left:50%;top:-200px;transform:translateX(-50%);
  width:560px;height:560px;border-radius:50%;border:1.5px solid rgba(196,165,90,.22);pointer-events:none;
}
.cta-final h2{font-family:'Playfair Display',serif;font-weight:500;font-size:clamp(30px,4vw,46px);line-height:1.12;margin:0 auto;max-width:18ch;text-wrap:balance;}
.cta-final h2 em{font-style:italic;color:var(--gold-soft);}
.cta-final .lead{color:rgba(255,255,255,.84);margin:22px auto 36px;text-align:center;}
.cta-final .hero__ctas{justify-content:center;margin-bottom:34px;}
.cta-final .hero__cred{justify-content:center;border-color:rgba(255,255,255,.2);margin-inline:auto;}

/* ---------- Footer ---------- */
.site-footer{background:var(--teal-deep);color:rgba(255,255,255,.72);padding-block:64px 32px;}
.site-footer__top{
  max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:44px;
}
.site-footer__logo{height:40px;margin-bottom:20px;}
.site-footer p{font-size:14.5px;line-height:1.7;margin:0 0 18px;max-width:34ch;}
.footer-social{margin-top:8px;}
.footer-social__label{display:block;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:12px;}
.footer-social__row{display:flex;gap:12px;}
.footer-social__btn{
  width:42px;height:42px;border-radius:11px;flex:none;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.82);
  transition:background .2s,color .2s,border-color .2s,transform .2s;
}
.footer-social__btn svg{width:20px;height:20px;}
.footer-social__btn:hover{background:var(--gold);color:var(--teal-deep);border-color:var(--gold);transform:translateY(-2px);}
.site-footer h4{font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);margin:0 0 18px;}
.site-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:12px;}
.site-footer a{color:rgba(255,255,255,.72);text-decoration:none;font-size:14.5px;transition:color .2s;}
.site-footer a:hover{color:#fff;}
.footer-contact{display:grid;gap:14px;}
.footer-contact a{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;}
.footer-contact svg{width:18px;height:18px;stroke:var(--gold-soft);fill:none;stroke-width:1.6;flex:none;margin-top:1px;}
.site-footer__bottom{
  max-width:var(--maxw);margin:48px auto 0;padding:24px var(--pad) 0;
  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,.5);
}

/* ---------- Floating WhatsApp ---------- */
.wa-float{
  position:fixed;right:26px;bottom:26px;z-index:90;
  width:58px;height:58px;border-radius:50%;background:var(--wa-green);
  display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(37,211,102,.4);
  transition:transform .25s,box-shadow .25s;text-decoration:none;
}
.wa-float svg{width:30px;height:30px;fill:#fff;}
.wa-float:hover{transform:scale(1.07) translateY(-2px);box-shadow:0 16px 36px rgba(37,211,102,.5);}
.wa-float::before{
  content:"";position:absolute;inset:0;border-radius:50%;background:var(--wa-green);
  animation:wa-pulse 2.4s ease-out infinite;z-index:-1;
}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.5;}70%,100%{transform:scale(1.6);opacity:0;}}

/* ---------- FAQ accordion ---------- */
.faq{max-width:840px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--border);}
.faq-q{
  width:100%;background:none;border:none;cursor:pointer;text-align:left;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:26px 4px;font-family:'DM Sans',sans-serif;font-size:18px;font-weight:600;color:var(--ink);
}
.faq-q:hover{color:var(--teal);}
.faq-icon{width:24px;height:24px;flex:none;position:relative;transition:transform .3s;}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;background:var(--teal);border-radius:2px;}
.faq-icon::before{top:11px;left:4px;width:16px;height:2px;}
.faq-icon::after{top:4px;left:11px;width:2px;height:16px;transition:transform .3s;}
.faq-item.open .faq-icon::after{transform:rotate(90deg);}
.faq-a{overflow:hidden;max-height:0;transition:max-height .35s ease;}
.faq-a p{font-size:16px;line-height:1.72;color:var(--muted);margin:0;padding:0 4px 28px;max-width:70ch;}

/* ---------- Forms ---------- */
.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:clamp(28px,4vw,44px);box-shadow:var(--shadow-card);}
.field{margin-bottom:20px;}
.field label{display:block;font-size:14px;font-weight:600;color:var(--ink);margin-bottom:8px;}
.field input,.field select,.field textarea{
  width:100%;font-family:'DM Sans',sans-serif;font-size:15.5px;color:var(--ink);
  padding:13px 15px;border:1.5px solid var(--border);border-radius:9px;background:var(--off);
  transition:border-color .2s,box-shadow .2s,background .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 3px rgba(26,122,110,.12);
}
.field textarea{resize:vertical;min-height:120px;}
.field.error input,.field.error select,.field.error textarea{border-color:#C0654E;}
.field .err-msg{display:none;color:#C0654E;font-size:13px;margin-top:6px;}
.field.error .err-msg{display:block;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form-success{display:none;text-align:center;padding:24px;}
.form-success.show{display:block;}
.form-success svg{width:56px;height:56px;margin:0 auto 16px;stroke:var(--teal);fill:none;stroke-width:1.5;}

/* ---------- Info / contact tiles ---------- */
.info-tile{display:flex;gap:16px;align-items:flex-start;padding:22px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:border-color .2s,box-shadow .2s;}
.info-tile:hover{border-color:var(--teal-light);box-shadow:var(--shadow-card);}
.info-tile .ic{width:46px;height:46px;border-radius:11px;background:var(--teal-light);display:flex;align-items:center;justify-content:center;flex:none;}
.info-tile .ic svg{width:22px;height:22px;stroke:var(--teal);fill:none;stroke-width:1.6;}
.info-tile h4{font-size:16px;font-weight:600;margin:0 0 4px;color:var(--ink);}
.info-tile p,.info-tile a{font-size:14.5px;color:var(--muted);margin:0;text-decoration:none;line-height:1.5;}
.info-tile a:hover{color:var(--teal);}

/* ---------- Pills / tags row ---------- */
.pill-row{display:flex;flex-wrap:wrap;gap:10px;}
.pill{font-size:13.5px;font-weight:500;color:var(--teal-dark);background:var(--teal-light);padding:8px 16px;border-radius:100px;}

/* ---------- Reveal animation ----------
   Hidden state is gated behind html.js so content is always visible
   without JS. A failsafe (html.reveal-fallback) force-reveals when the
   compositor is paused / rAF is dead (headless capture, background tab). */
html.js [data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
html.js [data-reveal].in{opacity:1;transform:none;}
html.js [data-reveal][data-reveal-delay="1"]{transition-delay:.08s;}
html.js [data-reveal][data-reveal-delay="2"]{transition-delay:.16s;}
html.js [data-reveal][data-reveal-delay="3"]{transition-delay:.24s;}
html.js [data-reveal][data-reveal-delay="4"]{transition-delay:.32s;}
html.reveal-fallback [data-reveal]{opacity:1 !important;transform:none !important;transition:none !important;}
@media (prefers-reduced-motion:reduce){
  html.js [data-reveal]{opacity:1;transform:none;transition:none;}
  .wa-float::before{animation:none;}
  html{scroll-behavior:auto;}
}

/* ---------- Mobile nav drawer ---------- */
.mobile-drawer{
  position:fixed;inset:0;z-index:200;background:var(--teal-deep);color:#fff;
  display:flex;flex-direction:column;padding:28px var(--pad);
  transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.mobile-drawer.open{transform:none;}
.mobile-drawer__head{display:flex;justify-content:space-between;align-items:center;height:50px;}
.mobile-drawer__head img{height:34px;}
.mobile-drawer__close{background:none;border:none;color:#fff;font-size:30px;cursor:pointer;line-height:1;padding:4px;}
.mobile-drawer nav{display:flex;flex-direction:column;gap:6px;margin-top:40px;}
.mobile-drawer nav a{font-family:'Playfair Display',serif;font-size:26px;color:#fff;text-decoration:none;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.1);}
.mobile-drawer .btn{margin-top:32px;justify-content:center;}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1024px){
  .grid--4{grid-template-columns:repeat(2,1fr);}
  .steps{grid-template-columns:repeat(2,1fr);gap:36px 0;}
  .step:nth-child(2)::after{display:none;}
  .site-footer__top{grid-template-columns:1fr 1fr;gap:36px;}
}
@media (max-width:860px){
  .site-nav,.site-header__cta .header-wa,.header-social{display:none;}
  .nav-toggle{display:flex;}
  .hero__inner{grid-template-columns:1fr;padding-top:128px;padding-bottom:80px;}
  .hero__media{order:-1;height:340px;}
  .hero__badge{left:auto;right:16px;bottom:16px;}
  .founder{grid-template-columns:1fr;gap:26px;text-align:left;}
  .founder__photo image-slot,.founder__photo .photo,.founder__photo{width:100%;max-width:340px;height:300px;}
  .grid--2,.grid--3{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .grid--4{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .step::after{display:none !important;}
  .form-row{grid-template-columns:1fr;}
  .site-footer__top{grid-template-columns:1fr;}
  .hero__cred span{padding:4px 14px;}
  .hero__cred span:first-child{padding-left:0;}
}
