/* BPM marketing / shell — builds on app.css tokens (:root). Institutional, restrained. */
.mkt-body{background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.6}
.mkt-topbar{position:sticky;top:0;z-index:40;height:var(--topbar-h);display:flex;align-items:center;padding:0 clamp(20px,5vw,48px);
  background:rgba(245,241,234,.85);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--rule)}
.mkt-topbar .brand .sub{margin-left:8px}
.mkt-nav{margin-left:auto;display:flex;align-items:center;gap:2px;height:100%}
.mkt-nav a{font-size:13px;font-weight:500;color:var(--ink-3);padding:0 13px;height:100%;display:inline-flex;align-items:center;border-bottom:2px solid transparent}
.mkt-nav a:hover{color:var(--ink-2)}.mkt-nav a.active{color:var(--ink);border-bottom-color:var(--red)}
.mkt-nav a.intel{color:var(--red)}.mkt-nav a.intel.active{border-bottom-color:var(--red)}
.mkt-cta{margin-left:10px;background:var(--red);color:var(--paper)!important;font-weight:500;border-radius:2px;padding:8px 14px!important;border-bottom:0!important}
.mkt-cta:hover{background:var(--red-hover)}
.navtog{display:none;margin-left:auto;background:none;border:0;color:var(--ink);cursor:pointer}

.wrap{max-width:1180px;margin:0 auto;padding:0 clamp(20px,5vw,48px)}
.wrap-tight{max-width:920px}
main.mkt{min-height:60vh}
.eyebrow.big{font-size:12px}
.lead{font-family:var(--cjk);font-size:clamp(16px,2vw,19px);line-height:1.85;color:var(--ink-2);max-width:62ch}
.serif-it{font-family:var(--serif);font-style:italic;color:var(--ink-3)}

/* hero */
.hero{padding:clamp(48px,9vw,104px) 0 clamp(36px,5vw,60px);border-bottom:1px solid var(--rule)}
.hero h1{font-family:var(--cjk);font-weight:700;font-size:clamp(32px,5.4vw,60px);line-height:1.12;letter-spacing:.004em;margin:14px 0 0;max-width:20ch}
.hero .h-sub{font-family:var(--serif);font-style:italic;font-size:clamp(17px,2.4vw,24px);color:var(--ink-3);margin:16px 0 0}
.hero .lead{margin-top:22px}
.hero-actions{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap}
.btn-lg{font-size:14px;padding:12px 20px}
.page-hero{padding:clamp(40px,7vw,84px) 0 clamp(26px,4vw,40px);border-bottom:1px solid var(--rule)}
.page-hero h1{font-family:var(--cjk);font-weight:700;font-size:clamp(30px,4.6vw,50px);line-height:1.14;margin:12px 0 0}
.page-hero .h-sub{font-family:var(--serif);font-style:italic;font-size:clamp(16px,2vw,21px);color:var(--ink-3);margin:14px 0 0}
.page-hero .lead{margin-top:20px}

/* sections */
.sec{padding:clamp(40px,6vw,72px) 0}
.sec+.sec{border-top:1px solid var(--rule)}
.sec-ink{border-top:2px solid var(--ink)!important}
.sec-lab{display:flex;align-items:baseline;gap:14px;margin-bottom:8px}
.sec-lab .no{font-family:var(--mono);font-size:12px;color:var(--red)}
.sec h2{font-family:var(--cjk);font-weight:600;font-size:clamp(23px,3vw,33px);line-height:1.25;margin:8px 0 0;letter-spacing:.006em;max-width:24ch}
.sec h2 .en{font-family:var(--serif);font-style:italic;font-weight:400;font-size:.62em;color:var(--ink-3);margin-left:10px}
.sec .lead{margin-top:16px}
.sec-head{margin-bottom:clamp(24px,3vw,40px)}

/* outcome row */
.outcomes{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);margin-top:34px}
.outcome{background:var(--bone);padding:20px 22px}
.outcome .zh{font-family:var(--cjk);font-weight:600;font-size:17px}
.outcome .en{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-top:5px}
.outcome .d{font-size:12.5px;color:var(--ink-3);margin-top:9px;line-height:1.6}

/* stat band */
.statband{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--rule);background:var(--bone)}
.statband .st{padding:26px 24px;border-right:1px solid var(--rule)}.statband .st:last-child{border-right:0}
.statband .n{font-family:var(--serif);font-weight:500;font-size:clamp(30px,3.6vw,44px);line-height:1;letter-spacing:-.02em}
.statband .n small{font-size:.42em;color:var(--ink-3);margin-left:3px;letter-spacing:0}
.statband .l{font-size:12px;color:var(--ink-3);margin-top:11px;line-height:1.5}

/* problem grid */
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pcard{border:1px solid var(--rule);background:var(--bone);padding:20px;display:flex;flex-direction:column}
.pcard .tag{align-self:flex-start;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);border:1px solid var(--rule);border-radius:999px;padding:3px 9px}
.pcard .zh{font-family:var(--cjk);font-weight:600;font-size:18px;margin-top:14px}
.pcard .q{font-family:var(--cjk);font-size:13.5px;color:var(--ink-2);margin-top:8px;line-height:1.7}
.pcard .r{font-size:12px;color:var(--ink-3);margin-top:12px;padding-top:12px;border-top:1px solid var(--rule);line-height:1.6}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.pillar{border:1px solid var(--rule);background:var(--bone);padding:24px 26px;border-top:2px solid var(--red)}
.pillar .k{display:flex;align-items:baseline;gap:10px}
.pillar .k .ab{font-family:var(--mono);font-size:12px;color:var(--red)}
.pillar h3{font-family:var(--cjk);font-weight:600;font-size:21px;margin:0}
.pillar .tl{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-3);margin-top:4px}
.pillar ul{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:9px}
.pillar li{font-size:13.5px;color:var(--ink-2);padding-left:16px;position:relative;line-height:1.55}
.pillar li:before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;background:var(--red);border-radius:1px}

/* phases / timeline */
.phases{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--rule);background:var(--bone)}
.phase{padding:22px 22px 24px;border-right:1px solid var(--rule);position:relative}.phase:last-child{border-right:0}
.phase .ph-n{font-family:var(--mono);font-size:11px;color:var(--red)}
.phase .ph-t{font-family:var(--cjk);font-weight:600;font-size:18px;margin-top:8px}
.phase .ph-en{font-size:11px;color:var(--ink-4);text-transform:uppercase;letter-spacing:.08em;margin-top:3px}
.phase .ph-dur{display:inline-block;font-family:var(--mono);font-size:11px;color:var(--ink-3);background:var(--paper-2);border:1px solid var(--rule);border-radius:999px;padding:2px 9px;margin-top:12px}
.phase .ph-o{font-size:12.5px;color:var(--ink-3);margin-top:13px;line-height:1.65}

/* generic list-table (root causes, what-we-do) */
.rowtable{border:1px solid var(--rule);background:var(--bone)}
.rrow{display:grid;grid-template-columns:34px 1.1fr 1.4fr;gap:18px;padding:18px 22px;border-bottom:1px solid var(--rule)}
.rrow:last-child{border-bottom:0}
.rrow .rn{font-family:var(--serif);font-size:22px;color:var(--red);line-height:1}
.rrow .rh{font-family:var(--cjk);font-weight:600;font-size:15.5px}
.rrow .rh .s{display:block;font-weight:400;font-size:12.5px;color:var(--ink-3);margin-top:5px;line-height:1.6}
.rrow .rd{font-size:13px;color:var(--ink-2);line-height:1.7}
.rrow .rd .lab{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);display:block;margin-bottom:4px}

/* cases */
.cases{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.case{border:1px solid var(--rule);background:var(--bone);padding:24px 26px}
.case .ct{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4)}
.case h3{font-family:var(--cjk);font-weight:600;font-size:18px;margin:10px 0 0;line-height:1.4}
.case .cd{font-size:13px;color:var(--ink-2);margin-top:10px;line-height:1.7}
.case .cm{display:flex;gap:24px;margin-top:18px;flex-wrap:wrap;border-top:1px solid var(--rule);padding-top:16px}
.case .cm .m .n{font-family:var(--serif);font-weight:500;font-size:26px;letter-spacing:-.02em;color:var(--red)}
.case .cm .m .l{font-size:11px;color:var(--ink-3);margin-top:3px}

/* who-we-serve / generic 3-col */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tcard{border:1px solid var(--rule);background:var(--bone);padding:22px 24px}
.tcard h3{font-family:var(--cjk);font-weight:600;font-size:18px;margin:0}
.tcard .en{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);margin-top:4px}
.tcard p{font-size:13px;color:var(--ink-2);margin:12px 0 0;line-height:1.7}

/* not/is list */
.notis{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 28px}
.ni{display:flex;gap:12px;font-size:14px;line-height:1.6;padding:12px 0;border-bottom:1px solid var(--rule)}
.ni .x{color:var(--ink-4);font-family:var(--serif);flex:none}
.ni b{color:var(--ink);font-weight:600}

/* shift arrows */
.shifts{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.shift{border:1px solid var(--rule);background:var(--bone);padding:18px 20px;text-align:center}
.shift .from{font-family:var(--cjk);font-size:13px;color:var(--ink-3)}
.shift .ar{color:var(--red);font-size:18px;margin:8px 0}
.shift .to{font-family:var(--cjk);font-weight:600;font-size:15px;color:var(--ink)}

/* partners */
.partners{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.partner{font-size:13px;color:var(--ink-2);border:1px solid var(--rule);background:var(--bone);border-radius:2px;padding:8px 14px}
.partner.tier{font-weight:600}

/* checklist */
.checks{display:grid;grid-template-columns:repeat(2,1fr);gap:10px 28px}
.check{display:flex;gap:11px;font-size:14px;color:var(--ink-2);line-height:1.6;padding:11px 0;border-bottom:1px solid var(--rule)}
.check .ck{color:var(--red);flex:none;font-weight:700}

/* verbs */
.verbs{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.verb{font-family:var(--cjk);font-weight:600;font-size:15px;border:1px solid var(--red-tint);background:var(--red-tint);color:var(--red-press);border-radius:2px;padding:9px 18px}

/* cta band */
.ctaband{border:1px solid var(--rule);border-left:3px solid var(--red);background:var(--paper-2);padding:clamp(28px,4vw,44px);display:flex;justify-content:space-between;align-items:center;gap:28px;flex-wrap:wrap;margin:0}
.ctaband .h{font-family:var(--cjk);font-weight:600;font-size:clamp(20px,2.6vw,27px)}
.ctaband .p{font-size:14px;color:var(--ink-2);margin-top:8px;max-width:56ch}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:start}
.cinfo .row{padding:16px 0;border-bottom:1px solid var(--rule)}
.cinfo .row .l{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4)}
.cinfo .row .v{font-family:var(--cjk);font-size:16px;margin-top:5px}
.cinfo .row .v a{color:var(--red)}

/* intel hub */
.searchbox{position:relative;margin-top:8px}
.searchbox input{width:100%;font-family:var(--cjk);font-size:16px;padding:15px 18px 15px 46px;border:1px solid var(--rule-2);background:var(--bone);border-radius:3px;color:var(--ink)}
.searchbox input:focus{outline:none;border-color:var(--red)}
.searchbox .si{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--ink-4)}
.s-results{margin-top:10px;border:1px solid var(--rule);background:var(--bone);border-radius:3px;max-height:380px;overflow:auto;display:none}
.s-results.on{display:block}
.s-row{display:flex;align-items:center;gap:12px;padding:11px 16px;border-bottom:1px solid var(--rule);font-size:14px}
.s-row:last-child{border-bottom:0}.s-row:hover{background:var(--ink-03)}
.s-row .nm{font-family:var(--cjk);color:var(--ink);font-weight:500}
.s-row .meta{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--ink-4)}
.s-row .badge{font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--red);border:1px solid var(--red-tint);background:var(--red-tint);border-radius:999px;padding:2px 8px}
.s-empty{padding:16px;color:var(--ink-4);font-size:13px}
.sections-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.scard{border:1px solid var(--rule);background:var(--bone);padding:24px 26px;display:block;border-top:2px solid var(--red)}
.scard.soon{border-top-color:var(--rule-2);opacity:.7}
.scard h3{font-family:var(--cjk);font-weight:600;font-size:20px;margin:0}
.scard .en{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);margin-top:4px}
.scard p{font-size:13px;color:var(--ink-2);margin:12px 0 0;line-height:1.7}
.scard .cnt{font-family:var(--mono);font-size:12px;color:var(--red);margin-top:14px}
.browse h3{font-family:var(--cjk);font-weight:600;font-size:17px;margin:0 0 12px}
.chiplist{display:flex;flex-wrap:wrap;gap:8px}
.chiplist a{font-family:var(--cjk);font-size:13px;color:var(--ink-2);border:1px solid var(--rule);background:var(--bone);border-radius:2px;padding:7px 13px}
.chiplist a:hover{border-color:var(--red);color:var(--red)}
.chiplist a .en{font-size:10px;color:var(--ink-4);margin-left:5px}

/* footer */
.site-foot{border-top:2px solid var(--ink);background:var(--bone);margin-top:0}
.foot-main{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding:48px 0 36px}
.foot-brand .wm{font-family:var(--sans);font-weight:800;font-size:24px;letter-spacing:-.04em;color:var(--ink)}
.foot-brand .tri{display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:6px solid var(--red);margin-left:-3px;transform:translateY(-7px)}
.foot-brand .d{font-size:13px;color:var(--ink-3);margin-top:12px;max-width:34ch;line-height:1.7}
.foot-col h4{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin:0 0 14px}
.foot-col a{display:block;font-size:13.5px;color:var(--ink-2);padding:6px 0}.foot-col a:hover{color:var(--red)}
.foot-bar{border-top:1px solid var(--rule);padding:18px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--ink-4)}

@media(max-width:980px){
  .outcomes,.statband,.pgrid,.phases,.shifts{grid-template-columns:repeat(2,1fr)}
  .pillars,.cases,.contact-grid,.sections-grid,.notis,.checks{grid-template-columns:1fr}
  .trio{grid-template-columns:1fr}
  .foot-main{grid-template-columns:1fr 1fr;gap:28px}
  .statband .st:nth-child(2){border-right:0}
  .phase{border-right:0;border-bottom:1px solid var(--rule)}
  .rrow{grid-template-columns:28px 1fr;gap:12px}.rrow .rd{grid-column:2}
}
@media(max-width:600px){
  .mkt-nav{display:none}.navtog{display:inline-flex}
  .outcomes,.statband,.pgrid,.shifts{grid-template-columns:1fr}
  .statband .st{border-right:0;border-bottom:1px solid var(--rule)}
  .foot-main{grid-template-columns:1fr}
}
.mkt-nav.open{display:flex;position:absolute;top:var(--topbar-h);left:0;right:0;flex-direction:column;height:auto;background:var(--bone);border-bottom:1px solid var(--rule);padding:8px 20px}
.mkt-nav.open a{height:auto;padding:12px 0;border-bottom:1px solid var(--rule)}

/* ---- in-shell (app-main) marketing context ---- */
.app-main .lead{font-family:var(--cjk);font-size:15.5px;line-height:1.9;color:var(--ink-2);max-width:76ch;margin:14px 0 0}
.app-main .outcomes,.app-main .statband{margin-top:18px}
.block .outcomes,.block .statband,.block .pillars,.block .cases,.block .trio,.block .pgrid,.block .phases,.block .shifts,.block .rowtable,.block .notis,.block .checks,.block .partners,.block .verbs,.block .sections-grid,.block .contact-grid{margin-top:18px}
.block .lead{margin:6px 0 0}
.block .subhead{font-size:11px;font-weight:600;letter-spacing:var(--tr-caps);text-transform:uppercase;color:var(--ink-3);margin:22px 0 0}
.block .verbs{margin-top:10px}
.tcard4{grid-template-columns:repeat(4,1fr)!important}
@media(max-width:1080px){.tcard4{grid-template-columns:repeat(2,1fr)!important}}
.outcomes,.pgrid,.shifts{grid-template-columns:repeat(4,1fr)}
@media(max-width:1080px){.outcomes,.pgrid,.shifts,.phases,.statband{grid-template-columns:repeat(2,1fr)}.pillars,.cases,.trio,.contact-grid,.sections-grid{grid-template-columns:1fr}}
@media(max-width:600px){.outcomes,.pgrid,.shifts,.statband{grid-template-columns:1fr}}
@media(max-width:1080px){.sidebar.open{display:flex;position:fixed;top:var(--topbar-h);left:0;bottom:0;width:284px;z-index:35;overflow:auto;box-shadow:2px 0 16px rgba(0,0,0,.18)}}
