/* ============================================================
   Portail prospect - Fondation Trajets
   ABAXINFO x AXION - theme clair Inter
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  /* Direction artistique ABAXINFO - vert #88bf52 / anthracite #2b2c2e / blanc */
  --bg:#ffffff;--bg1:#f7f8f5;--bg2:#eef1ea;--bg3:#e4e8dd;
  --border:#e4e7dd;--border2:#cfd5c4;
  --text:#2b2c2e;--text2:#555759;--text3:#7c8178;
  /* accent de marque : vert ABAXINFO (anciens teal/cyan/green/orange y sont mappés) */
  --green:#88bf52;--green-bg:rgba(136,191,82,.14);--green-ink:#4a6e2a;
  --teal:#88bf52;--teal-bg:rgba(136,191,82,.14);
  --cyan:#88bf52;--cyan-bg:rgba(136,191,82,.14);
  --orange:#88bf52;--orange-bg:rgba(136,191,82,.14);
  /* neutres anthracite/ardoise pour la duotonie sobre */
  --blue:#4b5563;--blue-bg:rgba(75,85,99,.10);
  --purple:#6b7280;--purple-bg:rgba(107,114,128,.10);
  /* couleurs fonctionnelles (alerte / attention) - usage sémantique seulement */
  --amber:#b8860b;--amber-bg:rgba(184,134,11,.12);
  --red:#b04632;--red-bg:rgba(176,70,50,.12);
}
body{background:var(--bg);color:var(--text);font-family:'Heebo',sans-serif;min-height:100vh;-webkit-font-smoothing:antialiased;}
/* Titres : Montserrat (substitut Nexa en attendant les fichiers de licence) */
.hero h1,.section h2,.toc h3,.tile-title,.entity-name,.card-title,.volet-title,.rb-title,.sub-header,.cta h3,.nav-logo,.hb-name{font-family:'Montserrat',sans-serif;}

/* ---------- NAV ---------- */
.nav{background:var(--bg1);border-bottom:1px solid var(--border);padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:56px;position:sticky;top:0;z-index:100;}
.nav-logo{font-size:15px;font-weight:800;letter-spacing:-.3px;color:var(--text);white-space:nowrap;}
.nav-logo .x{color:inherit;}
.nav-logo .sep{color:var(--text3);font-weight:400;margin:0 5px;}
.nav-meta{font-size:12px;color:var(--text3);}
.nav-meta span{color:var(--text2);}
.nav-back{text-decoration:none;color:var(--text3);font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;transition:color .2s;}
.nav-back:hover{color:var(--green-ink);}

/* ---------- HEADER de marque (page d'accueil) ---------- */
header{padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200;background:rgba(255,255,255,.96);border-bottom:1px solid var(--border);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);}
.header-brands{display:flex;align-items:center;gap:12px;}
.hb-logo{height:34px;width:auto;display:block;flex-shrink:0;}
.hb-name{font-size:17px;font-weight:800;letter-spacing:-.3px;white-space:nowrap;}
.hb-name .a{color:var(--green-ink);}
.hb-name .b{color:var(--text);}
.hb-with{font-size:12px;font-weight:600;color:var(--text3);white-space:nowrap;}
.hb-with .hb-axion{color:var(--text2);font-weight:700;}
.hb-with .hb-trajets{color:var(--text2);font-weight:700;}
.badge-collab{background:var(--green-bg);border:1px solid var(--green);color:#5a7d35;font-size:10px;font-weight:700;padding:3px 11px;border-radius:50px;letter-spacing:1px;text-transform:uppercase;white-space:nowrap;}
.badge-collab svg{width:11px;height:11px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vertical-align:-1px;margin-right:4px;}
@media(max-width:560px){.hb-with{display:none;}}
@media(max-width:860px){header{padding:0 18px;}.hb,.badge-collab{font-size:11px;}}
@media(max-width:560px){header{height:auto;min-height:54px;padding:8px 14px;flex-wrap:wrap;gap:6px 8px;}.header-brands{flex-wrap:wrap;gap:4px 8px;}.hb,.badge-collab{font-size:10px;}.badge-collab{padding:2px 9px;}.nav-meta{display:none;}.nav-logo{font-size:14px;}}

/* ---------- HERO ---------- */
.hero{background:linear-gradient(135deg, var(--bg1) 0%, #eef6f8 100%);border-bottom:1px solid var(--border);padding:44px 24px 36px;}
.hero-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--green-ink);margin-bottom:12px;}
.hero h1{font-size:30px;font-weight:800;margin-bottom:12px;letter-spacing:-.6px;line-height:1.15;}
.hero h1 span{color:var(--green-ink);}
.hero-sub{font-size:15px;color:var(--text2);line-height:1.65;max-width:820px;margin-bottom:24px;}
.hero-meta{display:flex;gap:28px;flex-wrap:wrap;}
.meta-item{display:flex;flex-direction:column;gap:3px;}
.meta-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;}
.meta-value{font-size:13px;font-weight:600;color:var(--text);}

/* ---------- LAYOUT ---------- */
.wrap{max-width:1360px;margin:0 auto;padding:40px 24px;}
.wrap-narrow{max-width:1040px;margin:0 auto;padding:40px 24px;}
.page{display:grid;grid-template-columns:240px 1fr;gap:0;max-width:1440px;margin:0 auto;}
.toc{align-self:start;margin:22px 14px 22px 16px;padding:18px 16px;background:var(--bg1);border:1px solid var(--border);border-radius:14px;box-shadow:0 14px 34px -22px rgba(15,23,42,.35);position:sticky;top:72px;max-height:calc(100vh - 96px);overflow-y:auto;}
.toc h3{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;}
.toc a{display:block;font-size:12px;color:var(--text2);text-decoration:none;padding:6px 8px;border-radius:5px;margin-bottom:2px;transition:all .15s;}
.toc a:hover{background:var(--bg2);color:var(--text);}
.toc a.section{font-weight:700;color:var(--text);font-size:11px;margin-top:10px;}
.content{padding:40px 24px;}

/* ---------- SECTION HEADERS ---------- */
.section{margin-bottom:46px;}
.section-header{display:flex;align-items:center;gap:12px;margin-bottom:22px;padding-bottom:14px;border-bottom:2px solid var(--border);}
.section-header.teal{border-bottom-color:var(--green-ink);}
.section-header.blue{border-bottom-color:var(--blue);}
.section-header.green{border-bottom-color:var(--green-ink);}
.section-header.purple{border-bottom-color:var(--purple);}
.section-header.amber{border-bottom-color:var(--amber);}
.section-header.orange{border-bottom-color:var(--green-ink);}
.section-header.cyan{border-bottom-color:var(--green-ink);}
.section-header.red{border-bottom-color:var(--red);}
.section-icon{font-size:20px;}
.section-num{font-size:11px;font-weight:700;color:var(--text3);font-family:'JetBrains Mono',monospace;}
.section h2{font-size:19px;font-weight:800;letter-spacing:-.3px;}
.lead{font-size:14px;color:var(--text2);line-height:1.7;margin-bottom:18px;max-width:780px;}

/* ---------- TILES (vcards) ---------- */
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:20px;}
.tile{display:flex;flex-direction:column;background:var(--bg1);border:1px solid var(--border);border-radius:14px;padding:22px;text-decoration:none;color:inherit;transition:transform .16s, box-shadow .16s, border-color .16s;position:relative;overflow:hidden;}
.tile::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--teal);opacity:.85;}
.tile.blue::before{background:var(--blue);}
.tile.green::before{background:var(--green);}
.tile.purple::before{background:var(--purple);}
.tile.amber::before{background:var(--amber);}
.tile.cyan::before{background:var(--cyan);}
.tile.orange::before{background:var(--orange);}
.tile:hover{transform:translateY(-3px);box-shadow:0 12px 28px -12px rgba(15,23,42,.22);border-color:var(--border2);}
.tile.soon{opacity:.72;cursor:default;}
.tile.soon:hover{transform:none;box-shadow:none;border-color:var(--border);}
.tile-icon{font-size:26px;margin-bottom:14px;}
.tile-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--green-ink);margin-bottom:8px;}
.tile.blue .tile-tag{color:var(--blue);}
.tile.green .tile-tag{color:var(--green-ink);}
.tile.purple .tile-tag{color:var(--purple);}
.tile.amber .tile-tag{color:var(--amber);}
.tile.cyan .tile-tag{color:var(--green-ink);}
.tile.orange .tile-tag{color:var(--green-ink);}
.tile-title{font-size:16px;font-weight:800;letter-spacing:-.2px;margin-bottom:8px;line-height:1.3;}
.tile-desc{font-size:13px;color:var(--text2);line-height:1.6;flex:1;}
.tile-footer{display:flex;align-items:center;justify-content:space-between;margin-top:16px;}
.tile-meta{font-size:11px;color:var(--text3);font-weight:600;}
.tile-arrow{font-size:18px;color:var(--green-ink);transition:transform .16s;}
.tile:hover .tile-arrow{transform:translateX(4px);}
.tile.row{flex-direction:row;align-items:flex-start;gap:20px;}
.tile.row .tile-icon{margin-bottom:0;font-size:32px;line-height:1;flex-shrink:0;}
.tile.row .tile-body{flex:1;min-width:0;display:flex;flex-direction:column;}
/* --- Icônes ligne (SVG) & élévation premium --- */
.tile-icon svg,.section-icon svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;display:block;}
.section-icon{display:inline-flex;color:var(--text3);font-size:0;}
.section-header.teal .section-icon{color:var(--green-ink);}
.section-header.blue .section-icon{color:var(--blue);}
.section-header.green .section-icon{color:var(--green-ink);}
.section-header.purple .section-icon{color:var(--purple);}
.section-header.orange .section-icon{color:var(--green-ink);}
.section-header.cyan .section-icon{color:var(--green-ink);}
.section-header.amber .section-icon{color:var(--amber);}
.section-header.red .section-icon{color:var(--red);}
.tile-icon{color:var(--green-ink);line-height:0;}
.tile.blue .tile-icon{color:var(--blue);}
.tile.green .tile-icon{color:var(--green-ink);}
.tile.purple .tile-icon{color:var(--purple);}
.tile.amber .tile-icon{color:var(--amber);}
.tile.cyan .tile-icon{color:var(--green-ink);}
.tile.orange .tile-icon{color:var(--green-ink);}
.tile.row .tile-icon svg{width:28px;height:28px;}
.tile-value{margin-top:12px;font-size:12.5px;color:var(--text);line-height:1.5;background:var(--bg2);border-radius:9px;padding:9px 13px;}
.tile-value strong{color:var(--green-ink);font-weight:700;}
.tile.blue .tile-value strong{color:var(--blue);}
.tile.green .tile-value strong{color:var(--green-ink);}
.tile.purple .tile-value strong{color:var(--purple);}
.tile.amber .tile-value strong{color:var(--amber);}
.tile.cyan .tile-value strong{color:var(--green-ink);}
.tile.orange .tile-value strong{color:var(--green-ink);}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:0 0 38px;}
.steps .tile-desc{font-size:12.5px;}
@media(max-width:1000px){.steps{grid-template-columns:repeat(3,1fr);}}
@media(max-width:680px){.steps{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.steps{grid-template-columns:1fr;}}
.steps .tile{cursor:pointer;}
.steps .tile.active{background:var(--bg2);border-color:var(--border2);}
.steps .tile.active::before{height:5px;opacity:1;}
.step-panel{display:none;scroll-margin-top:64px;}
.step-panel.active{display:block;}
.hero-value{display:flex;flex-wrap:wrap;gap:9px 20px;margin-top:18px;}
.hero-value span{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--text2);font-weight:600;}
.hero-value svg{width:15px;height:15px;fill:none;stroke:var(--teal);stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;}
.step-frame{width:100%;border:0;display:block;background:var(--bg);}
body.embed{padding-bottom:14px;min-height:0 !important;}
body.embed .nav, body.embed footer{display:none !important;}
body.embed .hero{padding-top:26px;}
body.embed .toc{display:none !important;}
body.embed .page{grid-template-columns:1fr;}
.toc a.section.active{background:var(--bg2);color:var(--green-ink);}

/* ---------- STICKY MINI-BAR (01-05) ---------- */
.sticky-steps{position:fixed;top:60px;left:0;right:0;z-index:150;background:rgba(255,255,255,.97);border-bottom:1px solid var(--border);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);display:none;box-shadow:0 2px 8px -4px rgba(15,23,42,.08);}
.sticky-steps.visible{display:flex;}
.ss-inner{max-width:1360px;margin:0 auto;padding:0 24px;display:flex;align-items:stretch;height:44px;width:100%;}
.ss-btn{display:flex;align-items:center;gap:7px;padding:0 12px;flex:1;justify-content:center;background:none;border:none;border-top:3px solid transparent;cursor:pointer;font-family:'Heebo',sans-serif;font-size:12px;font-weight:600;color:var(--text2);white-space:nowrap;transition:color .15s,background .15s,border-color .15s;}
.ss-btn:hover{color:var(--text);background:var(--bg1);}
.ss-btn.active{color:var(--text);border-top-color:var(--green-ink);}
.ss-btn.s-blue.active{border-top-color:var(--blue);}
.ss-btn.s-purple.active{border-top-color:var(--purple);}
.ss-num{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text3);font-weight:700;}
.ss-btn.active .ss-num{color:var(--green-ink);}
.ss-btn.s-blue.active .ss-num{color:var(--blue);}
.ss-btn.s-purple.active .ss-num{color:var(--purple);}
.ss-sep{width:1px;background:var(--border);flex-shrink:0;margin:10px 0;}
.ss-top-btn{display:flex;align-items:center;justify-content:center;padding:0 14px;background:none;border:none;border-left:1px solid var(--border);cursor:pointer;color:var(--text3);font-size:18px;line-height:1;transition:color .15s;flex-shrink:0;}
.ss-top-btn:hover{color:var(--green-ink);}
@media(max-width:760px){.ss-label{display:none;}.ss-btn{padding:0 8px;}}
@media(max-width:480px){.ss-inner{padding:0 10px;}.ss-btn{padding:0 5px;}}

/* ---------- PANEL LAYOUT (sidebar + contenu) ---------- */
.panel-layout{display:grid;grid-template-columns:220px 1fr;gap:20px;align-items:start;}
.panel-layout.solo{grid-template-columns:1fr;}
.panel-main{min-width:0;}
.panel-toc{position:sticky;top:68px;max-height:calc(100vh - 100px);overflow-y:auto;padding:18px 16px;background:var(--bg1);border:1px solid var(--border);border-radius:14px;box-shadow:0 14px 34px -22px rgba(15,23,42,.2);transition:top .2s,max-height .2s;}
.panel-toc.bar-shifted{top:112px;max-height:calc(100vh - 144px);}
.panel-toc h3{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;}
#toc-nav a{display:block;font-size:12px;color:var(--text2);text-decoration:none;padding:6px 8px;border-radius:6px;margin-bottom:2px;transition:all .15s;cursor:pointer;line-height:1.4;}
#toc-nav a:hover{background:var(--bg2);color:var(--text);}
#toc-nav a.active{background:var(--green-bg);color:var(--green-ink);font-weight:700;}
@media(max-width:1000px){.panel-layout{grid-template-columns:200px 1fr;}}
@media(max-width:860px){.panel-layout{grid-template-columns:1fr;}.panel-toc{display:none;}}

/* ---------- BOUTON RETOUR EN HAUT ---------- */
.btn-top{position:fixed;bottom:28px;right:24px;width:40px;height:40px;border-radius:50%;background:var(--green-ink);color:#fff;border:none;font-size:18px;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .2s,transform .15s;z-index:300;box-shadow:0 4px 14px -4px rgba(15,23,42,.35);display:flex;align-items:center;justify-content:center;}
.btn-top.visible{opacity:1;pointer-events:auto;}
.btn-top:hover{transform:translateY(-2px);}
.access{display:flex;align-items:center;flex-wrap:wrap;gap:9px 12px;background:var(--bg1);border:1px solid var(--border);border-radius:14px;padding:16px 20px;margin-top:36px;}
.access-ico{font-size:20px;line-height:1;color:var(--green-ink);}
.access-ico svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;display:block;}
.access-txt{font-weight:800;font-size:13.5px;color:var(--text);margin-right:4px;}
.access-pill{font-size:12px;font-weight:700;padding:5px 13px;border-radius:50px;border:1px solid var(--border2);white-space:nowrap;}
.access-pill.a{background:var(--cyan-bg);border-color:var(--green-ink);color:var(--green-ink);}
.access-pill.b{background:var(--blue-bg);border-color:var(--blue);color:var(--blue);}
.access-pill.c{background:var(--green-bg);border-color:var(--green-ink);color:var(--green-ink);}
.exec{display:grid;grid-template-columns:repeat(auto-fit,minmax(232px,1fr));gap:1px;background:var(--border);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin:0 0 40px;}
.exec-item{background:var(--bg);padding:20px 22px;}
.exec-k{display:flex;align-items:center;gap:8px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--green-ink);margin-bottom:9px;}
.exec-k svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;}
.exec-v{font-size:13px;color:var(--text2);line-height:1.6;}
.exec-v strong{color:var(--text);font-weight:700;}
.card-badge{font-size:9px;font-weight:700;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;background:var(--teal-bg);border:1px solid var(--teal);color:var(--green-ink);}
.card-badge.amber{background:var(--amber-bg);border-color:var(--amber);color:var(--amber);}
.card-badge.soon{background:var(--bg2);border-color:var(--border2);color:var(--text3);}

/* ---------- GENERIC CARDS ---------- */
.card{background:var(--bg1);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:14px;}
.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px;}
.card-title{font-size:14px;font-weight:700;color:var(--text);}
.card-body{font-size:13px;color:var(--text2);line-height:1.7;}
.card ul{margin-top:8px;padding-left:18px;}
.card ul li{font-size:13px;color:var(--text2);line-height:1.8;margin-bottom:2px;}
.card ul li strong{color:var(--text);font-weight:600;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}

.badge{font-size:10px;font-weight:700;padding:3px 10px;border-radius:20px;white-space:nowrap;}
.badge-teal{background:var(--teal-bg);border:1px solid var(--teal);color:var(--green-ink);}
.badge-blue{background:var(--blue-bg);border:1px solid var(--blue);color:var(--blue);}
.badge-green{background:var(--green-bg);border:1px solid var(--green);color:var(--green-ink);}
.badge-purple{background:var(--purple-bg);border:1px solid var(--purple);color:var(--purple);}
.badge-amber{background:var(--amber-bg);border:1px solid var(--amber);color:var(--amber);}
.badge-orange{background:var(--orange-bg);border:1px solid var(--orange);color:var(--green-ink);}

code{font-family:'JetBrains Mono',monospace;font-size:12px;background:var(--bg3);border:1px solid var(--border2);border-radius:4px;padding:2px 6px;color:var(--amber);}

table{width:100%;border-collapse:collapse;font-size:12px;}
thead tr{background:var(--bg2);}
thead th{padding:10px 14px;text-align:left;font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border);}
tbody tr{border-bottom:1px solid var(--border);}
tbody tr:last-child{border-bottom:none;}
tbody td{padding:10px 14px;color:var(--text2);vertical-align:top;line-height:1.6;}
tbody td:first-child{font-weight:600;color:var(--text);}
.table-wrap{background:var(--bg1);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:16px;}

.summary-box{background:var(--bg1);border:1px solid var(--border);border-radius:14px;padding:26px;margin-bottom:26px;}
.summary-box p{font-size:14px;color:var(--text2);line-height:1.8;}
.summary-box p+p{margin-top:12px;}
.summary-stats{display:flex;gap:16px;margin-top:18px;flex-wrap:wrap;}
.stat{text-align:center;padding:14px 18px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;flex:1;min-width:120px;}
.stat .snum{font-size:24px;font-weight:800;font-family:'JetBrains Mono',monospace;}
.stat .slabel{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-top:3px;}

.info-box{background:var(--blue-bg);border:1px solid rgba(75,85,99,.30);border-radius:8px;padding:13px 16px;font-size:12px;color:var(--text2);line-height:1.6;margin:14px 0;}
.info-box strong{color:var(--blue);}
.teal-box{background:var(--teal-bg);border:1px solid rgba(136,191,82,.35);border-radius:8px;padding:13px 16px;font-size:12px;color:var(--text2);line-height:1.6;margin:14px 0;}
.teal-box strong{color:var(--text);}
.note-box{background:var(--amber-bg);border:1px solid rgba(184,134,11,.30);border-radius:8px;padding:13px 16px;font-size:12px;color:var(--text2);line-height:1.6;margin:14px 0;}
.note-box strong{color:var(--amber);}

.sub-header{font-size:11px;font-weight:700;color:var(--text2);margin-bottom:12px;margin-top:26px;text-transform:uppercase;letter-spacing:.8px;}

/* ---------- ENTITY (qui sommes-nous) ---------- */
.entity{background:var(--bg1);border:1px solid var(--border);border-radius:14px;padding:24px;margin-bottom:16px;}
.entity-head{display:flex;align-items:center;gap:14px;margin-bottom:14px;}
.entity-logo{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:#fff;flex-shrink:0;}
.entity-logo.abax{background:linear-gradient(135deg,#88bf52,#5a7d35);}
.entity-logo.axion{background:linear-gradient(135deg,#8b5cf6,#3b82f6);}
.entity-logo.cs{background:linear-gradient(135deg,#64748b,#0f172a);}
.entity-name{font-size:17px;font-weight:800;}
.entity-role{font-size:12px;color:var(--text3);font-weight:600;margin-top:2px;}

/* ---------- AWARENESS LADDER ---------- */
.ladder{display:flex;flex-direction:column;gap:0;margin:8px 0 24px;}
.rung{display:flex;gap:18px;align-items:stretch;}
.rung-rail{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:44px;}
.rung-dot{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;font-family:'JetBrains Mono',monospace;color:#fff;flex-shrink:0;}
.rung-line{width:2px;flex:1;background:var(--border2);margin:4px 0;}
.rung:last-child .rung-line{display:none;}
.rung-body{flex:1;background:var(--bg1);border:1px solid var(--border);border-radius:12px;padding:18px 20px;margin-bottom:16px;}
.rung-body .rb-stage{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;}
.rung-body .rb-title{font-size:15px;font-weight:800;margin-bottom:8px;}
.rung-body .rb-desc{font-size:13px;color:var(--text2);line-height:1.65;}
.rung-body .rb-desc strong{color:var(--text);}
.rung-body .rb-lever{margin-top:10px;font-size:11px;color:var(--text2);background:var(--bg2);border:1px solid var(--border);border-radius:7px;padding:8px 11px;line-height:1.55;}
.rung-body .rb-lever strong{font-weight:700;}

/* ---------- VOLET LIST ---------- */
.volet{background:var(--bg1);border:1px solid var(--border);border-radius:12px;padding:18px 20px;margin-bottom:12px;display:flex;gap:16px;align-items:flex-start;}
.volet-num{font-size:18px;font-weight:800;font-family:'JetBrains Mono',monospace;color:var(--green-ink);min-width:34px;text-align:center;}
.volet-body{flex:1;}
.volet-title{font-size:14px;font-weight:700;margin-bottom:5px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.volet-desc{font-size:12.5px;color:var(--text2);line-height:1.65;}
.pill-owner{font-size:9px;font-weight:700;padding:2px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;}
.pill-abax{background:var(--teal-bg);border:1px solid var(--teal);color:var(--green-ink);}
.pill-axion{background:var(--purple-bg);border:1px solid var(--purple);color:var(--purple);}
.pill-cs{background:var(--bg2);border:1px solid var(--border2);color:var(--text2);}

/* ---------- CTA ---------- */
.cta{background:linear-gradient(135deg,#0f172a,#1e293b);border-radius:16px;padding:32px;color:#fff;margin-top:8px;}
.cta h3{font-size:20px;font-weight:800;margin-bottom:10px;}
.cta p{font-size:14px;color:#cbd5e1;line-height:1.7;max-width:640px;margin-bottom:18px;}
.cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--teal);color:#04201d;font-weight:700;font-size:13px;padding:11px 20px;border-radius:9px;text-decoration:none;transition:transform .15s,background .15s;}
.cta-btn:hover{transform:translateY(-2px);background:#10cdb8;}

footer{padding:34px 24px;text-align:center;font-size:12px;color:var(--text3);border-top:1px solid var(--border);margin-top:48px;}
footer a{color:var(--green-ink);text-decoration:none;}

@media(max-width:860px){
  .nav{padding:0 18px;}
  .hero{padding:30px 20px;}
  .wrap,.wrap-narrow{padding:26px 18px;}
  .page{grid-template-columns:1fr;}
  .toc{display:none;}
  .content{padding:26px 18px;}
  .hero h1{font-size:23px;}
  .tiles{grid-template-columns:1fr;}
  .grid-2{grid-template-columns:1fr;}
  .summary-stats{flex-direction:column;}
}
