/* OneWorld, Inc. — Style A (Midnight Azure). Shared across all pages. */
:root{
  --ink:#E8EFF4; --soft:#93A7B6; --faint:#5A7184;
  --bg:#0A1E30; --surface:#0E2840; --surface-2:#10314E;
  --accent:#00ABD6; --accent-deep:#0E7FA6; --accent-bright:#15B9E2; --line:#1C3854;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Archivo",system-ui,-apple-system,sans-serif;
  --pad:clamp(1.5rem,5vw,5.5rem); --maxw:1180px; --measure:42rem;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-weight:400; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden;
}
a{color:inherit}
img{max-width:100%; display:block}

/* ---------- animated aurora background ---------- */
.bg{position:fixed; inset:0; z-index:-2; overflow:hidden; pointer-events:none}
.bg span{position:absolute; border-radius:50%; filter:blur(70px); opacity:.5; mix-blend-mode:screen; will-change:transform}
.bg .b1{width:48vw; height:48vw; left:-8vw; top:-12vw; background:radial-gradient(circle at 30% 30%,rgba(0,171,214,.55),rgba(0,171,214,0) 70%); animation:drift1 34s ease-in-out infinite}
.bg .b2{width:42vw; height:42vw; right:-6vw; top:6vh; background:radial-gradient(circle at 50% 50%,rgba(14,127,166,.5),rgba(14,127,166,0) 70%); animation:drift2 44s ease-in-out infinite}
.bg .b3{width:38vw; height:38vw; left:30vw; bottom:-16vw; background:radial-gradient(circle at 50% 50%,rgba(60,140,200,.32),rgba(60,140,200,0) 70%); animation:drift3 52s ease-in-out infinite}
@keyframes drift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(6vw,5vh) scale(1.12)}}
@keyframes drift2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-5vw,7vh) scale(1.08)}}
@keyframes drift3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(4vw,-6vh) scale(1.15)}}
.bg::after{content:""; position:absolute; inset:0; background:radial-gradient(120% 100% at 50% 40%,rgba(10,30,48,0) 40%,rgba(10,30,48,.65) 100%)}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad)}

/* ---------- nav ---------- */
nav{position:sticky; top:0; z-index:10; backdrop-filter:blur(8px); background:linear-gradient(180deg,rgba(10,30,48,.86),rgba(10,30,48,0))}
.nav-in{display:flex; align-items:center; justify-content:space-between; padding:1.05rem 0; gap:1.5rem}
.brand{display:inline-flex; align-items:center; gap:.6rem; text-decoration:none}
.brand img{height:30px; width:auto}
.brand .wordmark{font-family:var(--serif); font-weight:400; font-size:1.18rem; letter-spacing:.01em; color:var(--ink)}
.brand .wordmark b{font-weight:500}
.nav-links{display:flex; gap:2rem; font-size:.82rem; letter-spacing:.04em}
.nav-links a{text-decoration:none; color:var(--soft); transition:color .2s ease}
.nav-links a:hover{color:var(--ink)}
@media (max-width:720px){.nav-links{display:none}}

/* ---------- hero ---------- */
header.hero{padding:clamp(4rem,12vh,9rem) 0 clamp(3rem,8vh,6rem)}
.eyebrow{display:inline-flex; align-items:center; gap:.85rem; font-size:.74rem; letter-spacing:.26em; text-transform:uppercase; color:var(--accent); margin:0 0 1.6rem}
.eyebrow::before{content:""; width:2.4rem; height:1px; background:var(--accent); opacity:.7}
h1{font-family:var(--serif); font-weight:300; font-size:clamp(2.6rem,6.5vw,5.25rem); line-height:1.04; letter-spacing:-.015em; margin:0; max-width:18ch}
h1 em{font-style:italic; font-weight:400; color:var(--accent)}
.lede{max-width:46ch; margin:1.9rem 0 2.4rem; font-size:clamp(1.05rem,1.5vw,1.25rem); color:var(--soft)}
.cta-row{display:flex; flex-wrap:wrap; gap:1rem 1.4rem; align-items:center}

/* ---------- buttons ---------- */
.btn{font-family:var(--sans); font-weight:600; font-size:.88rem; letter-spacing:.01em; padding:.85rem 1.7rem; border-radius:8px; border:0; cursor:pointer; text-decoration:none; display:inline-block; transition:transform .2s ease,background .2s ease}
.btn-primary{background:var(--accent); color:#04222E}
.btn-primary:hover{transform:translateY(-2px); background:var(--accent-bright)}
.btn-ghost{background:transparent; color:var(--ink); border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--accent); color:var(--accent)}

/* ---------- sections ---------- */
section{padding:clamp(3.5rem,9vh,6.5rem) 0}
.kicker{font-size:.72rem; letter-spacing:.24em; text-transform:uppercase; color:var(--faint); margin:0 0 1.1rem}
.section-head{max-width:60ch}
.section-head h2{font-family:var(--serif); font-weight:300; font-size:clamp(1.9rem,3.6vw,2.9rem); line-height:1.1; letter-spacing:-.01em; margin:0 0 1rem}
.section-head p{color:var(--soft); margin:0; max-width:52ch}

/* ---------- capability grid ---------- */
.grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1px; margin-top:3rem; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden}
.card{background:var(--surface); padding:2rem 1.9rem; transition:background .25s ease}
.card:hover{background:var(--surface-2)}
.card .num{font-family:var(--serif); font-style:italic; font-size:1.05rem; color:var(--accent)}
.card h3{font-family:var(--sans); font-weight:600; font-size:1.12rem; margin:.7rem 0 .6rem; letter-spacing:.005em}
.card p{color:var(--soft); font-size:.95rem; margin:0}

/* ---------- approach band ---------- */
.band{border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.stats{display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:2.5rem; margin-top:2.5rem}
.stat .n{font-family:var(--serif); font-weight:300; font-size:clamp(2.2rem,4vw,3rem); color:var(--ink); line-height:1}
.stat .l{color:var(--soft); font-size:.92rem; margin-top:.6rem}

/* ---------- contact + form ---------- */
.contact-layout{display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(2rem,5vw,4.5rem); margin-top:2.6rem; align-items:start}
@media (max-width:820px){.contact-layout{grid-template-columns:1fr}}
.contact-details{display:flex; flex-direction:column; gap:1.8rem}
.contact-item .label{font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--faint); margin-bottom:.45rem}
.contact-item a,.contact-item span{font-size:1.02rem; color:var(--ink); text-decoration:none}
.contact-item a{border-bottom:1px solid rgba(0,171,214,.5); padding-bottom:1px; transition:color .2s,border-color .2s}
.contact-item a:hover{color:var(--accent); border-color:var(--accent)}
.form-field{margin-bottom:1.15rem}
.form-field label{display:block; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--soft); margin-bottom:.5rem}
.form-field input,.form-field textarea{width:100%; background:var(--surface); border:1px solid var(--line); border-radius:8px; color:var(--ink); font-family:var(--sans); font-size:1rem; padding:.8rem .95rem; transition:border-color .2s ease}
.form-field textarea{min-height:130px; resize:vertical}
.form-field input:focus,.form-field textarea:focus{outline:none; border-color:var(--accent)}
.form-field input::placeholder,.form-field textarea::placeholder{color:#52677a}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line); padding:2.6rem 0 2.2rem}
.foot-grid{display:flex; flex-wrap:wrap; justify-content:space-between; gap:1.4rem 2rem}
.foot-brand{font-family:var(--serif); font-size:1.05rem; color:var(--ink)}
.foot-links{display:flex; flex-wrap:wrap; gap:1.2rem; font-size:.82rem}
.foot-links a{color:var(--soft); text-decoration:none; transition:color .2s ease}
.foot-links a:hover{color:var(--accent)}
.foot-meta{margin-top:1.6rem; color:var(--faint); font-size:.78rem; line-height:1.7}

/* ---------- legal / document pages ---------- */
.doc{padding:clamp(3rem,8vh,5.5rem) 0 clamp(3rem,7vh,5rem)}
.doc .col{max-width:var(--measure); margin:0 auto}
.doc .back{display:inline-block; font-size:.78rem; letter-spacing:.04em; color:var(--accent); text-decoration:none; margin-bottom:2rem}
.doc .back:hover{text-decoration:underline}
.doc h1{font-family:var(--serif); font-weight:300; font-size:clamp(2.2rem,5vw,3.4rem); line-height:1.06; letter-spacing:-.015em; max-width:none; margin:0 0 .5rem}
.doc .eff{color:var(--faint); font-size:.85rem; letter-spacing:.02em; margin:0 0 2.4rem}
.doc h2{font-family:var(--serif); font-weight:400; font-size:1.5rem; line-height:1.2; color:var(--ink); margin:2.6rem 0 .9rem}
.doc h3{font-family:var(--sans); font-weight:600; font-size:1.08rem; color:var(--ink); margin:1.8rem 0 .7rem}
.doc p,.doc li{color:#c4d2dc; font-size:1rem; line-height:1.75}
.doc p{margin:0 0 1.1rem}
.doc strong{color:var(--ink); font-weight:600}
.doc a{color:var(--accent); text-decoration:none; border-bottom:1px solid rgba(0,171,214,.4)}
.doc a:hover{border-color:var(--accent)}
.doc ul{margin:0 0 1.2rem; padding-left:1.2rem}
.doc li{margin:.4rem 0}
.doc .addr{background:var(--surface); border:1px solid var(--line); border-radius:10px; padding:1.2rem 1.4rem; color:#c4d2dc; line-height:1.7; margin-top:1rem}

:focus-visible{outline:2px solid var(--accent); outline-offset:3px; border-radius:2px}

/* ---------- entrance motion ---------- */
.rise{opacity:0; transform:translateY(16px); animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.d1{animation-delay:.05s}.d2{animation-delay:.15s}.d3{animation-delay:.27s}.d4{animation-delay:.39s}
@keyframes rise{to{opacity:1; transform:none}}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .rise{opacity:1; transform:none; animation:none}
  .bg span{animation:none !important}
}

/* buttons keep their own colors/treatment even inside .doc (where links are azure) */
a.btn{border-bottom:0}
a.btn-primary,a.btn-primary:hover{color:#04222E}
a.btn-ghost{color:var(--ink)}
a.btn-ghost:hover{color:var(--accent)}

/* ---------- engagement platform flow (capabilities page) ---------- */
.flow{margin-top:2.8rem}
.flow .step{display:grid; grid-template-columns:auto 1fr; gap:clamp(1rem,3vw,2rem); padding:1.7rem 0; border-top:1px solid var(--line)}
.flow .step:last-child{border-bottom:1px solid var(--line)}
.flow .step .idx{font-family:var(--serif); font-style:italic; font-weight:400; font-size:1.7rem; color:var(--accent); line-height:1.1}
.flow .step h3{font-family:var(--sans); font-weight:600; font-size:1.12rem; margin:.15rem 0 .55rem}
.flow .step p{color:var(--soft); margin:0; max-width:62ch}

/* ---------- deep capability pillars ---------- */
.caps{margin-top:2.8rem; display:grid; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden}
.cap{background:var(--surface); padding:2rem 1.9rem; transition:background .25s ease}
.cap:hover{background:var(--surface-2)}
.cap .n{font-family:var(--serif); font-style:italic; color:var(--accent); font-size:1.05rem}
.cap h3{font-family:var(--sans); font-weight:600; font-size:1.18rem; margin:.4rem 0 .55rem; letter-spacing:.005em}
.cap p{color:var(--soft); margin:0; max-width:66ch}
.cap .inc{margin-top:.9rem; color:var(--faint); font-size:.86rem; line-height:1.6}
.cap .inc b{color:var(--soft); font-weight:600; letter-spacing:.1em; text-transform:uppercase; font-size:.7rem; margin-right:.5rem}
@media (min-width:780px){.caps{grid-template-columns:1fr 1fr}}

/* ---------- ecosystem / integrations ---------- */
.eco{display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:1px; margin-top:2.8rem; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden}
.eco .cat{background:var(--surface); padding:1.7rem 1.6rem}
.eco .cat h4{font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--accent); margin:0 0 .9rem}
.eco .cat ul{list-style:none; margin:0; padding:0}
.eco .cat li{color:var(--ink); font-size:.97rem; padding:.32rem 0; border-bottom:1px solid rgba(255,255,255,.05)}
.eco .cat li:last-child{border-bottom:0}

/* ===================== MODERN / DEPTH UPGRADE ===================== */
:root{--ease:cubic-bezier(.2,.7,.2,1)}

/* scroll reveal */
.reveal{opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease)}
.reveal.in{opacity:1; transform:none}
.reveal.d1{transition-delay:.06s}.reveal.d2{transition-delay:.14s}.reveal.d3{transition-delay:.22s}

/* media frame with glow */
.media{position:relative; border-radius:18px; overflow:hidden; border:1px solid var(--line); background:var(--surface);
  box-shadow:0 34px 90px -34px rgba(0,171,214,.5), 0 12px 34px -14px rgba(0,0,0,.6)}
.media img{width:100%; height:100%; object-fit:cover; display:block}
.media::after{content:""; position:absolute; inset:0; background:linear-gradient(165deg,rgba(0,171,214,.10),rgba(10,30,48,.55)); pointer-events:none}
.media .tag{position:absolute; left:16px; bottom:16px; z-index:2; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink); background:rgba(8,22,36,.6); border:1px solid rgba(0,171,214,.45); padding:.4rem .8rem; border-radius:999px; backdrop-filter:blur(6px)}
.float{animation:float 8s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* hero two-column */
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4rem); align-items:center}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr; gap:2.5rem}}
.hero-grid h1{max-width:none}

/* feature split (text + image) */
.feature{display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center}
.feature.rev .fmedia{order:-1}
@media (max-width:860px){.feature{grid-template-columns:1fr} .feature.rev .fmedia{order:0}}
.feature .section-head{max-width:48ch; margin-bottom:0}
.feature .mini{display:flex; gap:2rem; flex-wrap:wrap; margin-top:1.6rem}
.feature .mini .n{font-family:var(--serif); font-weight:300; font-size:1.8rem; color:var(--accent); line-height:1}
.feature .mini .l{color:var(--soft); font-size:.85rem; margin-top:.3rem; max-width:16ch}

/* insight band (big stat over image) */
.insight{position:relative; border-radius:20px; overflow:hidden; border:1px solid var(--line); min-height:320px; display:flex; align-items:center; margin-top:.5rem}
.insight .bgimg{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.6}
.insight::after{content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(8,22,36,.94),rgba(8,22,36,.55) 65%,rgba(8,22,36,.25))}
.insight .inner{position:relative; z-index:1; padding:clamp(2rem,5vw,3.6rem); width:100%}
.insight .big{font-family:var(--serif); font-weight:300; font-size:clamp(2rem,4.5vw,3.4rem); line-height:1.1; letter-spacing:-.015em; max-width:22ch; margin:0}
.insight .big em{font-style:italic; color:var(--accent)}
.insight .statline{display:flex; align-items:baseline; gap:1.2rem; margin-top:1.8rem; flex-wrap:wrap}
.insight .fig{font-family:var(--serif); font-weight:300; font-size:clamp(3rem,8vw,5rem); color:var(--accent); line-height:.85}
.insight .figcap{color:var(--soft); max-width:34ch}

/* interactive platform tour */
.tour{display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(1.5rem,4vw,3rem); margin-top:2.8rem; align-items:start}
@media (max-width:880px){.tour{grid-template-columns:1fr} .tour-stage{position:relative !important; top:0 !important}}
.tour-steps{display:flex; flex-direction:column; gap:.45rem}
.tour-step{display:grid; grid-template-columns:auto 1fr; gap:1rem; text-align:left; background:transparent; border:1px solid transparent; border-radius:12px; padding:.95rem 1.1rem; cursor:pointer; color:var(--soft); font-family:inherit; transition:all .25s var(--ease)}
.tour-step .si{font-family:var(--serif); font-style:italic; color:var(--faint); font-size:1.1rem; line-height:1.2}
.tour-step h4{margin:0; font-size:1rem; font-weight:600; color:var(--ink)}
.tour-step p{margin:0; font-size:.88rem; max-height:0; overflow:hidden; opacity:0; transition:max-height .35s var(--ease),opacity .3s ease,margin .3s}
.tour-step:hover{border-color:var(--line)}
.tour-step[aria-selected="true"]{background:linear-gradient(180deg,rgba(16,49,78,.6),rgba(14,40,64,.4)); border-color:rgba(0,171,214,.4); color:var(--ink)}
.tour-step[aria-selected="true"] .si{color:var(--accent)}
.tour-step[aria-selected="true"] p{max-height:9rem; opacity:1; margin-top:.35rem}
.tour-stage{position:sticky; top:90px; border-radius:18px; overflow:hidden; border:1px solid var(--line); box-shadow:0 34px 90px -34px rgba(0,171,214,.45)}
.tour-stage img{width:100%; display:block}
.tour-stage .cap{position:absolute; left:0; right:0; bottom:0; padding:1.5rem 1.6rem; background:linear-gradient(180deg,rgba(8,22,36,0),rgba(8,22,36,.94))}
.tour-stage .cap .t{font-weight:600; color:var(--ink); font-size:1.1rem}
.tour-stage .cap .d{color:var(--soft); font-size:.92rem; margin-top:.25rem}
.tour-stage .badge{position:absolute; top:14px; left:14px; background:rgba(0,171,214,.18); border:1px solid rgba(0,171,214,.5); color:var(--accent); font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:.35rem .7rem; border-radius:999px; backdrop-filter:blur(4px)}

/* glass capability cards (home) */
.grid{background:transparent; border:0; gap:1.1rem; grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.card{position:relative; border:1px solid var(--line); border-radius:16px; background:linear-gradient(180deg,rgba(16,49,78,.55),rgba(14,40,64,.32)); backdrop-filter:blur(6px); overflow:hidden; transition:transform .28s var(--ease),border-color .28s,box-shadow .28s}
.card::before{content:""; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--accent),transparent); opacity:.75}
.card:hover{transform:translateY(-5px); border-color:rgba(0,171,214,.5); box-shadow:0 26px 54px -26px rgba(0,171,214,.45)}

/* how-we-work phases */
.phases{display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:1.1rem; margin-top:2.8rem}
.phase{position:relative; background:linear-gradient(180deg,rgba(16,49,78,.5),rgba(14,40,64,.3)); border:1px solid var(--line); border-radius:16px; padding:1.8rem 1.6rem; backdrop-filter:blur(6px)}
.phase .ph{font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--accent); margin:0 0 .8rem}
.phase h3{font-family:var(--serif); font-weight:400; font-size:1.35rem; margin:0 0 .55rem}
.phase p{color:var(--soft); margin:0; font-size:.95rem}

/* FAQ accordion */
.faq{margin-top:2.6rem; border-top:1px solid var(--line); max-width:62rem}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer; list-style:none; padding:1.3rem 0; font-weight:600; font-size:1.06rem; color:var(--ink); display:flex; justify-content:space-between; align-items:center; gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+"; color:var(--accent); font-weight:400; font-size:1.5rem; line-height:1; transition:transform .25s ease}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--soft); margin:0 0 1.3rem; max-width:72ch; line-height:1.75}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important; transform:none !important; transition:none}
  .float{animation:none !important}
}

/* enriched home capability cards (clickable, with includes + learn-more) */
a.card{text-decoration:none; color:inherit; display:block}
.card .inc{margin-top:1rem; color:var(--faint); font-size:.82rem; line-height:1.55}
.card .inc b{display:block; color:var(--soft); font-weight:600; letter-spacing:.1em; text-transform:uppercase; font-size:.66rem; margin-bottom:.3rem}
.card .more{display:inline-flex; align-items:center; gap:.4rem; margin-top:1.15rem; color:var(--accent); font-size:.82rem; font-weight:600; border-bottom:0}
.card .more::after{content:"→"; transition:transform .2s ease}
.card:hover .more::after{transform:translateX(5px)}

/* tour stage image crossfade */
.tour-stage img{transition:opacity .3s ease}

/* anchor offset under the sticky nav */
[id]{scroll-margin-top:88px}

/* clickable capability pillars (capabilities page) */
a.cap{text-decoration:none; color:inherit; display:block}
.cap .more{display:inline-flex; align-items:center; gap:.4rem; margin-top:1.1rem; color:var(--accent); font-size:.82rem; font-weight:600}
.cap .more::after{content:"\2192"; transition:transform .2s ease}
.cap:hover .more::after{transform:translateX(5px)}

/* ---------- breadcrumb (capability detail pages) ---------- */
.crumb{font-size:.78rem; letter-spacing:.03em; margin:0 0 1.7rem; display:flex; gap:.55rem; flex-wrap:wrap; align-items:center}
.crumb a{color:var(--soft); text-decoration:none; border-bottom:1px solid transparent; transition:color .2s ease,border-color .2s ease}
.crumb a:hover{color:var(--accent); border-color:rgba(0,171,214,.5)}
.crumb span{color:var(--faint)}
.crumb .here{color:var(--ink)}

/* capability detail: full-width hero image band */
.hero-band{padding-top:0}
.hero-band .media img{max-height:440px}

/* capability detail: centered vision statement */
.vision{text-align:center; max-width:32ch; margin:0 auto}
.vision .mk{font-family:var(--serif); font-style:italic; font-size:2.4rem; color:var(--accent); line-height:1; opacity:.6; display:block; margin-bottom:.4rem}
.vision p{font-family:var(--serif); font-weight:300; font-size:clamp(1.55rem,3.1vw,2.5rem); line-height:1.26; letter-spacing:-.01em; color:var(--ink); margin:0}
.vision em{font-style:italic; color:var(--accent)}

/* ---------- enriched engagement flow (capabilities) ---------- */
.flow .step .out{display:block; margin-top:.6rem; color:var(--accent); font-size:.82rem; letter-spacing:.04em}

/* ---------- upgraded ecosystem cards (capabilities) ---------- */
.ecogrid{display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:1.1rem; margin-top:3rem}
.ecocard{position:relative; border:1px solid var(--line); border-radius:16px; background:linear-gradient(180deg,rgba(16,49,78,.5),rgba(14,40,64,.3)); backdrop-filter:blur(6px); padding:1.7rem 1.6rem; overflow:hidden; transition:transform .28s var(--ease),border-color .28s,box-shadow .28s}
.ecocard::before{content:""; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--accent),transparent); opacity:.7}
.ecocard:hover{transform:translateY(-5px); border-color:rgba(0,171,214,.5); box-shadow:0 26px 54px -26px rgba(0,171,214,.45)}
.ecocard .lyr{font-family:var(--serif); font-style:italic; color:var(--accent); font-size:1rem; margin:0}
.ecocard h4{font-family:var(--sans); font-weight:600; font-size:1.1rem; margin:.35rem 0 .55rem; letter-spacing:.005em}
.ecocard > p{color:var(--soft); font-size:.92rem; margin:0 0 1.15rem}
.ecocard .chips{display:flex; flex-wrap:wrap; gap:.5rem}
.ecocard .chips span{font-size:.78rem; color:var(--ink); background:rgba(0,171,214,.08); border:1px solid var(--line); padding:.32rem .7rem; border-radius:999px; transition:border-color .2s ease,background .2s ease}
.ecocard:hover .chips span{border-color:rgba(0,171,214,.35)}
