:root{
 --ink:#1B2733; --navy:#122A3E; --em:#18715C; --em-l:#2FB89A; --em-d:#1E8E73;
 --slate:#6B7682; --ice:#AEBDCB; --paper:#F2F4F6; --hair:#E3E7EB; --white:#fff;
 --tint:#EAF6F1; --lit:var(--em-l); --sha:var(--em); --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased;padding-top:80px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.narrow{max-width:840px}
.center{text-align:center;margin-top:36px}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:1.12;letter-spacing:-.02em;font-weight:700}
p{color:var(--slate)}
main{display:block}
.eyebrow{font-size:.76rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--em)}
.ico,.mark{width:100%;height:100%;display:block}
.wm{font-family:Lora,serif;font-weight:700;letter-spacing:.04em;color:var(--ink)}
.wo{color:var(--em-l)}
/* header */
header{position:fixed;top:0;left:0;right:0;width:100%;z-index:100;background:rgba(255,255,255,.88);backdrop-filter:blur(14px) saturate(1.1);border-bottom:1px solid var(--hair)}
.nav{display:flex;align-items:center;justify-content:space-between;height:80px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mk{width:36px;height:36px} .brand .wm{font-size:1.55rem}
.navlinks{display:flex;gap:42px;align-items:center}
.navlinks a:not(.btn){font-size:.92rem;font-weight:600;letter-spacing:.01em;color:var(--ink);opacity:.78;transition:color .2s, opacity .2s;position:relative;padding:6px 1px}
.navlinks a:not(.btn)::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--em-l),var(--em));transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.navlinks a:not(.btn):hover{color:var(--em);opacity:1} .navlinks a:not(.btn):hover::after,.navlinks a.on::after{transform:scaleX(1)}
.navlinks a.on{color:var(--em)}
.navlinks .btn{margin-left:30px;position:relative}
.navlinks .btn::before{content:"";position:absolute;left:-30px;top:50%;transform:translateY(-50%);width:1px;height:20px;background:var(--hair)}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.95rem;padding:12px 22px;border-radius:40px;border:1.5px solid transparent;cursor:pointer;transition:transform .18s, background .2s, color .2s, box-shadow .2s, border-color .2s;white-space:nowrap;user-select:none;-webkit-user-select:none;text-decoration:none}
.btn:active{transform:translateY(0) scale(.985)}
.btn.lg{padding:15px 30px;font-size:1rem}
.btn-primary{background:linear-gradient(135deg,var(--em),var(--em-d));color:#fff} .btn-primary:hover{background:linear-gradient(135deg,var(--em-d),#155d4c);transform:translateY(-1px)}
.btn-ghost{border-color:var(--hair);color:var(--ink)} .btn-ghost:hover{border-color:var(--em);color:var(--em)}
.btn-light{background:var(--em-l);color:var(--navy)} .btn-light:hover{background:#fff;transform:translateY(-1px)}
.btn-outline-l{border-color:rgba(255,255,255,.32);color:#fff} .btn-outline-l:hover{border-color:var(--em-l);color:var(--em-l)}
.menu-btn{display:none;background:none;border:0;cursor:pointer;padding:8px}
.menu-btn span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.3s}
/* hero */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 500px at 78% 18%,rgba(47,184,154,.16),transparent 60%);pointer-events:none}
.hero-grid{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;padding:clamp(64px,9vw,118px) 0}
.hero h1{font-size:clamp(2.6rem,6vw,4.4rem);font-weight:800;letter-spacing:-.03em;margin:18px 0 22px;color:#fff}
.hero h1 em{font-style:normal;color:var(--em-l)}
.hero .lead{font-size:1.16rem;color:var(--ice);max-width:33em;margin-bottom:32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-art{position:relative;height:420px}
.hero-art .hex{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:430px;height:430px;--lit:var(--em-l);--sha:var(--em-d);filter:drop-shadow(0 30px 60px rgba(0,0,0,.35));animation:float 7s ease-in-out infinite}
.hero-art .hex.ghost{width:600px;height:600px;opacity:.07;animation:none;filter:none}
@keyframes float{0%,100%{transform:translate(-50%,-52%)}50%{transform:translate(-50%,-48%)}}
.hero-strip{position:relative;border-top:1px solid rgba(255,255,255,.1);display:flex;gap:38px;flex-wrap:wrap;padding:22px 0 30px;color:var(--ice);font-weight:600;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase}
.hero-strip b{color:var(--em-l)}
/* page hero */
.page-hero{background:var(--navy);color:#fff;position:relative;overflow:hidden;padding:clamp(70px,9vw,112px) 0 clamp(54px,7vw,84px)}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 420px at 88% 10%,rgba(47,184,154,.14),transparent 60%)}
.page-hero .eyebrow,.page-hero h1,.page-hero .lead{position:relative}
.page-hero h1{font-size:clamp(2.3rem,5vw,3.6rem);font-weight:800;color:#fff;margin:16px 0 18px;max-width:16em}
.page-hero .lead{color:var(--ice);font-size:1.14rem;max-width:44em}
/* sections */
section{padding:clamp(62px,8.5vw,108px) 0}
.sec-head{max-width:740px;margin-bottom:46px}
.sec-head h2{font-size:clamp(1.85rem,3.4vw,2.6rem);margin:14px 0 14px}
.sec-head p{font-size:1.08rem}
.prose{font-size:1.16rem;color:var(--ink);line-height:1.75}
/* brand clarity band (light, centred) */
.brand-band{background:var(--paper);text-align:center}
.bb-inner{max-width:780px;margin:0 auto}
.bb-mark{display:inline-block;width:62px;height:62px;margin-bottom:18px}
.brand-band h2{color:var(--navy);font-size:clamp(1.8rem,3.4vw,2.45rem);margin:12px auto 16px;max-width:19em}
.brand-band p{color:var(--slate);font-size:1.12rem;max-width:46em;margin:0 auto}
.bb-chips{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:28px}
.bb-chips span{border:1px solid var(--hair);background:#fff;color:var(--ink);border-radius:30px;padding:9px 18px;font-size:.88rem;font-weight:600}
.bb-chips b{color:var(--em);font-weight:700}
/* pillars */
.pillars{background:var(--paper)}
.pillar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pillar{background:#fff;border:1px solid var(--hair);border-radius:18px;padding:34px 30px}
.pillar-ic{width:46px;height:46px;color:var(--ink);margin-bottom:20px}
.pillar h3{font-size:1.34rem;margin-bottom:6px} .pillar .ph-sub{color:var(--em);font-weight:600;font-size:.92rem;margin-bottom:10px;display:block}
/* matrix */
.matrix-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:16px;border:1px solid var(--hair)}
.matrix{display:grid;grid-template-columns:160px repeat(3,1fr);gap:1px;background:var(--hair);min-width:740px}
.mx-corner,.mx-h{background:var(--navy);color:#fff;padding:18px 16px}
.mx-h .dh{font-weight:700;font-size:1.02rem} .mx-h .dh-sub{display:block;color:var(--em-l);font-size:.8rem;font-weight:600;margin-top:3px}
.mx-stage{background:var(--paper);padding:18px 16px}
.mx-stage b{display:block;color:var(--em);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:4px}
.mx-stage span{font-size:.82rem;color:var(--slate)}
.mx-cell{background:#fff;padding:18px 16px;font-weight:600;color:var(--ink);font-size:.92rem;transition:background .2s}
.mx-cell:hover{background:var(--tint)}
/* domain detail */
.domain-block{margin-top:56px}
.db-head{display:flex;align-items:center;gap:16px;margin-bottom:22px;border-bottom:1px solid var(--hair);padding-bottom:18px}
.db-head .db-ic{width:42px;height:42px;color:var(--ink);flex:none}
.db-head h3{font-size:1.5rem} .db-head .db-sub{color:var(--em);font-weight:600;font-size:.95rem}
.cap-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cap2{background:#fff;border:1px solid var(--hair);border-radius:14px;padding:24px 24px;transition:.2s}
.cap2:hover{border-color:var(--em);transform:translateY(-3px);box-shadow:0 18px 36px rgba(18,42,62,.07)}
.lc-tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--em);background:var(--tint);padding:4px 11px;border-radius:20px;margin-bottom:12px}
.cap2 h4{font-size:1.1rem;margin-bottom:7px} .cap2 p{font-size:.93rem}
.advisory-note{margin-top:30px;display:flex;align-items:center;gap:12px;color:var(--slate);font-size:.98rem}
.advisory-note .dot{width:9px;height:9px;border-radius:50%;background:var(--em-l);flex:none}
/* lifecycle (how we work) */
.lifecycle{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.mode{background:var(--paper);border-radius:18px;padding:32px 26px;border:1px solid var(--hair);position:relative}
.mode .step{font-family:Lora,serif;font-size:1.1rem;color:var(--em-l);font-weight:700}
.mode-ic{width:42px;height:42px;color:var(--ink);margin:14px 0 16px}
.mode h3{font-size:1.3rem;margin-bottom:9px}
/* services mini (home) */
.svc-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.svc-mini{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--hair);border-radius:14px;padding:20px 22px;font-weight:600;color:var(--ink);transition:.2s}
.svc-mini:hover{border-color:var(--em);transform:translateY(-3px)}
.svc-mini .smi{width:30px;height:30px;color:var(--ink);flex:none}
.svc-mini .arw{margin-left:auto;color:var(--em);font-weight:700}
/* industries */
.industries{background:var(--paper)}
.sector-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sector{background:#fff;border:1px solid var(--hair);border-radius:16px;padding:26px 24px;transition:.2s}
.sector:hover{border-color:var(--em);transform:translateY(-3px);box-shadow:0 18px 36px rgba(18,42,62,.07)}
.sector-ic{width:38px;height:38px;color:var(--ink);margin-bottom:14px}
.sector h4{font-size:1.12rem;margin-bottom:7px} .sector p{font-size:.93rem}
/* values / beliefs */
.approach{background:var(--navy);color:#fff}
.approach .sec-head h2{color:#fff} .approach .sec-head p{color:var(--ice)}
.value-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px 50px}
.value{display:flex;gap:20px;align-items:flex-start;border-top:1px solid rgba(255,255,255,.12);padding-top:24px}
.vn{font-family:Lora,serif;font-size:1.5rem;color:var(--em-l);font-weight:700;min-width:38px}
.value h4{font-size:1.16rem;color:#fff;margin-bottom:8px} .value p{color:var(--ice);font-size:.97rem}
.belief-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.belief{background:#fff;border:1px solid var(--hair);border-radius:16px;padding:28px 24px}
.belief-ic{width:40px;height:40px;color:var(--ink);margin-bottom:16px}
.belief h4{font-size:1.08rem;margin-bottom:8px} .belief p{font-size:.95rem}
/* network */
.network{background:linear-gradient(120deg,var(--ink),var(--navy));color:#fff}
.net-in{display:flex;align-items:center;justify-content:space-between;gap:34px;flex-wrap:wrap}
.net-in h2{color:#fff;font-size:clamp(1.6rem,3vw,2.2rem);margin:12px 0 12px;max-width:14em}
.net-in p{color:var(--ice);max-width:40em} .net-in .eyebrow{color:var(--em-l)}
/* cta */
.cta{background:linear-gradient(120deg,var(--em),var(--em-d));color:#fff;text-align:center}
.cta h2{font-size:clamp(1.9rem,4vw,2.7rem);color:#fff;margin-bottom:14px}
.cta p{color:rgba(255,255,255,.88);font-size:1.1rem;max-width:34em;margin:0 auto 28px}
.cta .btn-light{background:#fff;color:var(--em)} .cta .btn-light:hover{background:var(--navy);color:#fff}
/* contact */
.contact-actions{display:flex;gap:14px;flex-wrap:wrap;margin:30px 0 26px;position:relative}
.contact-meta{display:flex;gap:34px;flex-wrap:wrap;color:var(--ice);font-size:.97rem;position:relative}
.contact-meta b{color:#fff;font-weight:600;margin-right:6px}
.cform{display:grid;gap:18px}
.cform label{display:grid;gap:7px;font-weight:600;font-size:.92rem;color:var(--ink)}
.cform input,.cform textarea{font-family:inherit;font-size:1rem;padding:13px 15px;border:1px solid var(--hair);border-radius:10px;background:var(--paper);color:var(--ink);transition:.2s}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--em);background:#fff}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.formnote{font-size:.84rem;color:var(--slate)}
/* footer */
footer{background:var(--ink);color:var(--ice);padding:70px 0 34px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand .wm{color:#fff;font-size:1.7rem} .foot-brand .wo{color:var(--em-l)}
.foot-brand .bmk{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.foot-brand .bmk .mk{width:38px;height:38px;--lit:var(--em-l);--sha:var(--em-d)}
.foot-brand p{color:var(--ice);max-width:30em}
.foot-col h5{color:#fff;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:16px}
.foot-col a,.foot-col span{display:block;color:var(--ice);font-size:.98rem;margin-bottom:10px;transition:color .2s}
.foot-col a:hover{color:var(--em-l)}
.triad{display:flex;gap:12px;align-items:center;flex-wrap:wrap;color:var(--ice);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;margin-top:26px}
.triad .sep{color:var(--em-l)}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding-top:26px;font-size:.85rem;color:var(--slate)}
.reveal{opacity:1;transform:none;transition:opacity .6s ease, transform .6s ease}
.js .reveal{opacity:0;transform:translateY(22px)} .js .reveal.in{opacity:1;transform:none}
@media (max-width:920px){
 .hero-grid{grid-template-columns:1fr} .hero-art{display:none}
 .bb-grid{grid-template-columns:1fr} .bb-art{display:none}
 .pillar-grid,.svc-mini-grid,.sector-grid,.contact-cards,.nav-cards{grid-template-columns:1fr 1fr}
 .lifecycle{grid-template-columns:1fr 1fr} .belief-grid{grid-template-columns:1fr 1fr}
 .value-grid{grid-template-columns:1fr} .foot-top{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
 .navlinks{position:fixed;inset:80px 0 auto 0;background:#fff;flex-direction:column;gap:0;padding:10px 0;border-bottom:1px solid var(--hair);transform:translateY(-130%);transition:transform .3s;box-shadow:0 20px 30px rgba(0,0,0,.06)}
 .navlinks.open{transform:none} .navlinks a{padding:14px 28px;width:100%} .navlinks .btn{margin:10px 28px} .navlinks .btn::before{display:none} .navlinks a:not(.btn)::after{display:none}
 .menu-btn{display:block}
 .pillar-grid,.svc-mini-grid,.sector-grid,.lifecycle,.belief-grid,.cap-grid,.frow,.contact-cards,.nav-cards{grid-template-columns:1fr}
 .foot-top{grid-template-columns:1fr} .net-in{flex-direction:column;align-items:flex-start} .biz-cards{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.js .reveal{opacity:1;transform:none}}

/* premium accents */
header::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--em-l),var(--em) 55%,var(--em-d));z-index:1}
.btn-primary{box-shadow:0 10px 22px -8px rgba(24,113,92,.5)}
.btn-light{box-shadow:0 10px 22px -8px rgba(0,0,0,.28)}
.btn-primary:hover{box-shadow:0 14px 26px -8px rgba(24,113,92,.55)}
a:focus-visible,.btn:focus-visible,input:focus-visible,textarea:focus-visible,button:focus-visible{outline:2px solid var(--em-l);outline-offset:3px;border-radius:6px}
::selection{background:var(--em-l);color:#fff}

/* nav robustness + sticky shadow */
.navlinks a{white-space:nowrap}
header{transition:box-shadow .25s}
header.scrolled{box-shadow:0 8px 28px rgba(18,42,62,.08)}
/* contact form feedback */
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}
.form-success,.form-error{display:none;border-radius:12px;padding:16px 20px;font-weight:600;font-size:.97rem;margin-bottom:4px}
.form-success{background:var(--tint);color:var(--em-d);border:1px solid #BFE6DA}
.form-error{background:#FDECEC;color:#B23B3B;border:1px solid #F2C9C9}
.form-success.show,.form-error.show{display:block}

/* contact cards */
.contact-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.ccard{background:#fff;border:1px solid var(--hair);border-radius:16px;padding:28px 26px;display:block;transition:transform .22s, box-shadow .22s, border-color .22s;position:relative;overflow:hidden}
.ccard::after{content:"";position:absolute;top:0;right:0;width:22px;height:22px;background:linear-gradient(135deg,var(--em-l),var(--em));clip-path:polygon(100% 0,0 0,100% 100%);opacity:0;transition:opacity .22s}
.ccard:hover{border-color:var(--em);transform:translateY(-5px);box-shadow:0 24px 46px rgba(18,42,62,.1)}
.ccard:hover::after{opacity:1}
.cc-ic{display:block;width:42px;height:42px;color:var(--ink);margin-bottom:16px}
.cc-label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--em);margin-bottom:7px}
.cc-val{display:block;font-size:1.08rem;font-weight:600;color:var(--ink);line-height:1.3}
a.ccard:hover .cc-val{color:var(--em)}

/* compact industry strip (home) */
.sector-strip{display:flex;flex-wrap:wrap;gap:12px}
.sector-strip span{background:#fff;border:1px solid var(--hair);border-radius:30px;padding:11px 20px;font-weight:600;color:var(--ink);font-size:.96rem;transition:.2s}
.sector-strip span:hover{border-color:var(--em);color:var(--em);transform:translateY(-2px)}

/* full-screen hero + navigation cards (navigation-led home) */
.hero-tall .hero-grid{min-height:min(600px,calc(100vh - 200px));align-items:center}
.explore{background:var(--paper)}
.nav-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ncard{background:#fff;border:1px solid var(--hair);border-radius:18px;padding:38px 32px;display:block;transition:transform .22s,box-shadow .22s,border-color .22s;position:relative;overflow:hidden}
.ncard::after{content:"";position:absolute;top:0;right:0;width:24px;height:24px;background:linear-gradient(135deg,var(--em-l),var(--em));clip-path:polygon(100% 0,0 0,100% 100%);opacity:0;transition:opacity .22s}
.ncard:hover{border-color:var(--em);transform:translateY(-6px);box-shadow:0 26px 50px rgba(18,42,62,.1)}
.ncard:hover::after{opacity:1}
.nc-ic{display:block;width:48px;height:48px;color:var(--ink);margin-bottom:20px}
.ncard h3{font-size:1.45rem;margin-bottom:10px;color:var(--ink)}
.ncard p{font-size:.98rem;margin-bottom:20px}
.nc-go{font-weight:700;color:var(--em);font-size:.95rem}
.ncard:hover .nc-go{color:var(--em-d)}

/* office business cards */
.biz-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:900px;margin:0 auto}
.biz-card{background:#fff;border:1px solid var(--hair);border-radius:18px;padding:34px;position:relative;overflow:hidden;transition:transform .22s, box-shadow .22s}
.biz-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--em-l),var(--em-d))}
.biz-card:hover{box-shadow:0 24px 46px rgba(18,42,62,.09);transform:translateY(-3px)}
.biz-head{display:flex;align-items:center;gap:11px;margin-bottom:22px}
.biz-head .mk{width:34px;height:34px}
.biz-head .wm{font-size:1.4rem}
.biz-label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--em);margin-bottom:6px}
.biz-card h3{font-size:1.7rem;margin-bottom:10px;color:var(--ink)}
.biz-card p{color:var(--slate);font-size:1rem;line-height:1.6;margin-bottom:22px}
.biz-foot{display:flex;flex-direction:column;gap:4px;border-top:1px solid var(--hair);padding-top:18px;font-size:.96rem;font-weight:600}
.biz-foot a{color:var(--em)} .biz-foot a:hover{color:var(--em-d)} .biz-foot span{color:var(--slate)}

.nav .btn-primary{padding:11px 26px;font-size:.92rem}

/* ============ PREMIUM VISUAL REBUILD ============ */
/* inviting nav: pill hover */
.navlinks a:not(.btn){padding:9px 16px;border-radius:30px;opacity:.85;transition:background .2s,color .2s,opacity .2s}
.navlinks a:not(.btn)::after{display:none}
.navlinks a:not(.btn):hover{background:var(--tint);color:var(--em);opacity:1}
.navlinks a.on{background:var(--tint);color:var(--em);opacity:1}
.nav .btn-primary{padding:12px 24px;gap:9px}
.nav .btn-primary .ba{transition:transform .2s} .nav .btn-primary:hover .ba{transform:translateX(3px)}
/* hero lifecycle ribbon */
.hero-ribbon{position:relative;display:flex;align-items:center;gap:10px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.12);padding:26px 0 6px;margin-top:8px}
.rib-step{display:flex;align-items:center;gap:10px;color:#fff;font-weight:600;font-size:.96rem}
.rib-step .ri{width:26px;height:26px;color:var(--em-l);flex:none}
.rib-step b{color:#fff} .rib-step span{color:var(--ice);font-weight:500;display:none}
.rib-arrow{color:var(--em-l);opacity:.55;font-weight:700;margin:0 6px}
/* section intro centered variant */
.sec-head.mid{margin-left:auto;margin-right:auto;text-align:center}
/* WHY / differentiators (icon cards) */
.why{background:var(--navy);color:#fff}
.why .sec-head h2{color:#fff} .why .sec-head p{color:var(--ice)} .why .eyebrow{color:var(--em-l)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.wcard{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:30px 28px;transition:.22s}
.wcard:hover{background:rgba(47,184,154,.08);border-color:var(--em-l);transform:translateY(-4px)}
.wcard .wic{width:46px;height:46px;color:var(--em-l);margin-bottom:18px}
.wcard h4{font-size:1.2rem;color:#fff;margin-bottom:9px}
.wcard p{color:var(--ice);font-size:.96rem}
/* offering domain cards (home) */
.domain-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.dcard{background:#fff;border:1px solid var(--hair);border-radius:20px;padding:34px 30px;display:flex;flex-direction:column;transition:.22s;position:relative;overflow:hidden}
.dcard::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--em-l),var(--em-d));opacity:0;transition:opacity .22s}
.dcard:hover{border-color:var(--em);transform:translateY(-6px);box-shadow:0 28px 54px rgba(18,42,62,.1)}
.dcard:hover::before{opacity:1}
.dc-ic{width:52px;height:52px;color:var(--ink);margin-bottom:18px}
.dcard h3{font-size:1.5rem;margin-bottom:4px}
.dc-sub{color:var(--em);font-weight:600;font-size:.95rem;margin-bottom:18px;display:block}
.dc-caps{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:22px;flex:1}
.dc-caps li{display:flex;gap:11px;align-items:baseline;font-size:.95rem;color:var(--ink)}
.dc-caps li b{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--em);min-width:62px;flex:none}
.dc-go{font-weight:700;color:var(--em);font-size:.95rem;margin-top:auto}
.dcard:hover .dc-go{color:var(--em-d)}
/* lifecycle flow (home + how-we-work) */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.flow-step{position:relative;padding:0 22px;text-align:center}
.flow-step:not(:last-child)::after{content:"";position:absolute;top:34px;right:-1px;width:2px;height:0;}
.flow-num{font-family:Lora,serif;font-size:.95rem;color:var(--em);font-weight:700;letter-spacing:.1em}
.flow-ic{width:54px;height:54px;color:var(--ink);margin:14px auto 16px;padding:14px;background:var(--paper);border-radius:16px;border:1px solid var(--hair)}
.flow-step h4{font-size:1.15rem;margin-bottom:8px}
.flow-step p{font-size:.92rem}
.flow-line{display:none}
/* industries icon cards (visual) */
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.icard{background:#fff;border:1px solid var(--hair);border-radius:14px;padding:22px 20px;display:flex;align-items:center;gap:14px;font-weight:600;color:var(--ink);transition:.2s}
.icard:hover{border-color:var(--em);transform:translateY(-3px)}
.icard .iic{width:30px;height:30px;color:var(--ink);flex:none}
/* what-we-do sticky sub-nav */
.subnav{position:sticky;top:80px;z-index:40;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--hair)}
.subnav .wrap{display:flex;gap:8px;align-items:center;height:58px;overflow-x:auto}
.subnav a{font-size:.9rem;font-weight:600;color:var(--slate);padding:8px 16px;border-radius:30px;white-space:nowrap;transition:.2s}
.subnav a:hover{color:var(--em);background:var(--tint)}
.subnav a.on{color:var(--em);background:var(--tint)}
/* what-we-do domain sections (organized) */
#overview,#industries,.domain-section{scroll-margin-top:150px}
.ds-head{display:flex;align-items:center;gap:18px;margin-bottom:30px}
.ds-head .ds-ic{width:56px;height:56px;color:var(--ink);padding:14px;background:var(--paper);border:1px solid var(--hair);border-radius:16px;flex:none}
.ds-head h3{font-size:1.7rem} .ds-head .ds-sub{color:var(--em);font-weight:600}
.ds-flow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.ds-cap{background:#fff;border:1px solid var(--hair);border-radius:16px;padding:24px;transition:.2s;position:relative}
.ds-cap:hover{border-color:var(--em);transform:translateY(-3px);box-shadow:0 16px 32px rgba(18,42,62,.07)}
.ds-cap .stg{display:inline-flex;align-items:center;gap:7px;font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--em);margin-bottom:12px}
.ds-cap .stg .si{width:16px;height:16px}
.ds-cap h4{font-size:1.08rem;margin-bottom:8px} .ds-cap p{font-size:.92rem}
@media (max-width:920px){
 .why-grid,.domain-cards{grid-template-columns:1fr 1fr}
 .flow,.ds-flow{grid-template-columns:1fr 1fr}
 .ind-grid{grid-template-columns:1fr 1fr}
 .rib-step span{display:none}
}
@media (max-width:680px){
 .why-grid,.domain-cards,.flow,.ds-flow,.ind-grid{grid-template-columns:1fr}
 .subnav{top:80px} .hero-ribbon{gap:6px} .rib-arrow{display:none}
 .rib-step{width:100%;justify-content:flex-start}
}
