/* Vosj — shared site stylesheet (open source). One design system across all pages. */
:root{
  --navy:#0E2235;--ink:#1b2b3a;--teal:#0f8b86;--accent:#15314a;--mut:#5c7286;
  --line:#e3eaf1;--code:#eef3f8;--codeink:#143a4f;--green:#16A34A;--amber:#C25A00;
  --blue:#2B6CB2;--purple:#7a3ea3;--soft:#f4f8fb;--soft2:#fafcfe
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Segoe UI',-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.62;font-size:16px}
a{color:var(--teal)}

/* ---- header / nav ---- */
header.top{border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:20}
.bar{max-width:1080px;margin:0 auto;padding:11px 22px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--navy);letter-spacing:.4px;text-decoration:none;flex:0 0 auto}
.brand svg{width:24px;height:24px}
.nav{display:flex;align-items:center;gap:3px;flex-wrap:wrap;margin-left:2px}
.nav a{font-size:14px;color:var(--accent);text-decoration:none;padding:6px 10px;border-radius:7px;font-weight:600}
.nav a:hover{background:var(--soft);color:var(--navy)}
.nav a.on{background:var(--navy);color:#fff}
.nav a.ext::after{content:" \2197";color:var(--mut);font-weight:400}
.right{display:flex;align-items:center;gap:12px;margin-left:auto}
.oss{font-size:12px;color:var(--green);border:1px solid #bfe6cd;background:#f1faf3;border-radius:999px;padding:3px 10px;font-weight:700;white-space:nowrap}
.lang{display:flex;gap:4px}
.lang button{font:inherit;font-size:13px;border:1px solid var(--line);background:#fff;color:var(--mut);padding:5px 10px;border-radius:7px;cursor:pointer}
.lang button.on{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ---- layout ---- */
main{max-width:880px;margin:0 auto;padding:34px 22px 6px}
article{display:none} article.active{display:block}
.crumbs{font-size:13px;color:var(--mut);margin:0 0 12px;letter-spacing:.02em}
.crumbs a{color:var(--mut);text-decoration:none}
.crumbs a:hover{color:var(--teal)}
h1{font-size:34px;line-height:1.12;margin:0 0 8px;color:var(--navy);letter-spacing:-.4px}
.tagline{color:var(--mut);font-size:15.5px;margin:0 0 22px}
.lead{font-size:18px;color:#2c4256;margin:0 0 18px}
h2{font-size:21px;color:var(--navy);margin:40px 0 10px;padding-bottom:6px;border-bottom:2px solid var(--line)}
h3{font-size:15.5px;margin:20px 0 4px;color:var(--accent)}
h4{font-size:14px;margin:16px 0 3px;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}
p{margin:0 0 13px} ul,ol{margin:0 0 13px;padding-left:20px} li{margin:5px 0}
code,.mono{background:var(--code);color:var(--codeink);padding:1px 6px;border-radius:5px;font-family:'Cascadia Code',Consolas,monospace;font-size:13.5px}
.mono{background:none;padding:0}
strong,b{color:var(--accent)}

/* ---- tables ---- */
table{width:100%;border-collapse:collapse;margin:8px 0 14px;font-size:14px}
th,td{text-align:left;border:1px solid var(--line);padding:8px 10px;vertical-align:top}
th{background:#f4f8fb;color:var(--navy);font-weight:700}
td .mono{font-weight:700;color:var(--blue)}
.tbl-scroll{overflow-x:auto}
.small{font-size:13px;color:var(--mut)}

/* ---- figures / diagrams ---- */
figure{margin:18px 0}
figure svg{width:100%;height:auto;border:1px solid var(--line);border-radius:12px;background:#fcfdff;display:block}
figcaption{color:var(--mut);font-size:13px;margin-top:7px;text-align:center}

/* ---- callouts / notes ---- */
.note,.callout{background:var(--soft);border-left:3px solid var(--teal);padding:11px 15px;border-radius:0 8px 8px 0;color:#33485c;font-size:14.5px;margin:14px 0}
.callout.good{background:#f7fcf8;border-left-color:var(--green)}
.callout.warn{background:#fbf3ef;border-left-color:var(--amber)}
.callout b{color:var(--navy)}

/* ---- pills / tags ---- */
.plat,.tags{display:flex;flex-wrap:wrap;gap:7px;margin:6px 0 14px}
.plat span,.tag{border:1px solid var(--line);border-radius:6px;padding:5px 11px;font-size:13.5px;color:var(--accent);background:#fafcfe}
.tag.teal{border-color:#b9e3e0;background:#f0faf9;color:#0c6b67}
.tag.blue{border-color:#bcd5ef;background:#eef5fc;color:#1f4f86}
.tag.amber{border-color:#f0d3bd;background:#fbf3ec;color:#9a4a08}

/* ---- cards / grids ---- */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:12px 0}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin:12px 0}
.card{border:1px solid var(--line);border-radius:12px;padding:16px 18px;background:#fff}
.card h3{margin-top:0}
.card .ico{font-size:20px;line-height:1;margin-bottom:6px;display:block}
.card.accent{border-color:#bcd5ef;background:#f7fbff}

/* ---- layered stack diagram (CSS, like the whitepaper) ---- */
.stackdia{margin:14px 0}
.stack{border:1px solid var(--line);border-radius:8px;margin:5px 0;padding:9px 13px;background:#fff}
.stack b{color:var(--navy)}
.stack .k{font-size:12px;color:var(--mut);font-weight:700;letter-spacing:.04em}
.stack.gov{background:#fbf3ef;border-color:#f0d3bd}
.stack.ai{background:#f4f0fb;border-color:#dccdef}
.stack.exec{background:#eef5fc;border-color:#bcd5ef}
.stack.data{background:#f0faf9;border-color:#b9e3e0}

/* ---- download cards ---- */
.dl{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:10px 0}
.dl a{display:block;border:1px solid var(--line);border-radius:10px;padding:14px 16px;text-decoration:none;color:var(--ink);background:#fff;transition:.12s}
.dl a:hover{border-color:var(--teal);box-shadow:0 6px 18px rgba(15,139,134,.12)}
.dl b{color:var(--navy)} .dl .k{font-size:12px;color:var(--mut);font-weight:700;letter-spacing:.5px}

/* ---- editions ---- */
.ed{border:1px solid var(--line);border-radius:12px;padding:18px 20px;margin:12px 0}
.ed.free{border-color:#bfe6cd;background:#f7fcf8} .ed h3{margin-top:0}

/* ---- next-page links ---- */
.next{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:26px 0 6px}
.next a{display:block;border:1px solid var(--line);border-radius:10px;padding:13px 16px;text-decoration:none;color:var(--ink);background:#fff}
.next a:hover{border-color:var(--teal)}
.next .k{font-size:12px;color:var(--mut);font-weight:700;letter-spacing:.4px}
.next b{color:var(--navy);display:block;margin-top:2px}

/* ---- footer ---- */
footer{border-top:1px solid var(--line);margin-top:40px;background:#fafcfe}
.foot{max-width:1080px;margin:0 auto;padding:24px 22px;color:var(--mut);font-size:14px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;align-items:center}
.foot a{font-weight:600}
.foot .tm{flex-basis:100%;color:var(--mut);font-size:12px;line-height:1.55;margin-top:8px;border-top:1px solid var(--line);padding-top:10px}

@media(max-width:720px){
  .grid2,.grid3,.dl,.next{grid-template-columns:1fr}
  h1{font-size:27px}
  .nav{width:100%;order:3}
}
