/* ============================================================
   IIIBC — Non-Profit AI Training Web Kit
   Shared stylesheet · design system: design/guides.md
   Used by ../non-profit-training.html (index) and module-*.html
   ============================================================ */

/* ── 1. DESIGN TOKENS ─────────────────────────────────────── */
:root{
  --navy:#0F172A; --blue:#1D4ED8; --teal:#0EA5E9; --gold:#F59E0B;
  --ink:#1E293B; --slate:#64748B; --mist:#94A3B8; --feather:#E2E8F0;
  --cloud:#F8FAFC; --white:#FFFFFF;
  --success:#10B981; --risk:#EF4444; --caution:#F59E0B; --steel:#3B82F6;

  --f-display:'Sora',-apple-system,'Segoe UI',Helvetica,Arial,sans-serif;
  --f-body:'Inter',-apple-system,'Segoe UI',Helvetica,Arial,sans-serif;
  --f-mono:'IBM Plex Mono','Consolas','Courier New',monospace;

  --s1:4px; --s2:8px; --s3:16px; --s4:24px; --s5:32px; --s6:48px; --s7:64px; --s8:96px;
  --r-sm:4px; --r-md:6px; --r-lg:12px;
  --shadow-sm:0 2px 8px rgba(15,23,42,.06);
  --shadow-md:0 4px 14px rgba(15,23,42,.10);
  --max:1180px; --read:860px; --nav-h:64px;
}

/* ── 2. RESET & BASE ──────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:var(--f-body);font-size:16px;line-height:1.7;color:var(--ink);background:var(--white);-webkit-font-smoothing:antialiased;}
img,svg{display:block;max-width:100%;}
a{color:var(--blue);text-decoration:none;}
a:hover{text-decoration:underline;}
ul,ol{list-style:none;}
.mono{font-family:var(--f-mono);}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 var(--s4);}
.skip-link{position:absolute;top:-100%;left:var(--s3);background:var(--blue);color:#fff;padding:var(--s2) var(--s3);border-radius:var(--r-sm);z-index:1000;transition:top .2s;}
.skip-link:focus{top:var(--s2);}

/* ── 3. TOP NAV ───────────────────────────────────────────── */
.nav{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--feather);}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h);}
.nav__logo{display:flex;align-items:center;gap:10px;}
.nav__links{display:flex;align-items:center;gap:var(--s4);}
.nav__links a{font-size:14px;font-weight:500;color:var(--slate);}
.nav__links a:hover{color:var(--blue);text-decoration:none;}

/* ── 4. BUTTONS ───────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:12px 22px;border-radius:var(--r-sm);font-family:var(--f-body);font-weight:600;font-size:15px;cursor:pointer;border:none;transition:background .15s,color .15s,border-color .15s;}
.btn--primary{background:var(--blue);color:#fff;}
.btn--primary:hover{background:#1740b0;text-decoration:none;}
.btn--white{background:#fff;color:var(--navy);}
.btn--white:hover{background:var(--cloud);text-decoration:none;}
.btn--ghost{background:transparent;color:var(--navy);border:1px solid var(--feather);}
.btn--ghost:hover{background:var(--cloud);text-decoration:none;}
.btn--ghost-white{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4);}
.btn--ghost-white:hover{background:rgba(255,255,255,.1);text-decoration:none;}

/* ── 5. HERO / PAGE HEADER (navy) ─────────────────────────── */
.hero{background:var(--navy);color:#fff;padding:var(--s8) 0;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px);background-size:28px 28px;pointer-events:none;}
.hero>*{position:relative;z-index:1;}
.hero__eyebrow{font-family:var(--f-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);margin-bottom:var(--s4);}
.hero h1{font-family:var(--f-display);font-weight:800;font-size:clamp(30px,4.4vw,48px);line-height:1.1;max-width:18ch;margin-bottom:var(--s4);}
.hero__sub{font-size:18px;color:#cbd5e1;max-width:62ch;margin-bottom:var(--s5);}
.hero__actions{display:flex;flex-wrap:wrap;gap:var(--s3);}
.hero__teal-rule{height:2px;background:var(--teal);width:120px;margin:var(--s5) 0 0;opacity:.7;}

/* page-header variant (module pages) */
.page-header{background:var(--navy);color:#fff;padding:var(--s7) 0 var(--s6);position:relative;overflow:hidden;}
.page-header::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px);background-size:26px 26px;pointer-events:none;}
.page-header>*{position:relative;z-index:1;}
.page-header__eyebrow{font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:var(--s3);}
.page-header h1{font-family:var(--f-display);font-weight:800;font-size:clamp(26px,3.6vw,40px);line-height:1.12;max-width:24ch;margin-bottom:var(--s3);}
.page-header__purpose{font-size:18px;font-style:italic;color:#cbd5e1;max-width:64ch;border-left:3px solid var(--teal);padding-left:var(--s3);}
.page-header__badges{display:flex;flex-wrap:wrap;gap:var(--s2);margin-top:var(--s4);}

/* ── 6. BADGES / PILLS ────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-body);font-size:12px;font-weight:600;letter-spacing:.02em;padding:4px 11px;border-radius:99px;white-space:nowrap;}
.badge--level{background:rgba(14,165,233,.16);color:#7dd3fc;}
.badge--section{background:rgba(255,255,255,.12);color:#e2e8f0;}
.badge--audience{background:rgba(245,158,11,.18);color:#fcd34d;}
/* light-context badges (on white) */
.tag{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:99px;}
.tag--blue{background:rgba(29,78,216,.1);color:#1740b0;}
.tag--teal{background:rgba(14,165,233,.12);color:#0369a1;}
.tag--gold{background:rgba(245,158,11,.14);color:#b45309;}
.tag--slate{background:var(--cloud);color:var(--slate);border:1px solid var(--feather);}

/* ── 7. SECTION SCAFFOLD ──────────────────────────────────── */
.section{padding:var(--s7) 0;}
.section--cloud{background:var(--cloud);}
.section--navy{background:var(--navy);color:#fff;}
.section__eyebrow{font-family:var(--f-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:var(--s2);}
.section__title{font-family:var(--f-display);font-weight:700;font-size:clamp(22px,2.6vw,30px);color:var(--navy);margin-bottom:var(--s3);}
.section--navy .section__title{color:#fff;}
.section__lead{font-size:18px;color:var(--slate);max-width:66ch;margin-bottom:var(--s5);}

/* ── 8. 4D SPINE (index) ──────────────────────────────────── */
.fourd{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s4);}
.fourd__card{background:#fff;border:1px solid var(--feather);border-top:4px solid var(--teal);border-radius:var(--r-md);padding:var(--s4);box-shadow:var(--shadow-sm);}
.fourd__card h3{font-family:var(--f-display);font-weight:700;font-size:18px;color:var(--navy);margin-bottom:6px;}
.fourd__card p{font-size:14px;color:var(--slate);line-height:1.6;}

/* ── 9. MODULE GRID (index) ───────────────────────────────── */
.module-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s4);}
.module-card{display:flex;flex-direction:column;gap:var(--s2);background:#fff;border:1px solid var(--feather);border-left:4px solid var(--blue);border-radius:var(--r-md);padding:var(--s4) var(--s5);box-shadow:var(--shadow-sm);transition:box-shadow .15s,transform .15s;}
.module-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none;}
.module-card__num{font-family:var(--f-mono);font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--blue);}
.module-card__title{font-family:var(--f-display);font-weight:700;font-size:19px;color:var(--navy);line-height:1.25;}
.module-card__desc{font-size:14px;color:var(--slate);line-height:1.55;}
.module-card__meta{display:flex;flex-wrap:wrap;gap:var(--s2);margin-top:auto;padding-top:var(--s2);}
.module-card__cta{font-size:14px;font-weight:600;color:var(--blue);margin-top:var(--s2);}

/* priority highlight (Module 7 / mandatory) */
.module-card--priority{border-left-color:var(--gold);}
.module-card--foundation{border-left-color:var(--teal);}

/* ── 10. LEARNING-PATH & DATA TABLES ──────────────────────── */
.data-table{width:100%;border-collapse:collapse;font-size:14.5px;margin:var(--s3) 0;}
.data-table thead th{background:var(--navy);color:#fff;text-align:left;padding:11px 15px;font-family:var(--f-body);font-weight:600;font-size:13px;letter-spacing:.02em;vertical-align:top;}
.data-table thead th.accent{background:rgba(14,165,233,.2);color:#bae6fd;}
.data-table tbody tr{border-bottom:1px solid var(--feather);}
.data-table tbody tr:nth-child(even){background:var(--cloud);}
.data-table tbody td{padding:11px 15px;vertical-align:top;line-height:1.55;}
.data-table td.lead{font-weight:600;color:var(--navy);}
.data-table .num{font-family:var(--f-mono);text-align:right;}

/* ── 11. MODULE CONTENT (generic markdown→html styling) ───── */
.module-layout{display:grid;grid-template-columns:240px minmax(0,1fr);gap:var(--s6);align-items:start;padding:var(--s7) 0;}
.toc{position:sticky;top:calc(var(--nav-h) + 16px);align-self:start;}
.toc__title{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);margin-bottom:var(--s2);}
.toc ul{display:flex;flex-direction:column;gap:2px;}
.toc a{display:block;font-size:13.5px;color:var(--slate);padding:5px 10px;border-left:2px solid var(--feather);line-height:1.4;}
.toc a:hover{color:var(--blue);border-left-color:var(--blue);text-decoration:none;background:var(--cloud);}

.module-content{max-width:var(--read);}
.module-content>section{margin-bottom:var(--s7);scroll-margin-top:calc(var(--nav-h) + 16px);}
.module-content h2{font-family:var(--f-display);font-weight:700;font-size:clamp(20px,2.2vw,26px);color:var(--navy);line-height:1.2;margin:0 0 var(--s4);padding-left:12px;border-left:4px solid var(--blue);}
.module-content h3{font-family:var(--f-body);font-weight:600;font-size:19px;color:var(--navy);margin:var(--s5) 0 var(--s2);}
.module-content h4{font-family:var(--f-body);font-weight:600;font-size:16px;color:var(--ink);margin:var(--s4) 0 var(--s2);}
.module-content p{margin:0 0 var(--s3);}
.module-content strong{color:var(--navy);font-weight:600;}
.module-content em{color:var(--navy);}
.module-content ul,.module-content ol{margin:0 0 var(--s3) 0;padding-left:0;}
.module-content ul li,.module-content ol li{position:relative;padding-left:1.5em;margin-bottom:var(--s2);line-height:1.6;}
.module-content ul li::before{content:'';position:absolute;left:2px;top:.62em;width:7px;height:7px;background:var(--teal);border-radius:2px;}
.module-content ol{counter-reset:li;}
.module-content ol li{counter-increment:li;}
.module-content ol li::before{content:counter(li);position:absolute;left:0;top:0;font-family:var(--f-mono);font-size:12px;font-weight:600;color:var(--blue);background:rgba(29,78,216,.08);width:1.3em;height:1.3em;display:flex;align-items:center;justify-content:center;border-radius:4px;margin-top:2px;}
.module-content a{color:var(--blue);text-decoration:underline;text-underline-offset:2px;}
.module-content hr{border:none;border-top:1px solid var(--feather);margin:var(--s5) 0;}

/* tables inside content auto-styled */
.module-content table{width:100%;border-collapse:collapse;font-size:14px;margin:var(--s3) 0 var(--s4);}
.module-content thead th{background:var(--navy);color:#fff;text-align:left;padding:10px 13px;font-weight:600;font-size:13px;vertical-align:top;}
.module-content tbody tr{border-bottom:1px solid var(--feather);}
.module-content tbody tr:nth-child(even){background:var(--cloud);}
.module-content tbody td{padding:10px 13px;vertical-align:top;line-height:1.5;}
.module-content tbody td:first-child{font-weight:500;color:var(--navy);}

/* code / pre (ASCII diagrams, prompts, templates) */
.module-content code{font-family:var(--f-mono);font-size:.88em;background:var(--cloud);border:1px solid var(--feather);border-radius:3px;padding:1px 5px;color:#0f3a8f;}
.module-content pre{background:var(--navy);color:#e2e8f0;border-radius:var(--r-md);padding:var(--s4);overflow-x:auto;margin:var(--s3) 0 var(--s4);font-family:var(--f-mono);font-size:13px;line-height:1.5;}
.module-content pre code{background:none;border:none;padding:0;color:inherit;font-size:13px;}

/* ── 12. CALLOUTS (SIGNAL / NOISE / PRACTITIONER / SAFEGUARD) ─ */
.callout{border-left:4px solid var(--blue);background:var(--cloud);border-radius:0 var(--r-sm) var(--r-sm) 0;padding:var(--s3) var(--s4);margin:var(--s4) 0;}
.callout__label{display:block;font-family:var(--f-mono);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px;}
.callout p{margin:0;font-size:15px;line-height:1.6;}
.callout p+p{margin-top:var(--s2);}
.callout--signal{border-left-color:var(--teal);background:rgba(14,165,233,.07);}
.callout--signal .callout__label{color:#0369a1;}
.callout--noise{border-left-color:var(--risk);background:rgba(239,68,68,.06);}
.callout--noise .callout__label{color:#b91c1c;}
.callout--practitioner{border-left-color:var(--blue);background:rgba(29,78,216,.05);}
.callout--practitioner .callout__label{color:#1740b0;}
.callout--safeguard{border-left-color:var(--gold);background:rgba(245,158,11,.09);}
.callout--safeguard .callout__label{color:#b45309;}
.callout--note{border-left-color:var(--slate);}
.callout--note .callout__label{color:var(--slate);}

/* generic blockquote fallback */
.module-content blockquote{border-left:4px solid var(--gold);background:var(--cloud);padding:var(--s3) var(--s4);margin:var(--s4) 0;border-radius:0 var(--r-sm) var(--r-sm) 0;font-style:italic;color:var(--navy);}

/* ── 13. AT-A-GLANCE CARD ─────────────────────────────────── */
.glance{background:#fff;border:1px solid var(--feather);border-radius:var(--r-md);box-shadow:var(--shadow-sm);overflow:hidden;margin:0 0 var(--s5);}
.glance__head{background:var(--cloud);border-bottom:1px solid var(--feather);padding:12px 18px;font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);}
.glance dl{display:grid;grid-template-columns:auto 1fr;}
.glance dt{font-weight:600;color:var(--navy);font-size:13.5px;padding:9px 18px;border-bottom:1px solid var(--feather);background:var(--cloud);}
.glance dd{font-size:13.5px;color:var(--ink);padding:9px 18px;border-bottom:1px solid var(--feather);}

/* ── 14. PROGRESS / PREV-NEXT ─────────────────────────────── */
.module-foot-nav{display:flex;justify-content:space-between;gap:var(--s3);flex-wrap:wrap;border-top:1px solid var(--feather);padding-top:var(--s5);margin-top:var(--s6);}
.module-foot-nav a{display:flex;flex-direction:column;gap:2px;max-width:46%;}
.module-foot-nav .dir{font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);}
.module-foot-nav .ttl{font-weight:600;color:var(--navy);}
.module-foot-nav a.next{text-align:right;margin-left:auto;}

/* ── 15. FOOTER ───────────────────────────────────────────── */
.footer{background:var(--navy);color:#cbd5e1;padding:var(--s7) 0 var(--s5);margin-top:var(--s8);}
.footer__top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--s5);align-items:flex-start;}
.footer__tag{font-size:14px;max-width:42ch;margin-top:var(--s3);}
.footer__tag strong{color:#fff;}
.footer__pillars{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;color:var(--mist);margin-top:var(--s3);}
.footer__links{display:flex;flex-direction:column;gap:8px;}
.footer__links a{font-size:14px;color:#cbd5e1;}
.footer__bottom{border-top:1px solid #1e2b46;margin-top:var(--s5);padding-top:var(--s4);display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--s3);font-size:13px;color:var(--mist);}

/* ── 16. RESPONSIVE ───────────────────────────────────────── */
@media (max-width:900px){
  .module-layout{grid-template-columns:1fr;gap:var(--s4);}
  .toc{position:static;display:none;}
  .fourd{grid-template-columns:1fr 1fr;}
  .module-grid{grid-template-columns:1fr;}
  .nav__links{display:none;}
}
@media (max-width:520px){
  .fourd{grid-template-columns:1fr;}
  .glance dl{grid-template-columns:1fr;}
  .glance dt{border-bottom:none;padding-bottom:2px;}
}

/* ── 17. PRINT ────────────────────────────────────────────── */
@media print{
  .nav,.toc,.module-foot-nav,.footer,.hero__actions{display:none!important;}
  .module-layout{grid-template-columns:1fr;display:block;}
  .page-header,.hero{background:#fff;color:var(--navy);}
  .page-header__eyebrow,.hero__eyebrow{color:var(--blue);}
  .page-header h1,.hero h1{color:var(--navy);}
  .page-header__purpose,.hero__sub{color:var(--slate);}
  .module-content pre{background:#fff;color:var(--ink);border:1px solid var(--feather);}
  body{font-size:11pt;}
  a{color:var(--ink);}
}
