/* ============================================================
   academic.css — components for the access/training inner pages
   Used by: academic.html, commercial.html, general-training.html
   Load after: base.css → menu.css → subpage.css
   (foundations, header and .pagehead/.cta/.btn live in those files)
   ============================================================ */

  /* ---- pagehead jump links ---- */
  .jump{display:flex;gap:12px;margin-top:38px;flex-wrap:wrap}
  .jump a{font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:#cfe6db;border:1px solid rgba(255,255,255,.2);padding:10px 16px;transition:background .2s,border-color .2s}
  .jump a:hover{background:rgba(255,255,255,.08);border-color:#8fbcaa}

  /* ---- content blocks ---- */
  .block{padding:96px 0;border-bottom:1px solid var(--line)}
  .block:nth-of-type(even){background:var(--white)}
  .sec-head{margin-bottom:44px}
  .sec-head .index{font-family:var(--mono);font-size:13px;color:var(--steel);letter-spacing:.16em;display:block;margin-bottom:16px}
  .sec-head h2{font-size:clamp(26px,3vw,40px);font-weight:800;letter-spacing:-.01em;line-height:1.08;max-width:22ch}
  .prose p{color:var(--ink-soft);font-size:16px;line-height:1.72;margin-top:16px;max-width:74ch}
  .prose p:first-child{margin-top:0}
  .prose a{color:var(--steel);font-weight:600}
  .prose a:hover{color:var(--steel-deep)}
  .bullets{list-style:none;margin-top:8px}
  .bullets li{position:relative;padding-left:22px;margin-top:12px;color:var(--ink-soft);font-size:16px;line-height:1.7;max-width:74ch}
  .bullets li::before{content:"";position:absolute;left:0;top:10px;width:7px;height:7px;background:var(--steel)}

  /* ---- note / callout ---- */
  .note{margin-top:28px;border-left:3px solid var(--steel);background:var(--concrete-2);padding:22px 26px;max-width:74ch}
  .note .nt{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--steel);display:block;margin-bottom:8px}
  .note p{color:var(--ink-soft);font-size:15px;line-height:1.65}
  .note a{color:var(--steel);font-weight:600}

  /* ---- mode cards ---- */
  .modes{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:8px}
  .mode{border:1px solid var(--line);background:var(--white);padding:40px 36px;position:relative}
  .mode .pill{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--steel);padding:5px 11px;margin-bottom:18px}
  .mode .pill.alt{background:var(--steel-tint)}
  .mode h3{font-size:22px;font-weight:800;letter-spacing:-.01em}
  .mode p{color:var(--ink-soft);font-size:15px;line-height:1.65;margin-top:12px}
  @media(max-width:820px){.modes{grid-template-columns:1fr}}

  /* ---- numbered steps ---- */
  .steps{counter-reset:step;margin-top:14px}
  .step{position:relative;padding:22px 0 22px 64px;border-top:1px solid var(--line)}
  .step:first-child{border-top:0}
  .step::before{counter-increment:step;content:counter(step,decimal-leading-zero);position:absolute;left:0;top:22px;font-family:var(--mono);font-size:13px;font-weight:600;color:var(--steel);border:1px solid var(--line);width:40px;height:40px;display:grid;place-items:center}
  .step h4{font-size:16px;font-weight:700;letter-spacing:-.01em}
  .step p{color:var(--ink-soft);font-size:15px;line-height:1.65;margin-top:8px;max-width:70ch}
  .step a{color:var(--steel);font-weight:600}

  /* ---- price table ---- */
  .ptitle{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--steel);margin:40px 0 14px}
  .ptable{width:100%;border-collapse:collapse;border:1px solid var(--line);background:var(--white);font-size:15px}
  .ptable th,.ptable td{text-align:left;padding:16px 20px;border-bottom:1px solid var(--line)}
  .ptable thead th{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);background:var(--concrete-2);font-weight:600}
  .ptable td.num,.ptable th.num{text-align:right;font-family:var(--mono);white-space:nowrap}
  .ptable tbody tr:last-child td{border-bottom:0}
  .ptable tbody tr:hover{background:var(--concrete)}
  .ptable .name{font-weight:600;color:var(--ink)}
  .pnote{font-size:13px;color:var(--ink-soft);margin-top:12px;line-height:1.6}
  @media(max-width:680px){.ptable th,.ptable td{padding:12px 14px}.ptable{font-size:13.5px}}

  @media(max-width:600px){.block{padding:64px 0}}
