/*
Theme Name: Decode Systems 2026
Theme URI: https://decodesystems.net
Author: Decode Systems & Technology
Author URI: https://decodesystems.net
Description: Identity-first offensive-security theme for Decode Systems. Dark by default with a persistent light-mode toggle, CTEM-aligned messaging, a homepage with the maze-O signature mark and a live identity-first attack-path trace, a full Services template, and a Field-notes (single post) template. Built on the DECODE navy/cyan brand system.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: decode-systems
Tags: dark-mode, custom-menu, featured-images, translation-ready, two-columns, threaded-comments
*/

/* ============================================================
   DECODE SYSTEMS — shared stylesheet (dark default + light theme)
   ============================================================ */
:root{
  --void:#07142A; --navy:#0F2747; --panel:#102A4C; --panel-2:#0C2240;
  --line:#213A5F; --cyan:#19A8E8; --cyan-deep:#0098D8; --mist:#9FB4CC;
  --paper:#EAF2FA; --ember:#E5564E;
  --on-cyan:#04111F; --logo:#7e93ad;
  --glow:rgba(25,168,232,.16); --dot:rgba(25,168,232,.10);
  --grad-a:#08182F; --grad-b:#07142A;
  --threat-a:#07142A; --threat-b:#081A33; --why-bg:#081A33;
  --nav-bg:rgba(7,20,42,.82);
  --cta-glow:rgba(25,168,232,.22); --cta-a:#0A1E3A; --cta-b:#07152B;
  --signal-a:rgba(16,42,76,.55); --signal-b:rgba(12,34,64,.35);
  --tile-big-a:#143257; --tile-big-b:#0C2240; --tile-hover:#143257;
  --card-shadow:none;
  --maxw:1180px;
  --display:"Space Grotesk",system-ui,sans-serif;
  --body:"Inter",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
html[data-theme="light"]{
  --void:#F4F8FC; --navy:#0F2747; --panel:#FFFFFF; --panel-2:#EDF3FA;
  --line:#D7E3EF; --cyan:#0098D8; --cyan-deep:#0079AD; --mist:#51617A;
  --paper:#0F2747; --ember:#C0392B;
  --on-cyan:#FFFFFF; --logo:#7488A0;
  --glow:rgba(0,152,216,.12); --dot:rgba(0,152,216,.10);
  --grad-a:#E9F3FB; --grad-b:#F4F8FC;
  --threat-a:#F4F8FC; --threat-b:#E8F1FB; --why-bg:#E8F1FB;
  --nav-bg:rgba(244,248,252,.88);
  --cta-glow:rgba(0,152,216,.16); --cta-a:#E3EFFA; --cta-b:#F4F8FC;
  --signal-a:#FFFFFF; --signal-b:#F1F6FC;
  --tile-big-a:#FFFFFF; --tile-big-b:#EDF3FA; --tile-hover:#F5F9FE;
  --card-shadow:0 1px 3px rgba(15,39,71,.07);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--void);color:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .3s ease,color .3s ease}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--cyan);color:#04121F}
a:focus-visible,button:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:4px}

/* ---------- utilities ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--cyan);font-weight:500;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--cyan);display:inline-block}
h2.section-title{font-family:var(--display);font-weight:600;line-height:1.08;font-size:clamp(28px,4vw,44px);letter-spacing:-0.5px;margin:18px 0 0;max-width:18ch}
.section-lead{color:var(--mist);max-width:60ch;margin-top:16px;font-size:17px}
section{padding:104px 0;position:relative}
.btn{font-family:var(--mono);font-size:13px;font-weight:500;letter-spacing:.5px;display:inline-flex;align-items:center;gap:9px;cursor:pointer;padding:14px 22px;border-radius:8px;border:1px solid transparent;transition:transform .18s ease,background .18s ease,border-color .18s ease,color .18s ease}
.btn-primary{background:var(--cyan);color:var(--on-cyan);font-weight:700}
.btn-primary:hover{transform:translateY(-2px);background:var(--cyan-deep)}
.btn-ghost{border-color:var(--line);color:var(--paper)}
.btn-ghost:hover{border-color:var(--cyan);color:var(--cyan);transform:translateY(-2px)}
.btn .arrow{transition:transform .18s ease}
.btn:hover .arrow{transform:translateX(3px)}

/* ---------- background grid ---------- */
.dotgrid{position:absolute;inset:0;pointer-events:none;z-index:0;background-image:radial-gradient(var(--dot) 1px,transparent 1.4px);background-size:34px 34px;-webkit-mask-image:linear-gradient(180deg,#000,transparent 70%);mask-image:linear-gradient(180deg,#000,transparent 70%)}

/* ---------- nav ---------- */
header.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .25s ease,border-color .25s ease,backdrop-filter .25s ease;border-bottom:1px solid transparent}
header.nav.scrolled{background:var(--nav-bg);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:baseline;gap:9px;font-family:var(--display);font-weight:700;font-size:22px;letter-spacing:.5px;color:var(--paper)}
.brand .dot{color:var(--cyan)}
.brand small{font-family:var(--mono);font-weight:400;font-size:10px;letter-spacing:2px;color:var(--mist);text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links li{list-style:none;display:flex;align-items:center}
.nav-links a{font-size:14px;color:var(--mist);transition:color .15s ease}
.nav-links a:hover{color:var(--paper)}
.nav-right{display:flex;align-items:center;gap:14px}
.theme-toggle{width:38px;height:38px;border:1px solid var(--line);background:transparent;color:var(--paper);border-radius:8px;cursor:pointer;font-size:15px;line-height:1;display:grid;place-items:center;transition:border-color .18s,color .18s}
.theme-toggle:hover{border-color:var(--cyan);color:var(--cyan)}
.theme-toggle .to-dark{display:none}
html[data-theme="light"] .theme-toggle .to-light{display:none}
html[data-theme="light"] .theme-toggle .to-dark{display:inline}
.nav-cta{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.5px;background:var(--cyan);color:var(--on-cyan);padding:11px 16px;border-radius:7px;transition:background .18s,transform .18s}
.nav-cta:hover{background:var(--cyan-deep);transform:translateY(-1px)}
.menu-btn{display:none;background:none;border:1px solid var(--line);color:var(--paper);border-radius:7px;padding:8px 10px;font-family:var(--mono);font-size:12px;cursor:pointer}

/* ---------- hero ---------- */
.hero{padding:160px 0 90px;position:relative;background:radial-gradient(1100px 520px at 78% -8%,var(--glow),transparent 60%),linear-gradient(180deg,var(--grad-a) 0%,var(--void) 60%)}
.hero .wrap{position:relative;z-index:2}
.hero-mark{position:absolute;top:96px;right:0;width:clamp(190px,24vw,340px);height:auto;z-index:-1;pointer-events:none;filter:drop-shadow(0 22px 55px rgba(25,168,232,.20));animation:omaze-float 7.5s ease-in-out infinite}
@keyframes omaze-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media(max-width:1040px){.hero-mark{display:none}}
@media(prefers-reduced-motion:reduce){.hero-mark{animation:none}}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(40px,7vw,82px);line-height:.98;letter-spacing:-1.5px;margin:22px 0 0;max-width:16ch}
.hero h1 .alt{color:var(--cyan)}
.hero p.sub{color:var(--mist);font-size:clamp(16px,2vw,19px);max-width:56ch;margin-top:24px}
.hero-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}

/* ---------- signature: identity-first attack path ---------- */
.signal{margin-top:64px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,var(--signal-a),var(--signal-b));padding:22px 24px 26px;position:relative;overflow:hidden;box-shadow:var(--card-shadow)}
.signal-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:26px}
.signal-head .label{font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--mist)}
.signal-head .label b{color:var(--cyan);font-weight:700}
.clock{font-family:var(--mono);font-size:13px;color:var(--paper)}
.clock .t{color:var(--cyan);font-weight:700}
.path{display:grid;grid-template-columns:repeat(5,1fr);gap:0;align-items:start;position:relative}
.path-line{position:absolute;top:11px;left:8%;right:8%;height:2px;background:var(--line);overflow:hidden;border-radius:2px}
.path-line::after{content:"";position:absolute;top:0;left:-30%;width:30%;height:100%;background:linear-gradient(90deg,transparent,var(--cyan),transparent);animation:scan 4.6s linear infinite}
@keyframes scan{0%{left:-30%}100%{left:100%}}
.node{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;position:relative;z-index:2}
.node .dot{width:24px;height:24px;border-radius:50%;border:2px solid var(--line);background:var(--void);display:grid;place-items:center;transition:border-color .3s,box-shadow .3s}
.node .dot::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--line);transition:background .3s}
.node.lit .dot{border-color:var(--cyan);box-shadow:0 0 0 4px rgba(25,168,232,.14)}
.node.lit .dot::after{background:var(--cyan)}
.node.impact.lit .dot{border-color:var(--ember);box-shadow:0 0 0 4px rgba(229,86,78,.16)}
.node.impact.lit .dot::after{background:var(--ember)}
.node .nm{font-size:12.5px;color:var(--paper);font-weight:500;line-height:1.3}
.node .tac{font-family:var(--mono);font-size:9.5px;letter-spacing:.5px;color:var(--mist);text-transform:uppercase}
.signal-foot{margin-top:22px;font-size:13px;color:var(--mist);border-top:1px solid var(--line);padding-top:16px}
.signal-foot b{color:var(--paper);font-weight:600}

/* ---------- trust strip ---------- */
.trust{padding:46px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--panel-2)}
.trust .lbl{font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--mist);text-align:center;margin-bottom:22px}
.logos{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 36px}
.logos span{font-family:var(--display);font-weight:600;font-size:15px;color:var(--logo);letter-spacing:.3px;transition:color .2s;white-space:nowrap}
.logos span:hover{color:var(--paper)}
/* image logo wall — monochrome, theme-aware, brightens on hover.
   To show FULL-COLOUR logos instead, delete the two `filter:` lines below. */
.logo-wall{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:26px 46px}
.logo-wall a{display:inline-flex;align-items:center}
.logo-wall img{height:28px;width:auto;max-width:200px;object-fit:contain;opacity:.62;filter:grayscale(1) brightness(0) invert(1);transition:opacity .2s ease,filter .2s ease}
html[data-theme="light"] .logo-wall img{filter:grayscale(1) brightness(0);opacity:.5}
.logo-wall img:hover{opacity:1}
@media(max-width:620px){.logo-wall{gap:20px 30px}.logo-wall img{height:22px}}

/* ---------- threat reality ---------- */
.threat{background:linear-gradient(180deg,var(--threat-a),var(--threat-b))}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.stat{border-left:3px solid var(--cyan);padding:6px 0 6px 22px}
.stat .n{font-family:var(--display);font-weight:700;font-size:clamp(42px,6vw,64px);line-height:1;letter-spacing:-1px}
.stat .n .u{font-size:.4em;color:var(--cyan);font-weight:600;margin-left:4px}
.stat .d{color:var(--mist);font-size:14px;margin-top:12px;max-width:30ch}
.threat .kicker{margin-top:40px;font-size:18px;max-width:60ch}
.threat .kicker b{color:var(--cyan)}

/* ---------- approach principles ---------- */
.principles{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:52px}
.principle{border:1px solid var(--line);border-radius:12px;padding:24px;background:var(--panel-2);transition:transform .2s,border-color .2s;box-shadow:var(--card-shadow)}
.principle:hover{transform:translateY(-4px);border-color:var(--cyan)}
.principle .ix{font-family:var(--mono);font-size:12px;color:var(--cyan);font-weight:700}
.principle h3{font-family:var(--display);font-weight:600;font-size:18px;margin:14px 0 8px;letter-spacing:-.2px;color:var(--paper)}
.principle p{color:var(--mist);font-size:14px}

/* ---------- services bento ---------- */
.bento{display:grid;gap:18px;margin-top:52px;grid-template-columns:repeat(4,1fr);grid-template-areas:"vapt vapt ctem identity" "vapt vapt ai forensics" "grc training training forensics"}
.tile{border:1px solid var(--line);border-radius:14px;background:var(--panel);padding:26px;position:relative;overflow:hidden;transition:transform .2s,border-color .2s,background .2s;min-height:168px;display:flex;flex-direction:column;box-shadow:var(--card-shadow)}
.tile:hover{transform:translateY(-4px);border-color:var(--cyan);background:var(--tile-hover)}
.tile .tag{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cyan)}
.tile h3{font-family:var(--display);font-weight:600;font-size:20px;margin:12px 0 10px;letter-spacing:-.3px;color:var(--paper)}
.tile.big h3{font-size:27px}
.tile p{color:var(--mist);font-size:14px}
.tile .chips{margin-top:auto;padding-top:16px;display:flex;flex-wrap:wrap;gap:7px}
.chip{font-family:var(--mono);font-size:10.5px;color:var(--mist);border:1px solid var(--line);border-radius:20px;padding:4px 10px}
.tile.big{grid-area:vapt;background:linear-gradient(160deg,var(--tile-big-a),var(--tile-big-b))}
.tile.big .big-num{font-family:var(--mono);font-size:12px;color:var(--cyan);margin-top:14px}
.t-ctem{grid-area:ctem}.t-identity{grid-area:identity}.t-ai{grid-area:ai}.t-forensics{grid-area:forensics}.t-grc{grid-area:grc}.t-training{grid-area:training}

/* ---------- sectors ---------- */
.sectors-grid{display:flex;flex-wrap:wrap;gap:12px;margin-top:44px}
.sector{border:1px solid var(--line);border-radius:10px;padding:16px 20px;background:var(--panel-2);font-family:var(--mono);font-size:13px;color:var(--paper);display:flex;align-items:center;gap:12px;transition:border-color .2s,color .2s;box-shadow:var(--card-shadow)}
.sector:hover{border-color:var(--cyan)}
.sector .num{color:var(--cyan);font-size:11px}

/* ---------- why ---------- */
.why{background:var(--why-bg)}
.why-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:start}
.why-list{margin-top:34px;display:flex;flex-direction:column;gap:0}
.why-item{padding:22px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:40px 1fr;gap:18px}
.why-item:last-child{border-bottom:1px solid var(--line)}
.why-item .k{font-family:var(--mono);font-size:13px;color:var(--cyan);font-weight:700}
.why-item h4{font-family:var(--display);font-weight:600;font-size:17px;margin-bottom:6px;color:var(--paper)}
.why-item p{color:var(--mist);font-size:14px}
.why-card{border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,var(--panel),var(--panel-2));padding:30px;position:sticky;top:96px;box-shadow:var(--card-shadow)}
.why-card .q{font-family:var(--display);font-size:21px;font-weight:600;line-height:1.35;letter-spacing:-.3px;color:var(--paper)}
.why-card .q .alt{color:var(--cyan)}
.why-card .certs{margin-top:22px;display:flex;flex-wrap:wrap;gap:8px}
.why-card .meta{margin-top:24px;font-family:var(--mono);font-size:12px;color:var(--mist);line-height:1.9}
.why-card .meta b{color:var(--paper)}

/* ---------- field-note cards ---------- */
.notes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.note{border:1px solid var(--line);border-radius:12px;padding:24px;background:var(--panel-2);transition:transform .2s,border-color .2s;display:flex;flex-direction:column;min-height:200px;box-shadow:var(--card-shadow)}
.note:hover{transform:translateY(-4px);border-color:var(--cyan)}
.note .date{font-family:var(--mono);font-size:11px;color:var(--cyan);letter-spacing:1px}
.note h3{font-family:var(--display);font-weight:600;font-size:19px;margin:14px 0 10px;line-height:1.2;letter-spacing:-.3px;color:var(--paper)}
.note p{color:var(--mist);font-size:14px}
.note .read{margin-top:auto;padding-top:16px;font-family:var(--mono);font-size:12px;color:var(--cyan)}

/* ---------- cta band ---------- */
.cta-band{background:radial-gradient(700px 360px at 50% 120%,var(--cta-glow),transparent 60%),linear-gradient(180deg,var(--cta-a),var(--cta-b));border-top:1px solid var(--line);text-align:center}
.cta-band h2{font-family:var(--display);font-weight:700;font-size:clamp(30px,5vw,52px);letter-spacing:-1px;line-height:1.05;color:var(--paper)}
.cta-band h2 .alt{color:var(--cyan)}
.cta-band p{color:var(--mist);max-width:48ch;margin:18px auto 0;font-size:17px}
.cta-band .hero-cta{justify-content:center}

/* ---------- footer ---------- */
footer.site{background:var(--void);border-top:1px solid var(--line);padding:64px 0 36px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:36px}
.foot-brand .brand{margin-bottom:16px}
.foot-brand p{color:var(--mist);font-size:14px;max-width:34ch}
.foot-col h5{font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--mist);margin-bottom:16px}
.foot-col a,.foot-col p{display:block;color:var(--paper);font-size:14px;margin-bottom:10px;transition:color .15s}
.foot-col a:hover{color:var(--cyan)}
.foot-bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--mono);font-size:11.5px;color:var(--mist);letter-spacing:.5px}

/* ============================================================
   INTERIOR PAGES
   ============================================================ */
/* page hero (services / archive / generic) */
.page-hero{padding:150px 0 70px;position:relative;background:radial-gradient(900px 440px at 80% -10%,var(--glow),transparent 60%),linear-gradient(180deg,var(--grad-a),var(--void) 70%)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-family:var(--display);font-weight:700;font-size:clamp(34px,5.5vw,60px);line-height:1.02;letter-spacing:-1px;margin:20px 0 0;max-width:20ch}
.page-hero h1 .alt{color:var(--cyan)}
.page-hero p.sub{color:var(--mist);font-size:clamp(16px,2vw,19px);max-width:60ch;margin-top:22px}

/* services detail blocks */
.svc-block{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:54px 0;border-top:1px solid var(--line);align-items:start}
.svc-block:last-child{border-bottom:1px solid var(--line)}
.svc-block .svc-tag{font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--cyan)}
.svc-block h2{font-family:var(--display);font-weight:600;font-size:clamp(24px,3vw,32px);letter-spacing:-.5px;margin:14px 0 16px;color:var(--paper)}
.svc-block .lede{color:var(--mist);font-size:16px}
.svc-block .chips{margin-top:20px;display:flex;flex-wrap:wrap;gap:8px}
.svc-list{list-style:none;border:1px solid var(--line);border-radius:14px;background:var(--panel-2);padding:10px 24px;box-shadow:var(--card-shadow)}
.svc-list li{padding:15px 0;border-bottom:1px solid var(--line);display:grid;grid-template-columns:20px 1fr;gap:14px;color:var(--paper);font-size:14.5px}
.svc-list li:last-child{border-bottom:none}
.svc-list li .mk{color:var(--cyan);font-family:var(--mono);font-size:12px}
.svc-list li span.d{color:var(--mist);display:block;font-size:13px;margin-top:3px}

/* engagement tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:50px}
.tier{border:1px solid var(--line);border-radius:14px;background:var(--panel-2);padding:28px;display:flex;flex-direction:column;transition:transform .2s,border-color .2s;box-shadow:var(--card-shadow)}
.tier:hover{transform:translateY(-4px);border-color:var(--cyan)}
.tier.feature{background:linear-gradient(170deg,var(--tile-big-a),var(--tile-big-b));border-color:var(--cyan)}
.tier .name{font-family:var(--display);font-weight:600;font-size:21px;color:var(--paper)}
.tier .for{font-family:var(--mono);font-size:11px;color:var(--cyan);letter-spacing:1px;text-transform:uppercase;margin-top:6px}
.tier ul{list-style:none;margin:20px 0 0}
.tier li{padding:9px 0;color:var(--mist);font-size:13.5px;display:grid;grid-template-columns:18px 1fr;gap:10px;border-top:1px solid var(--line)}
.tier li .ck{color:var(--cyan)}
.tier .badge{align-self:flex-start;font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;background:var(--cyan);color:var(--on-cyan);padding:4px 9px;border-radius:20px;margin-bottom:16px;font-weight:700}

/* ============================================================
   SINGLE FIELD NOTE (article)
   ============================================================ */
.article-hero{padding:140px 0 40px;position:relative;background:linear-gradient(180deg,var(--grad-a),var(--void) 80%)}
.article-hero .wrap{position:relative;z-index:2;max-width:820px}
.article-cat{font-family:var(--mono);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--cyan)}
.article-hero h1{font-family:var(--display);font-weight:700;font-size:clamp(30px,4.6vw,50px);line-height:1.08;letter-spacing:-.8px;margin:18px 0 0;color:var(--paper)}
.article-meta{margin-top:22px;font-family:var(--mono);font-size:12.5px;color:var(--mist);display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center}
.article-meta .sep{color:var(--line)}
.article-cover{max-width:980px;margin:34px auto 0;padding:0 28px}
.article-cover .frame{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--panel-2);aspect-ratio:16/7;display:grid;place-items:center}
.article-cover .frame .ph{font-family:var(--mono);font-size:12px;color:var(--mist);letter-spacing:2px}
.article-body{padding:48px 0 90px}
.prose{max-width:720px;margin:0 auto;font-size:17.5px;line-height:1.75;color:var(--paper)}
.prose>p{margin:0 0 24px;color:var(--paper)}
.prose .standfirst{font-size:21px;line-height:1.55;color:var(--mist);margin-bottom:34px}
.prose h2{font-family:var(--display);font-weight:600;font-size:27px;letter-spacing:-.4px;margin:46px 0 14px;color:var(--paper)}
.prose h3{font-family:var(--display);font-weight:600;font-size:20px;margin:32px 0 10px;color:var(--cyan)}
.prose ul,.prose ol{margin:0 0 24px;padding-left:22px}
.prose li{margin-bottom:9px;color:var(--mist)}
.prose a{color:var(--cyan);text-decoration:underline;text-underline-offset:3px}
.prose blockquote{border-left:3px solid var(--cyan);padding:6px 0 6px 24px;margin:30px 0;color:var(--paper);font-family:var(--display);font-size:21px;font-weight:500;line-height:1.45}
.prose code{font-family:var(--mono);background:var(--panel-2);border:1px solid var(--line);padding:2px 7px;border-radius:5px;font-size:.86em}
.prose pre{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:18px 20px;overflow:auto;margin:0 0 24px}
.prose pre code{background:none;border:none;padding:0}
.prose img{border-radius:12px;border:1px solid var(--line);margin:8px 0 24px}
.prose hr{border:none;border-top:1px solid var(--line);margin:38px 0}
.callout{border:1px solid var(--line);border-left:3px solid var(--cyan);background:var(--panel-2);border-radius:12px;padding:20px 24px;margin:30px 0;font-size:15px;color:var(--mist)}
.callout b{color:var(--paper)}
.article-foot{max-width:720px;margin:48px auto 0;padding-top:26px;border-top:1px solid var(--line)}
.tagrow{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:30px}
.author-box{display:flex;gap:16px;align-items:center;border:1px solid var(--line);border-radius:14px;background:var(--panel-2);padding:20px 22px;box-shadow:var(--card-shadow)}
.author-box .ab-av{width:46px;height:46px;border-radius:50%;background:var(--cyan);color:var(--on-cyan);display:grid;place-items:center;font-family:var(--display);font-weight:700;flex:0 0 auto}
.author-box .ab-n{font-family:var(--display);font-weight:600;color:var(--paper)}
.author-box .ab-r{font-family:var(--mono);font-size:12px;color:var(--mist)}
.post-nav{max-width:720px;margin:34px auto 0;display:flex;justify-content:space-between;gap:16px;font-family:var(--mono);font-size:12.5px}
.post-nav a{color:var(--cyan)}
.post-nav a:hover{color:var(--paper)}

/* breadcrumb / back */
.backbar{max-width:720px;margin:0 auto}
.backbar a{font-family:var(--mono);font-size:12px;color:var(--mist)}
.backbar a:hover{color:var(--cyan)}

/* archive intro spacing helper */
.section-tight{padding-top:64px}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .nav-links{display:none}
  .nav-links.open{display:flex;flex-direction:column;gap:0;position:absolute;top:70px;left:0;right:0;background:var(--nav-bg);backdrop-filter:blur(10px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:10px 28px 18px}
  .nav-links.open li{width:100%}
  .nav-links.open a{padding:13px 0;border-bottom:1px solid var(--line);font-size:15px;width:100%}
  .nav-cta{display:none}
  .menu-btn{display:inline-block}
  .principles{grid-template-columns:repeat(2,1fr)}
  .bento{grid-template-columns:repeat(2,1fr);grid-template-areas:"vapt vapt" "ctem identity" "ai forensics" "grc training"}
  .why-grid{grid-template-columns:1fr;gap:34px}
  .why-card{position:static}
  .notes{grid-template-columns:1fr}
  .svc-block{grid-template-columns:1fr;gap:24px;padding:40px 0}
  .tiers{grid-template-columns:1fr}
}
@media(max-width:620px){
  section{padding:74px 0}
  .stats{grid-template-columns:1fr;gap:28px}
  .principles{grid-template-columns:1fr}
  .bento{grid-template-columns:1fr;grid-template-areas:"vapt" "ctem" "identity" "ai" "forensics" "grc" "training"}
  .path{grid-template-columns:repeat(5,1fr)}
  .node .nm{font-size:10px}.node .tac{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
  .prose{font-size:16.5px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .path-line::after{display:none}
}
