/* Pontura — shared stylesheet. Tokens per pontura-brand SKILL.md. Bump ?v= in <link> when editing (assets are cached 7 days). */
@font-face{font-family:'Archivo';font-style:normal;font-weight:400 700;font-stretch:110%;font-display:swap;src:url(/assets/fonts/archivo-latin-var.woff2) format('woff2')}
@font-face{font-family:'Public Sans';font-style:normal;font-weight:400 600;font-display:swap;src:url(/assets/fonts/publicsans-latin-var.woff2) format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url(/assets/fonts/plexmono-latin-400.woff2) format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url(/assets/fonts/plexmono-latin-500.woff2) format('woff2')}
:root{--harbor-900:#0E3A44;--harbor-700:#175766;--harbor-500:#2E7285;--beacon-500:#E98A15;--beacon-600:#C97207;--steel-500:#5E7A80;--line-200:#D8E0DE;--mist-50:#F2F5F4;--ink-900:#12262B;--radius:10px;--fd:'Archivo',Arial,sans-serif;--fb:'Public Sans','Segoe UI',sans-serif;--fm:'IBM Plex Mono',Consolas,monospace}
*{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);color:var(--ink-900);background:var(--mist-50);line-height:1.65}
.wrap{max-width:1100px;margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:var(--fd);font-stretch:110%;color:var(--harbor-900)}
.eyebrow{font-family:var(--fm);font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--beacon-500)}
.eyebrow.dark{color:var(--beacon-600)}
a.btn{display:inline-block;font-family:var(--fd);font-stretch:110%;font-weight:600;font-size:15.5px;padding:13px 26px;border-radius:8px;text-decoration:none;transition:background .15s}
.btn-amber{background:var(--beacon-500);color:var(--harbor-900)}
.btn-amber:hover{background:var(--beacon-600)}
.btn-ghost-l{border:1.5px solid rgba(255,255,255,.55);color:#fff;margin-left:12px}
.btn-ghost-l:hover{border-color:#fff}
/* nav */
nav{background:var(--harbor-900)}
.navin{display:flex;align-items:center;gap:34px;padding:18px 0;flex-wrap:wrap}
nav a{color:#CFE0E3;text-decoration:none;font-size:15px;font-weight:500;padding-bottom:2px;border-bottom:2px solid transparent}
nav a:hover{color:#fff}
nav a.active{color:#fff;border-bottom-color:var(--beacon-500)}
nav .cta{margin-left:auto;font-family:var(--fd);font-weight:600;color:var(--harbor-900);background:var(--beacon-500);padding:9px 18px;border-radius:7px;border-bottom:none}
nav .home{display:flex;border-bottom:none}
nav .lang{font-family:var(--fm);font-size:12px;letter-spacing:.12em;color:#9FC0C6;border:1px solid rgba(255,255,255,.28);border-radius:6px;padding:6px 10px;margin-left:2px}
nav .lang:hover{color:#fff;border-color:#fff}
/* hero (home) + page hero */
header{background:linear-gradient(165deg,var(--harbor-900) 0%,var(--harbor-700) 100%);color:#fff;overflow:hidden}
.hero{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding-top:84px;padding-bottom:64px}
.hero h1{color:#fff;font-size:clamp(32px,4.6vw,52px);font-weight:700;line-height:1.08;max-width:16ch}
.hero p{color:#BED3D7;font-size:18px;max-width:52ch;margin:20px 0 30px}
.hero-art svg{width:100%;height:auto;display:block}
@media(prefers-reduced-motion:no-preference){
 .hero-art .payload{animation:carry 7s ease-in-out 1.2s 1 both}
 @keyframes carry{0%{transform:translateX(-260px)}60%{transform:translateX(30px)}100%{transform:translateX(0)}}
}
.pagehero{padding-top:64px;padding-bottom:52px}
.pagehero h1{color:#fff;font-size:clamp(30px,4vw,44px);font-weight:700;line-height:1.12;max-width:24ch;margin-top:10px}
.pagehero p{color:#BED3D7;font-size:17.5px;max-width:58ch;margin:18px 0 0}
/* stats strip */
.stats{background:var(--harbor-900);border-top:1px solid rgba(255,255,255,.12)}
.stats .in{display:flex;gap:14px 44px;flex-wrap:wrap;justify-content:space-between;padding:20px 0;font-family:var(--fm);font-size:13.5px;letter-spacing:.14em;color:#9FC0C6}
.stats b{color:var(--beacon-500);font-weight:500}
/* sections */
section{padding:76px 0}
h2{font-size:clamp(24px,3vw,34px);font-weight:700;margin:10px 0 14px}
h3{font-size:20px;font-weight:600}
.lede{color:var(--steel-500);max-width:64ch}
.more{font-weight:600;color:var(--harbor-500);text-decoration:none;font-size:15px}
.more:hover{color:var(--harbor-900);text-decoration:underline}
/* cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.card{background:#fff;border:1px solid var(--line-200);border-radius:var(--radius);padding:30px 28px;display:flex;flex-direction:column}
.card .tag{font-family:var(--fm);font-size:12px;letter-spacing:.16em;color:var(--harbor-500);border:1px solid var(--line-200);border-radius:5px;padding:4px 9px;align-self:flex-start}
.card h3{margin:16px 0 10px}
.card p{font-size:15px;color:var(--ink-900)}
.card ul{margin:12px 0 0;padding-left:18px;font-size:14.5px;color:var(--steel-500)}
.card li{margin:5px 0}
/* approach steps */
.approach{background:#fff;border-top:1px solid var(--line-200);border-bottom:1px solid var(--line-200)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:36px}
.step .no{font-family:var(--fm);font-size:13px;color:var(--beacon-600)}
.step h3{font-size:17.5px;margin:8px 0 6px}
.step p{font-size:14.5px;color:var(--steel-500)}
/* case panel */
.case{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.case .panel,.panel-dark{background:var(--harbor-900);color:#fff;border-radius:var(--radius);padding:36px}
.case .panel .row,.panel-dark .row{display:flex;justify-content:space-between;gap:18px;border-bottom:1px solid rgba(255,255,255,.14);padding:13px 0;font-size:15px}
.case .panel .row:last-child,.panel-dark .row:last-child{border-bottom:none}
.case .panel .row b,.panel-dark .row b{font-family:var(--fm);font-weight:500;color:var(--beacon-500);letter-spacing:.06em}
.case .panel .row span,.panel-dark .row span{color:#BED3D7;text-align:right}
/* long-form content pages */
.prose{max-width:70ch}
.prose p{margin:0 0 18px}
.prose h2{margin-top:8px}
.prose h3{margin:30px 0 10px;color:var(--harbor-900)}
.prose ul{margin:0 0 18px;padding-left:20px}
.prose li{margin:7px 0}
.prose .capt{font-size:14.5px;color:var(--steel-500)}
.door{background:#fff;border:1px solid var(--line-200);border-radius:var(--radius);padding:40px 38px;margin-top:28px}
.door .doorhead{display:flex;align-items:baseline;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:6px}
.door h2{margin:0 0 8px;font-size:clamp(22px,2.6vw,28px)}
.door .tag{font-family:var(--fm);font-size:12px;letter-spacing:.16em;color:var(--harbor-500);border:1px solid var(--line-200);border-radius:5px;padding:4px 9px;white-space:nowrap}
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:20px 44px;margin-top:14px}
.twocol h3{font-size:16.5px;margin:14px 0 8px}
.twocol ul{margin:0;padding-left:18px;font-size:15px}
.twocol li{margin:6px 0}
.signals{background:var(--mist-50);border:1px solid var(--line-200);border-radius:8px;padding:20px 24px;margin-top:22px}
.signals .sighead{font-family:var(--fm);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--beacon-600);margin-bottom:10px}
.signals ul{margin:0;padding-left:18px;font-size:15px;color:var(--ink-900)}
.signals li{margin:6px 0}
/* phase blocks (approach page) */
.phase{background:#fff;border:1px solid var(--line-200);border-radius:var(--radius);padding:36px 38px;margin-top:24px;display:grid;grid-template-columns:110px 1fr;gap:28px}
.phase .no{font-family:var(--fm);font-size:15px;color:var(--beacon-600);letter-spacing:.08em}
.phase .no small{display:block;color:var(--steel-500);font-size:12px;letter-spacing:.14em;margin-top:6px;text-transform:uppercase}
.phase h2{font-size:clamp(20px,2.4vw,26px);margin:0 0 10px}
.phase p{margin:0 0 14px;max-width:66ch}
.phase ul{margin:0 0 6px;padding-left:18px}
.phase li{margin:6px 0;font-size:15px}
.phase .deliver{font-family:var(--fm);font-size:13px;color:var(--harbor-500);letter-spacing:.04em;margin-top:10px}
/* definition rows (firm/contact) */
.factrow{display:grid;grid-template-columns:190px 1fr;gap:10px 30px;padding:15px 0;border-bottom:1px solid var(--line-200);font-size:15.5px}
.factrow:last-child{border-bottom:none}
.factrow b{font-family:var(--fm);font-weight:500;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--harbor-500);padding-top:3px}
/* cta band */
.band{background:linear-gradient(165deg,var(--harbor-900),var(--harbor-700));color:#fff;border-radius:14px;padding:52px 48px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.band h2{color:#fff;margin:0;max-width:22ch}
/* footer */
footer{background:var(--harbor-900);color:#9FC0C6;margin-top:76px}
.flinks{display:flex;flex-wrap:wrap;gap:8px 24px;padding:24px 24px 22px;font-size:13.5px;border-bottom:1px solid rgba(255,255,255,.12)}
.flinks a{color:#CFE0E3;text-decoration:none}
.flinks a:hover{color:#fff;text-decoration:underline}
.fin{display:flex;align-items:center;gap:26px;padding:34px 0;flex-wrap:wrap;font-size:14px}
.fin .fm{font-family:var(--fm);font-size:12px;letter-spacing:.12em;margin-left:auto}
.fin .legal{display:block;font-size:12.5px;color:#7FA0A6;margin-top:3px}
@media(max-width:880px){
 .hero{grid-template-columns:1fr}
 .cards,.steps{grid-template-columns:1fr}
 .case{grid-template-columns:1fr}
 .twocol{grid-template-columns:1fr}
 .phase{grid-template-columns:1fr;gap:10px}
 .factrow{grid-template-columns:1fr;gap:2px}
}
@media(max-width:640px){
 .navin{gap:12px 20px;padding:14px 0}
 nav a{font-size:14px}
 nav .home{order:1}
 nav .cta{order:2;margin-left:auto;padding:8px 14px;font-size:13.5px}
 nav a:not(.home):not(.cta):not(.lang){order:3}
 nav .lang{order:2;padding:5px 8px;font-size:11px}
 section{padding:56px 0}
 .hero{padding-top:52px;padding-bottom:44px;gap:36px}
 .pagehero{padding-top:44px;padding-bottom:38px}
 .band{padding:40px 28px}
 .door{padding:30px 24px}
 .phase{padding:28px 24px}
}
:focus-visible{outline:2.5px solid var(--beacon-500);outline-offset:2px}
/* clients + interim (v2) */
.cards.four{grid-template-columns:repeat(4,1fr)}
.clients{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:36px}
.client{background:#fff;border:1px solid var(--line-200);border-radius:var(--radius);padding:26px 24px}
.client .cname{font-family:var(--fd);font-stretch:110%;font-weight:600;font-size:19px;color:var(--harbor-900)}
.client .csec{font-family:var(--fm);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--steel-500);margin-top:7px}
@media(max-width:880px){.cards.four{grid-template-columns:1fr}.clients{grid-template-columns:1fr 1fr}}
