/* ===== Thrive Solutions — shared styles ===== */
:root{
  --ink:#16263F; --ink-2:#21426e; --soft:#475066; --faint:#8a8f9c;
  --paper:#F6F4EF; --paper-2:#efeadd; --line:#e2ddd0;
  --accent:#2E6B4A; --accent-br:#388a5e; --blue:#1E4FA3;
  --deep:#101d33;
  --maxw:1180px; --pad:clamp(20px,5vw,56px); --radius:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',sans-serif;background:var(--paper);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background:radial-gradient(1100px 560px at 82% -12%,rgba(46,107,74,.10),transparent 60%),
             radial-gradient(820px 460px at -8% 108%,rgba(30,79,163,.07),transparent 55%)}
a{color:inherit;text-decoration:none}
img{display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);position:relative;z-index:1}
.eyebrow{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:var(--accent);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);display:inline-block}

/* nav */
header.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:rgba(246,244,239,.8);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.55rem}
.brand img{height:36px;width:auto}
.brand .bname{font-weight:800;font-size:1.18rem;letter-spacing:-.015em;color:var(--ink);line-height:1}
.navlinks{display:flex;gap:2rem;align-items:center;font-size:.93rem;font-weight:500}
.navlinks a{color:var(--soft);transition:color .2s}
.navlinks a:hover,.navlinks a.active{color:var(--ink)}
.navlinks a.btn-primary,.navlinks a.btn-primary:hover{color:#fff}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.93rem;padding:.72rem 1.3rem;border-radius:999px;transition:.2s;cursor:pointer;border:1px solid transparent;font-family:inherit}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-br);transform:translateY(-1px)}
.btn-ghost{border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--paper-2)}
.btn-lg{padding:.95rem 1.7rem;font-size:1rem}
.nav-toggle{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--ink)}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* hero */
.hero{padding:clamp(64px,10vw,128px) 0 clamp(48px,7vw,84px)}
.hero .eyebrow{margin-bottom:1.6rem}
.hero h1{font-size:clamp(2.6rem,7vw,5.2rem);line-height:1.02;letter-spacing:-.035em;font-weight:800;max-width:15ch}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero .lede{margin-top:1.7rem;font-size:clamp(1.05rem,2vw,1.3rem);color:var(--soft);max-width:58ch;font-weight:400}
.hero .pay{margin-top:1.2rem;font-size:1.02rem;color:var(--ink);max-width:54ch;font-weight:500}
.hero-cta{display:flex;gap:1rem;margin-top:2.4rem;flex-wrap:wrap}
.hero-foot{margin-top:3.2rem;display:flex;gap:2.2rem;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:1.5rem;color:var(--faint);font-size:.85rem;font-weight:500}
.hero-foot span strong{color:var(--ink);font-weight:700;display:block;font-size:1.02rem;margin-bottom:.1rem}

/* sections */
section{padding:clamp(58px,8vw,104px) 0}
.sec-head{max-width:62ch;margin-bottom:clamp(2.2rem,5vw,3.4rem)}
.sec-head h2{font-size:clamp(1.9rem,4vw,3rem);letter-spacing:-.03em;line-height:1.08;font-weight:800;margin-top:1rem}
.sec-head p{margin-top:1rem;color:var(--soft);font-size:1.06rem;max-width:54ch}
.center{text-align:center;margin-left:auto;margin-right:auto}
.center .eyebrow{justify-content:center}

/* promise band */
.promise{background:var(--ink);color:var(--paper);border-radius:var(--radius)}
.promise .wrap{padding-top:clamp(46px,7vw,80px);padding-bottom:clamp(46px,7vw,80px)}
.promise .eyebrow{color:#bfe0cd}.promise .eyebrow::before{background:#bfe0cd}
.promise h2{font-size:clamp(1.8rem,3.6vw,2.6rem);letter-spacing:-.03em;line-height:1.14;font-weight:700;max-width:24ch;margin-top:1rem}
.promise p{margin-top:1.2rem;color:#cfe2d6;max-width:60ch;font-size:1.06rem}

/* services grid */
.cap-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.cap{background:var(--paper);padding:clamp(1.6rem,3vw,2.4rem);transition:background .25s}
.cap:hover{background:#fff}
.cap .n{font-size:.78rem;font-weight:700;color:var(--accent);letter-spacing:.1em}
.cap h3{font-size:1.3rem;margin:.7rem 0 .6rem;letter-spacing:-.01em;font-weight:700}
.cap p{color:var(--soft);font-size:.98rem;margin-bottom:1rem}
.cap ul{list-style:none;display:flex;flex-wrap:wrap;gap:.45rem}
.cap li{font-size:.79rem;font-weight:600;color:var(--soft);background:var(--paper-2);border:1px solid var(--line);padding:.32rem .7rem;border-radius:999px}

/* metrics */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2.5vw,2rem);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(2.2rem,5vw,3.2rem) 0}
.metric .num{font-size:clamp(2.3rem,5vw,3.5rem);font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--accent)}
.metric .lbl{margin-top:.7rem;color:var(--soft);font-size:.92rem;font-weight:500;max-width:24ch}

/* principle card */
.who-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.who-list{display:flex;flex-direction:column;gap:1.1rem}
.who-item{display:flex;gap:1rem;align-items:flex-start}
.who-item .dot{flex:none;width:30px;height:30px;border-radius:8px;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.85rem;margin-top:2px}
.who-item h4{font-size:1.05rem;font-weight:700}
.who-item p{color:var(--soft);font-size:.96rem}
.qcard{background:var(--ink);color:var(--paper);border-radius:var(--radius);padding:clamp(1.8rem,3.5vw,2.6rem)}
.qcard .eyebrow{color:#bfe0cd}.qcard .eyebrow::before{background:#bfe0cd}
.qcard blockquote{font-size:1.3rem;line-height:1.42;font-weight:500;letter-spacing:-.01em;margin-top:1.2rem}
.qcard cite{display:block;margin-top:1.4rem;font-style:normal;color:#9fb6a8;font-size:.88rem;font-weight:600}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.step{border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;background:var(--paper)}
.step .s{font-size:.78rem;font-weight:700;letter-spacing:.12em;color:var(--accent)}
.step h4{font-size:1.18rem;margin:.7rem 0 .5rem;font-weight:700}
.step p{color:var(--soft);font-size:.95rem}

/* cta strip */
.ctaband{text-align:center}
.ctaband h2{font-size:clamp(1.8rem,4vw,2.8rem);letter-spacing:-.03em;font-weight:800;max-width:20ch;margin:0 auto 1rem}
.ctaband p{color:var(--soft);font-size:1.06rem;max-width:46ch;margin:0 auto 2rem}

/* logo wall */
.grid-logos{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.cell{background:var(--paper);aspect-ratio:3/2;display:grid;place-items:center;padding:clamp(.9rem,2vw,1.7rem);transition:background .25s}
.cell:hover{background:#fff}
.cell img{max-width:100%;max-height:56px;width:auto;object-fit:contain;opacity:.6;transition:opacity .25s,transform .25s}
.cell:hover img{opacity:1;transform:scale(1.04)}
.wordmark{text-align:center;opacity:.6;transition:opacity .25s}
.cell:hover .wordmark{opacity:1}
.wordmark .a{font-weight:800;font-size:1.3rem;letter-spacing:-.01em;line-height:1;color:var(--ink)}
.wordmark .b{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;margin-top:.35rem;color:var(--soft)}
.tags{margin-top:1.6rem;display:flex;flex-wrap:wrap;gap:.5rem}
.tag{font-size:.78rem;font-weight:600;color:var(--soft);background:#fff;border:1px solid var(--line);padding:.36rem .8rem;border-radius:999px}
.more{margin-top:1.4rem;font-size:.93rem;color:var(--soft)}
.more strong{color:var(--ink);font-weight:700}

/* map */
.map-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.usmap{width:100%;height:auto;display:block}
.usmap .st{fill:var(--paper-2);stroke:var(--paper);stroke-width:1}
.usmap .served{fill:var(--ink);stroke:var(--paper);stroke-width:1;transition:fill .2s}
.usmap .served:hover{fill:var(--accent)}
.map-stat{font-size:clamp(3rem,7vw,5rem);font-weight:800;letter-spacing:-.04em;color:var(--accent);line-height:1}
.map-stat small{display:block;font-size:1rem;font-weight:600;color:var(--soft);letter-spacing:0;margin-top:.4rem}

/* impact cards */
.impact{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.icard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;transition:.25s}
.icard:hover{background:#fff;box-shadow:0 18px 40px -28px rgba(16,29,51,.5)}
.icard .big{font-size:2rem;font-weight:800;letter-spacing:-.03em;color:var(--ink);line-height:1}
.icard h4{font-size:1.05rem;margin:.6rem 0 .5rem;font-weight:700}
.icard p{color:var(--soft);font-size:.93rem}

/* contact */
.contact{background:var(--ink);color:var(--paper);border-radius:var(--radius)}
.contact .wrap{padding-top:clamp(52px,8vw,88px);padding-bottom:clamp(52px,8vw,88px)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.2rem,5vw,4.2rem)}
.contact h1{font-size:clamp(2rem,4.6vw,3.3rem);letter-spacing:-.03em;line-height:1.04;font-weight:800;max-width:14ch}
.contact .sub{margin-top:1.2rem;color:#bcc8c0;font-size:1.05rem;max-width:42ch}
.contact .eyebrow{color:#bfe0cd}.contact .eyebrow::before{background:#bfe0cd}
.ch-list{margin-top:2.2rem;display:flex;flex-direction:column;gap:1.3rem}
.ch{display:flex;gap:.9rem;align-items:flex-start}
.ch svg{flex:none;width:20px;height:20px;margin-top:3px;stroke:#bfe0cd;fill:none}
.ch .k{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:#8fa599;font-weight:600}
.ch .v{font-size:1.02rem;font-weight:600}
.ch .v a:hover{color:#bfe0cd}
.loc{margin-top:2rem}
.loc .k{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:#8fa599;font-weight:600;margin-bottom:.3rem}
.loc .v{color:#cdd8d1;font-size:.97rem}
.form-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:clamp(1.6rem,3vw,2.2rem)}
form .field{margin-bottom:1.05rem}
form label{display:block;font-size:.8rem;font-weight:600;letter-spacing:.04em;color:#aebcb3;margin-bottom:.4rem}
form input,form select,form textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.16);color:var(--paper);padding:.85rem 1rem;border-radius:10px;font-family:inherit;font-size:.98rem;transition:.2s}
form input::placeholder,form textarea::placeholder{color:#7c8a82}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:#bfe0cd;background:rgba(255,255,255,.09)}
form select option{color:#16263F}
form textarea{resize:vertical;min-height:92px}
.btn-wa{background:var(--accent);color:#fff;width:100%;justify-content:center;padding:.95rem;font-size:1rem;margin-top:.3rem}
.btn-wa:hover{background:var(--accent-br)}
.form-mini{font-size:.78rem;color:#8fa599;margin-top:.9rem;text-align:center}

/* footer */
footer{background:var(--deep);color:#cdd6e0;margin-top:0}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;padding:clamp(48px,7vw,72px) 0 2.4rem}
.foot-brand .fname{font-size:1.3rem;font-weight:800;color:#fff;letter-spacing:-.01em}
.foot-brand p{margin-top:.8rem;font-size:.92rem;color:#9fb0c4;max-width:34ch}
.foot-col h5{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#7d90a8;font-weight:700;margin-bottom:1rem}
.foot-col a,.foot-col div{display:block;font-size:.93rem;color:#cdd6e0;margin-bottom:.6rem}
.foot-col a:hover{color:#fff}
.foot-bot{border-top:1px solid rgba(255,255,255,.1);padding:1.4rem 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-size:.82rem;color:#7d90a8}

/* chat widget */
.chat-launch{position:fixed;right:22px;bottom:22px;z-index:60;width:60px;height:60px;border-radius:50%;background:var(--accent);display:grid;place-items:center;box-shadow:0 12px 32px rgba(16,29,51,.3);cursor:pointer;transition:.2s;border:none}
.chat-launch:hover{transform:translateY(-3px) scale(1.04);background:var(--accent-br)}
.chat-launch svg{width:28px;height:28px;fill:#fff}
.chat-panel{position:fixed;right:22px;bottom:94px;z-index:60;width:min(340px,calc(100vw - 44px));background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 24px 60px -20px rgba(16,29,51,.45);overflow:hidden;opacity:0;transform:translateY(12px) scale(.98);pointer-events:none;transition:.22s}
.chat-panel.open{opacity:1;transform:none;pointer-events:auto}
.chat-head{background:var(--ink);color:#fff;padding:1rem 1.2rem;display:flex;align-items:center;gap:.7rem}
.chat-head img{height:30px;width:auto}
.chat-head .t{font-weight:700;font-size:.98rem}
.chat-head .s{font-size:.74rem;color:#9fb6a8}
.chat-body{padding:1.1rem;max-height:340px;overflow-y:auto}
.bubble{background:var(--paper-2);border-radius:12px;padding:.7rem .9rem;font-size:.9rem;color:var(--ink);margin-bottom:.7rem;max-width:90%}
.qbtns{display:flex;flex-direction:column;gap:.5rem;margin-top:.3rem}
.qbtn{text-align:left;background:#fff;border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;font-size:.88rem;font-weight:600;color:var(--ink);cursor:pointer;font-family:inherit;transition:.15s}
.qbtn:hover{border-color:var(--accent);color:var(--accent)}
.chat-foot{padding:.9rem 1.1rem;border-top:1px solid var(--line)}
.chat-foot .btn-wa{margin-top:0}

/* responsive */
@media(max-width:860px){
  .navlinks{display:none}
  .navlinks.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;background:var(--paper);border-bottom:1px solid var(--line);padding:1.4rem var(--pad);gap:1.2rem}
  .nav-toggle{display:block}
  .cap-grid,.who-grid,.contact-grid,.map-wrap{grid-template-columns:1fr}
  .metrics{grid-template-columns:repeat(2,1fr);gap:2rem}
  .steps,.impact{grid-template-columns:1fr}
  .grid-logos{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr;gap:1.6rem}
}
