/* ============================================================
   SaluVista — shared stylesheet
   Design: "clinical serenity" — deep healing teal + restrained
   brass, warm ivory ground, editorial Fraunces display type.
   Signature: the "vista arch" — arched image tops echoing the
   name (a calm view through an arch).
   ============================================================ */

:root{
  --pine:#1B2559;
  --pine-deep:#121A44;
  --pine-700:#26327C;
  --brass:#273ED4;
  --brass-soft:#DFCFF9;
  --ivory:#FFFFFF;
  --mint:#F4F1FD;
  --mint-deep:#E4DBF7;
  --ink:#232744;
  --muted:#63678A;
  --line:#E9E5F6;
  --white:#ffffff;

  --font-display:"Crimson Text",Georgia,"Times New Roman",serif;
  --font-body:"Amaranth",system-ui,-apple-system,"Segoe UI",sans-serif;

  --container:1180px;
  --radius:16px;
  --shadow-sm:0 1px 2px rgba(12,58,52,.06),0 4px 16px rgba(12,58,52,.05);
  --shadow-md:0 10px 40px rgba(12,58,52,.10);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--ivory);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.12;
  letter-spacing:-.01em;
  color:var(--ink);
  margin:0;
  font-optical-sizing:auto;
}
p{margin:0 0 1rem}

.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px}

/* ---- eyebrow label ---- */
.eyebrow{
  font-family:var(--font-body);
  font-size:.74rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--brass);
  display:inline-flex;
  align-items:center;
  gap:.6em;
  margin:0 0 1rem;
}
.eyebrow::before{
  content:"";width:26px;height:1px;background:var(--brass);display:inline-block;
}
.eyebrow--center{justify-content:center}
.eyebrow--center::after{content:"";width:26px;height:1px;background:var(--brass);display:inline-block}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-body);font-weight:700;font-size:.95rem;
  padding:.85em 1.6em;border-radius:100px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s,box-shadow .25s;
  line-height:1;white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em}
.btn--primary{background:var(--brass);color:#fff;box-shadow:0 6px 18px rgba(39,62,212,.30)}
.btn--primary:hover{transform:translateY(-2px);background:#1E31A8;box-shadow:0 10px 26px rgba(39,62,212,.38)}
.btn--dark{background:var(--pine);color:#fff}
.btn--dark:hover{transform:translateY(-2px);background:var(--pine-deep)}
.btn--ghost{background:transparent;border-color:var(--pine);color:var(--pine)}
.btn--ghost:hover{background:var(--pine);color:#fff;transform:translateY(-2px)}
.btn--wa{background:#1FA855;color:#fff;box-shadow:0 6px 18px rgba(31,168,85,.26)}
.btn--wa:hover{transform:translateY(-2px);background:#178c46}
.btn--light{background:#fff;color:var(--pine);}
.btn--light:hover{transform:translateY(-2px);background:var(--mint)}
.btn--outline-light{background:transparent;border-color:rgba(255,255,255,.5);color:#fff}
.btn--outline-light:hover{background:rgba(255,255,255,.12);border-color:#fff;transform:translateY(-2px)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(251,250,247,.86);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s,background .3s;
}
.site-header.is-scrolled{border-bottom-color:var(--line);box-shadow:0 4px 24px rgba(12,58,52,.05)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:76px}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.brand__logo{height:42px;width:auto;display:block}
.footer-brand .brand__logo{height:46px}
.brand__wordmark{font-family:var(--font-display);font-size:1.6rem;font-weight:600;color:#fff;letter-spacing:-.01em;line-height:1}
.brand__wordmark b{color:var(--brass-soft);font-weight:600}
@media(max-width:640px){.brand__logo{height:36px}}
.brand__mark{width:38px;height:38px;border-radius:11px;background:var(--pine);display:grid;place-items:center;flex-shrink:0}
.brand__mark svg{width:22px;height:22px}
.brand__name{font-family:var(--font-display);font-size:1.32rem;font-weight:600;letter-spacing:-.01em;color:var(--pine);line-height:1}
.brand__name b{color:var(--brass);font-weight:600}

.nav{display:flex;align-items:center;gap:4px}
.nav a{
  font-size:.92rem;font-weight:600;color:var(--ink);padding:.5em .85em;border-radius:8px;
  transition:color .2s,background .2s;position:relative;
}
.nav a:hover{color:var(--pine);background:var(--mint)}
.nav a.active{color:var(--pine)}
.nav a.active::after{content:"";position:absolute;left:.85em;right:.85em;bottom:.15em;height:2px;background:var(--brass);border-radius:2px}

.nav-drop{position:relative}
.nav-drop__panel{
  position:absolute;top:calc(100% + 8px);left:0;min-width:230px;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-md);padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);
  transition:opacity .2s,transform .2s,visibility .2s;
}
.nav-drop:hover .nav-drop__panel,.nav-drop:focus-within .nav-drop__panel{opacity:1;visibility:visible;transform:translateY(0)}
.nav-drop__panel a{display:block;padding:.6em .8em;border-radius:8px;font-size:.9rem}
.nav-drop__panel a::after{display:none}
.header-cta{display:flex;align-items:center;gap:10px;flex-shrink:0}

.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--pine)}
.menu-toggle svg{width:26px;height:26px}

/* mobile drawer */
.mobile-nav{
  position:fixed;inset:0 0 0 auto;width:min(340px,86vw);z-index:80;
  background:var(--ivory);box-shadow:-20px 0 60px rgba(12,58,52,.2);
  transform:translateX(100%);transition:transform .38s var(--ease);
  padding:26px 24px;overflow-y:auto;display:flex;flex-direction:column;
}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.mobile-nav__close{background:none;border:none;color:var(--ink);cursor:pointer;padding:6px}
.mobile-nav__close svg{width:26px;height:26px}
.mobile-nav a{padding:.8em 0;font-size:1.05rem;font-weight:600;border-bottom:1px solid var(--line)}
.mobile-nav .sub{padding-left:16px;font-size:.95rem;color:var(--muted);font-weight:600}
.mobile-nav .btn{margin-top:20px;justify-content:center}
.scrim{position:fixed;inset:0;background:rgba(12,32,29,.42);z-index:70;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.scrim.open{opacity:1;visibility:visible}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;padding:64px 0 72px}
.hero::before{
  content:"";position:absolute;top:-120px;right:-160px;width:520px;height:520px;
  background:radial-gradient(circle,var(--mint) 0%,transparent 68%);opacity:.9;z-index:0;
}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.5rem,5vw,4rem);letter-spacing:-.025em}
.hero h1 em{font-style:italic;color:var(--pine)}
.hero__lead{font-size:1.12rem;color:var(--muted);max-width:38ch;margin:1.4rem 0 2rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:1.8rem}
.hero__trust{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--muted)}
.hero__trust strong{color:var(--ink)}
.hero__stars{color:var(--brass);letter-spacing:2px}

/* vista arch image */
.arch{
  position:relative;border-radius:260px 260px 20px 20px;overflow:hidden;
  box-shadow:var(--shadow-md);aspect-ratio:4/5;border:6px solid #fff;
}
.arch img{width:100%;height:100%;object-fit:cover}
.hero__media{position:relative}
.credential{
  position:absolute;left:-18px;bottom:34px;background:#fff;border-radius:14px;
  padding:14px 18px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:12px;z-index:2;
}
.credential__num{font-family:var(--font-display);font-size:1.7rem;color:var(--pine);line-height:1;font-weight:600}
.credential__lbl{font-size:.78rem;color:var(--muted);line-height:1.3;font-weight:600;max-width:12ch}

/* ============================================================
   TRUST BAR
   ============================================================ */
.trustbar{background:var(--pine);color:#fff}
.trustbar__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:34px 0}
.trustbar__item{text-align:center;position:relative}
.trustbar__item:not(:last-child)::after{content:"";position:absolute;right:-12px;top:10%;height:80%;width:1px;background:rgba(255,255,255,.16)}
.trustbar__num{font-family:var(--font-display);font-size:2rem;color:var(--brass-soft);line-height:1;font-weight:600}
.trustbar__lbl{font-size:.86rem;color:rgba(255,255,255,.8);margin-top:6px;font-weight:600}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding:88px 0}
.section--mint{background:var(--mint)}
.section--pine{background:var(--pine);color:#fff}
.section-head{max-width:640px;margin-bottom:52px}
.section-head--center{margin-inline:auto;text-align:center}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
.section-head p{color:var(--muted);font-size:1.06rem;margin-top:1rem}
.section--pine .section-head p{color:rgba(255,255,255,.82)}
.section--pine h2,.section--pine h3{color:#fff}

/* service pillars (home + services) */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.pillar{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s;display:flex;flex-direction:column}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.pillar__media{aspect-ratio:1/1;overflow:hidden;border-radius:120px 120px 0 0;margin:14px 14px 0}
.pillar__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.pillar:hover .pillar__media img{transform:scale(1.05)}
.pillar__body{padding:20px 22px 26px;text-align:center;display:flex;flex-direction:column;flex:1}
.pillar h3{font-size:1.28rem;margin-bottom:.5rem}
.pillar p{font-size:.92rem;color:var(--muted);margin-bottom:1.1rem;flex:1}
.pillar__link{font-weight:700;font-size:.88rem;color:var(--pine);display:inline-flex;align-items:center;gap:.4em;justify-content:center}
.pillar__link svg{width:1em;height:1em;transition:transform .25s}
.pillar:hover .pillar__link svg{transform:translateX(3px)}

/* feature rows (why us) */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.feature{background:var(--ivory);border-radius:18px;padding:32px 28px;border:1px solid var(--line)}
.section--mint .feature{background:#fff}
.feature__icon{width:52px;height:52px;border-radius:13px;background:var(--mint);display:grid;place-items:center;margin-bottom:18px;color:var(--pine)}
.feature__icon svg{width:26px;height:26px}
.feature h3{font-size:1.24rem;margin-bottom:.55rem}
.feature p{font-size:.94rem;color:var(--muted);margin:0}

/* ============================================================
   PROCEDURE LIST (service detail pages)
   ============================================================ */
.page-hero{padding:56px 0 20px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:-140px;left:-140px;width:460px;height:460px;
  background:radial-gradient(circle,var(--mint) 0%,transparent 70%);z-index:0}
.page-hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr .82fr;gap:52px;align-items:center}
.page-hero h1{font-size:clamp(2.2rem,4.4vw,3.3rem)}
.page-hero__lead{color:var(--muted);font-size:1.08rem;margin:1.2rem 0 1.8rem}
.page-hero .arch{aspect-ratio:3/4;border-radius:220px 220px 20px 20px}

.proc-list{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.proc{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px 30px;transition:box-shadow .3s,transform .3s var(--ease)}
.proc:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.proc h3{font-size:1.3rem;margin-bottom:.7rem;display:flex;align-items:baseline;gap:.6rem}
.proc h3::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--brass);flex-shrink:0;transform:translateY(-2px)}
.proc p{font-size:.96rem;color:var(--muted);margin:0}
.proc ul{margin:.6rem 0 0;padding-left:1.1rem;color:var(--muted);font-size:.94rem}
.proc ul li{margin-bottom:.35rem}
.proc--wide{grid-column:1/-1}

/* ============================================================
   INSIGHTS / BLOG cards
   ============================================================ */
.insights{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.insight{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s;display:flex;flex-direction:column}
.insight:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.insight__media{aspect-ratio:16/10;overflow:hidden}
.insight__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.insight:hover .insight__media img{transform:scale(1.05)}
.insight__body{padding:22px 24px 26px;flex:1;display:flex;flex-direction:column}
.insight__tag{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);margin-bottom:.7rem}
.insight h3{font-size:1.16rem;line-height:1.25;margin-bottom:.6rem}
.insight p{font-size:.9rem;color:var(--muted);flex:1;margin-bottom:1rem}
.insight__link{font-weight:700;font-size:.85rem;color:var(--pine)}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{background:linear-gradient(135deg,var(--pine) 0%,var(--pine-deep) 100%);color:#fff;border-radius:26px;padding:60px 56px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;top:-80px;right:-60px;width:300px;height:300px;background:radial-gradient(circle,rgba(192,149,75,.25),transparent 70%)}
.cta-band::after{content:"";position:absolute;bottom:-90px;left:-70px;width:320px;height:320px;background:radial-gradient(circle,rgba(255,255,255,.06),transparent 70%)}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.6rem)}
.cta-band p{color:rgba(255,255,255,.85);max-width:52ch;margin:1rem auto 2rem;font-size:1.06rem}
.cta-band__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ============================================================
   TEAM
   ============================================================ */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.member{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;transition:box-shadow .3s,transform .3s var(--ease)}
.member:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.member__media{aspect-ratio:4/3;overflow:hidden;background:var(--mint)}
.member__media img{width:100%;height:100%;object-fit:cover}
.member__body{padding:22px 24px 26px}
.member__name{font-family:var(--font-display);font-size:1.3rem;color:var(--ink);font-weight:600}
.member__role{font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brass);margin:.3rem 0 .9rem}
.member p{font-size:.92rem;color:var(--muted);margin:0}

/* values grid (about) */
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.value{display:flex;gap:18px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px 26px}
.value__n{font-family:var(--font-display);font-size:1.5rem;color:var(--brass);font-weight:600;line-height:1;flex-shrink:0}
.value h3{font-size:1.18rem;margin-bottom:.4rem}
.value p{font-size:.93rem;color:var(--muted);margin:0}

/* split content (about story) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split .arch{aspect-ratio:5/4;border-radius:20px 20px 200px 200px}
.prose h3{font-size:1.5rem;margin:1.6rem 0 .6rem}
.prose h3:first-child{margin-top:0}
.prose p{color:var(--muted)}

/* ============================================================
   FAQ accordion
   ============================================================ */
.faq-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:34px;justify-content:center}
.faq-tab{font-size:.86rem;font-weight:700;padding:.55em 1.1em;border-radius:100px;border:1.5px solid var(--line);background:#fff;color:var(--muted);cursor:pointer;transition:all .2s}
.faq-tab.active,.faq-tab:hover{background:var(--pine);color:#fff;border-color:var(--pine)}
.faq-list{max-width:820px;margin-inline:auto}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden;transition:box-shadow .25s}
.faq-item[open]{box-shadow:var(--shadow-sm)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 26px;display:flex;justify-content:space-between;align-items:center;gap:18px;font-family:var(--font-display);font-size:1.12rem;font-weight:500;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .plus{width:24px;height:24px;flex-shrink:0;position:relative;transition:transform .3s}
.faq-item summary .plus::before,.faq-item summary .plus::after{content:"";position:absolute;background:var(--brass);border-radius:2px}
.faq-item summary .plus::before{top:11px;left:3px;right:3px;height:2px}
.faq-item summary .plus::after{left:11px;top:3px;bottom:3px;width:2px;transition:transform .3s}
.faq-item[open] summary .plus::after{transform:rotate(90deg)}
.faq-answer{padding:0 26px 24px;color:var(--muted);font-size:.98rem}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:52px;align-items:start}
.contact-info{background:var(--pine);color:#fff;border-radius:22px;padding:40px 38px}
.contact-info h2{color:#fff;font-size:1.8rem;margin-bottom:.6rem}
.contact-info>p{color:rgba(255,255,255,.82);font-size:.98rem;margin-bottom:2rem}
.contact-line{display:flex;gap:14px;align-items:flex-start;margin-bottom:22px}
.contact-line__icon{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.1);display:grid;place-items:center;flex-shrink:0;color:var(--brass-soft)}
.contact-line__icon svg{width:22px;height:22px}
.contact-line__lbl{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6);font-weight:700}
.contact-line__val{font-size:1.02rem;font-weight:600;color:#fff}
.contact-line__val a:hover{color:var(--brass-soft)}
.social-row{display:flex;gap:12px;margin-top:26px}
.social-row a{width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.1);display:grid;place-items:center;transition:background .2s,transform .2s;color:#fff}
.social-row a:hover{background:var(--brass);transform:translateY(-3px)}
.social-row svg{width:20px;height:20px}

.form-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:38px 36px;box-shadow:var(--shadow-sm)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.82rem;font-weight:700;color:var(--ink);margin-bottom:.45rem}
.field input,.field textarea,.field select{
  width:100%;padding:.85em 1em;border:1.5px solid var(--line);border-radius:11px;
  font-family:var(--font-body);font-size:.98rem;color:var(--ink);background:var(--ivory);
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--pine);box-shadow:0 0 0 3px rgba(18,77,69,.12);background:#fff;
}
.field textarea{resize:vertical;min-height:120px}
.form-note{font-size:.82rem;color:var(--muted);margin-top:14px;text-align:center}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--pine-deep);color:rgba(255,255,255,.72);padding:64px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:44px}
.footer-brand .brand__name{color:#fff}
.footer-about{font-size:.92rem;line-height:1.7;margin:18px 0 0;max-width:34ch}
.footer-col h4{font-family:var(--font-body);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass-soft);margin-bottom:16px;font-weight:700}
.footer-col a{display:block;font-size:.92rem;padding:.32em 0;color:rgba(255,255,255,.72);transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:.84rem}
.footer-bottom a:hover{color:#fff}
.footer-social{display:flex;gap:10px}
.footer-social a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:background .2s,transform .2s}
.footer-social a:hover{background:var(--brass);transform:translateY(-2px)}
.footer-social svg{width:18px;height:18px;color:#fff}

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:55;width:60px;height:60px;border-radius:50%;
  background:#1FA855;display:grid;place-items:center;box-shadow:0 8px 26px rgba(31,168,85,.44);
  transition:transform .25s var(--ease);
}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:32px;height:32px;color:#fff}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #1FA855;animation:waPulse 2.4s ease-out infinite}
@keyframes waPulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.5);opacity:0}}

/* announcement strip */
.topbar{background:var(--pine-deep);color:rgba(255,255,255,.9);font-size:.82rem;text-align:center;padding:8px 16px;font-weight:600}
.topbar a{color:var(--brass-soft);text-decoration:underline;text-underline-offset:2px}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero__media{max-width:440px;margin-inline:auto;width:100%}
  .page-hero-grid{grid-template-columns:1fr;gap:36px}
  .page-hero__media{max-width:400px;margin-inline:auto;width:100%}
  .pillars{grid-template-columns:repeat(2,1fr)}
  .trustbar__grid{grid-template-columns:repeat(2,1fr);gap:28px 16px}
  .trustbar__item:nth-child(2)::after{display:none}
  .feature-grid{grid-template-columns:1fr}
  .insights{grid-template-columns:1fr}
  .team{grid-template-columns:1fr}
  .values{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:36px}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .nav,.header-cta .btn--ghost{display:none}
  .menu-toggle{display:block}
}
@media(max-width:620px){
  body{font-size:16px}
  .section{padding:60px 0}
  .hero{padding:40px 0 52px}
  .proc-list{grid-template-columns:1fr}
  .pillars{grid-template-columns:1fr;max-width:360px;margin-inline:auto}
  .form-row{grid-template-columns:1fr}
  .cta-band{padding:44px 26px}
  .contact-info,.form-card{padding:30px 24px}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{justify-content:center;text-align:center}
  .header-cta .btn--primary{padding:.7em 1.1em;font-size:.85rem}
  .credential{left:6px}
}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
:focus-visible{outline:3px solid var(--brass);outline-offset:2px;border-radius:4px}

/* ============================================================
   V2 — CINEMATIC LAYER (brand-strict: #273ED4 / #DFCFF9 / #fff)
   ============================================================ */

/* ---- Scroll progress bar ---- */
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--brass),#5A6CE8);z-index:200;transition:width .08s linear}

/* ---- Header hide/show on scroll ---- */
.site-header{transform:translateY(0);transition:transform .38s var(--ease),border-color .3s,box-shadow .3s,background .3s}
.site-header.is-hidden{transform:translateY(-110%)}

/* ---- Hero: ambient animated backdrop ---- */
.hero{position:relative;overflow:hidden}
.hero::before,.hero::after{content:"";position:absolute;border-radius:50%;filter:blur(70px);opacity:.55;z-index:0;pointer-events:none}
.hero::before{width:520px;height:520px;right:-140px;top:-160px;background:radial-gradient(circle,var(--brass-soft) 0%,transparent 65%);animation:drift 16s ease-in-out infinite alternate}
.hero::after{width:420px;height:420px;left:-160px;bottom:-180px;background:radial-gradient(circle,rgba(39,62,212,.14) 0%,transparent 65%);animation:drift 20s ease-in-out -6s infinite alternate-reverse}
@keyframes drift{from{transform:translate(0,0) scale(1)}to{transform:translate(46px,30px) scale(1.12)}}
.hero>.container{position:relative;z-index:1}

/* ---- Hero load-in sequence ---- */
@keyframes riseIn{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
.hero .anim{opacity:0;animation:riseIn .85s var(--ease) forwards}
.hero .anim-1{animation-delay:.05s}.hero .anim-2{animation-delay:.18s}
.hero .anim-3{animation-delay:.32s}.hero .anim-4{animation-delay:.46s}
.hero .anim-5{animation-delay:.60s}.hero .anim-6{animation-delay:.55s}

/* ---- Hero video reel in arch ---- */
.arch--video{position:relative;max-width:390px;margin-left:auto;aspect-ratio:4/5.1;border-radius:210px 210px 22px 22px;overflow:hidden;border:6px solid #fff;box-shadow:0 24px 70px -24px rgba(39,62,212,.35),var(--shadow-md);background:var(--mint)}
.arch--video::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px rgba(39,62,212,.10);pointer-events:none}
.arch--video video{width:100%;height:100%;object-fit:cover;display:block}
.hero__media{position:relative}
.hero__media .halo{position:absolute;inset:-26px -20px auto auto;width:78%;aspect-ratio:1;border-radius:50%;border:1.5px dashed rgba(39,62,212,.30);animation:spin 26s linear infinite;z-index:-1}
@keyframes spin{to{transform:rotate(360deg)}}
.reel-chip{position:absolute;left:-14px;bottom:88px;display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:100px;padding:9px 16px 9px 10px;box-shadow:var(--shadow-md);font-size:.8rem;font-weight:700;color:var(--pine)}
.reel-chip .dot{width:26px;height:26px;border-radius:50%;background:var(--brass);display:grid;place-items:center;flex-shrink:0}
.reel-chip .dot::after{content:"";width:0;height:0;border-left:8px solid #fff;border-top:5px solid transparent;border-bottom:5px solid transparent;margin-left:2px}
.reel-chip small{display:block;font-weight:600;color:var(--muted);font-size:.7rem;line-height:1.1}
.hero__media .credential{animation:floatY 5.5s ease-in-out infinite}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ---- Treatments marquee ribbon ---- */
.marquee{background:var(--brass-soft);border-top:1px solid #d4c2f2;border-bottom:1px solid #d4c2f2;overflow:hidden;padding:16px 0;position:relative}
.marquee__track{display:flex;gap:0;width:max-content;animation:marquee 30s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__item{display:flex;align-items:center;gap:26px;padding-right:26px;white-space:nowrap;font-family:var(--font-display);font-size:1.08rem;font-style:italic;color:var(--pine-deep)}
.marquee__item svg{width:14px;height:14px;color:var(--brass);flex-shrink:0}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---- Reveal v2: variants + stagger ---- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal--left{transform:translateX(-34px)}
.reveal--right{transform:translateX(34px)}
.reveal--zoom{transform:scale(.94)}
.reveal.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.stagger.in>*{opacity:1;transform:none}
.stagger.in>*:nth-child(1){transition-delay:.03s}.stagger.in>*:nth-child(2){transition-delay:.11s}
.stagger.in>*:nth-child(3){transition-delay:.19s}.stagger.in>*:nth-child(4){transition-delay:.27s}
.stagger.in>*:nth-child(5){transition-delay:.35s}.stagger.in>*:nth-child(6){transition-delay:.43s}
.stagger.in>*:nth-child(7){transition-delay:.51s}.stagger.in>*:nth-child(8){transition-delay:.59s}

/* ---- Image shine on reveal ---- */
.arch,.pillar__media,.insight__media,.member__photo{position:relative;overflow:hidden}
.reveal.in .arch img{animation:imgIn 1.1s var(--ease)}
@keyframes imgIn{from{transform:scale(1.08)}to{transform:scale(1)}}

/* ---- Button shine sweep ---- */
.btn{position:relative;overflow:hidden}
.btn::before{content:"";position:absolute;top:0;left:-80%;width:50%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-20deg);transition:left .6s var(--ease)}
.btn:hover::before{left:130%}

/* ---- Card hover polish ---- */
.pillar:hover,.insight:hover,.member:hover{transform:translateY(-8px);box-shadow:0 22px 54px -18px rgba(39,62,212,.22)}
.pillar:hover .pillar__media img,.insight:hover .insight__media img{transform:scale(1.07)}
.proc:hover{transform:translateY(-5px);box-shadow:0 16px 40px -16px rgba(39,62,212,.18);border-color:var(--mint-deep)}

/* ---- Section head underline draw ---- */
.section-head h2{position:relative;display:inline-block}
.section-head h2::after{content:"";position:absolute;left:0;bottom:-10px;height:3px;width:0;border-radius:3px;background:linear-gradient(90deg,var(--brass),var(--brass-soft));transition:width .9s var(--ease) .25s}
.section-head.in h2::after,.reveal.in .section-head h2::after,.section-head h2.in::after{width:56px}

/* ---- Reduced motion: calm everything ---- */
@media (prefers-reduced-motion: reduce){
  .hero::before,.hero::after,.hero__media .halo,.hero__media .credential,.marquee__track{animation:none!important}
  .hero .anim{opacity:1;animation:none}
  .stagger>*{opacity:1;transform:none;transition:none}
}
@media(max-width:960px){
  .arch--video{margin:0 auto;max-width:330px}
  .hero__media .halo{display:none}
}
