/* ===========================================================
   Furb Foundation · Training site design system
   =========================================================== */

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}

:root{
  --furb:#00D63B;
  --furb-dark:#00A82E;
  --furb-soft:#E8FBEE;
  --ink:#0A0A0A;
  --ink-soft:#3A3A3A;
  --muted:#8A8A8A;
  --line:#E5E5E5;
  --line-soft:#EFEFEF;
  --soft:#F6F6F4;
  --bg:#FFFFFF;
  --shadow-sm:0 1px 2px rgba(10,10,10,.04);
  --shadow-md:0 8px 30px rgba(10,10,10,.06);
  --radius:14px;
  --radius-sm:8px;
  --sidebar-w:280px;
  --topbar-h:60px;
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SF Mono,Menlo,Consolas,monospace;
}

body{
  font-family:var(--font);
  font-size:15px;
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

a{color:inherit;text-decoration:none}
button{font:inherit}
img{max-width:100%;display:block}

/* ---------- TOP BAR ---------- */
.topbar{
  position:fixed;top:0;left:0;right:0;height:var(--topbar-h);
  background:#fff;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;z-index:50;
}
.topbar__left{display:flex;align-items:center;gap:24px;min-width:0}
.topbar__logo{
  display:flex;align-items:baseline;gap:0;
  font-family:var(--font);font-weight:800;letter-spacing:-.03em;font-size:21px;color:var(--ink);
}
.topbar__logo span{color:var(--furb)}
.topbar__crumb{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:var(--muted);
  min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.topbar__crumb a{color:var(--muted);transition:color .15s}
.topbar__crumb a:hover{color:var(--ink)}
.topbar__crumb .sep{color:var(--line)}
.topbar__crumb .cur{color:var(--ink);font-weight:500}

.topbar__right{display:flex;align-items:center;gap:16px}
.topbar__progress{
  display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.06em;
}
.topbar__progress b{color:var(--ink);font-weight:600;font-size:12px}
.topbar__bar{
  width:140px;height:6px;background:var(--line-soft);border-radius:3px;overflow:hidden;
}
.topbar__bar i{display:block;height:100%;background:var(--furb);width:0;transition:width .4s ease}
.topbar__back{
  font-size:13px;color:var(--ink-soft);padding:6px 12px;border:1px solid var(--line);border-radius:8px;
  transition:border-color .15s,color .15s;
}
.topbar__back:hover{border-color:var(--ink);color:var(--ink)}

.menu-toggle{
  display:none;background:none;border:1px solid var(--line);border-radius:8px;
  width:38px;height:38px;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);
}

/* ---------- SIDEBAR ---------- */
.sidebar{
  position:fixed;top:var(--topbar-h);left:0;bottom:0;width:var(--sidebar-w);
  background:#fff;border-right:1px solid var(--line);
  display:flex;flex-direction:column;overflow-y:auto;z-index:40;
}
.sidebar__head{
  padding:24px 22px 20px;border-bottom:1px solid var(--line-soft);
}
.sidebar__eyebrow{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--furb-dark);font-weight:600;display:block;margin-bottom:8px;
}
.sidebar__title{
  font-family:var(--font);font-weight:800;font-size:18px;letter-spacing:-.02em;
  margin:0 0 16px;color:var(--ink);line-height:1.25;
}
.sidebar__progress-label{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);margin-bottom:8px;
}
.sidebar__progress-label b{color:var(--ink);font-weight:600}
.sidebar__bar{
  width:100%;height:6px;background:var(--line-soft);border-radius:3px;overflow:hidden;
}
.sidebar__bar i{
  display:block;height:100%;background:var(--furb);width:0;transition:width .4s ease;
  border-radius:3px;
}

.sidebar__list{
  list-style:none;margin:0;padding:14px 0;flex:1;
}
.sidebar__list li{margin:0}
.sidebar__item{
  display:flex;align-items:flex-start;gap:12px;
  padding:11px 22px;
  color:var(--ink-soft);font-size:14px;line-height:1.35;
  transition:background .15s,color .15s;
  border-left:3px solid transparent;
  cursor:pointer;
}
.sidebar__item:hover{background:var(--soft);color:var(--ink)}
.sidebar__item.active{
  background:var(--furb-soft);color:var(--ink);font-weight:600;
  border-left-color:var(--furb);
}
.sidebar__item .num{
  font-family:var(--mono);font-size:11px;color:var(--muted);
  min-width:18px;padding-top:2px;font-weight:500;
}
.sidebar__item.active .num{color:var(--furb-dark);font-weight:600}
.sidebar__item .label{flex:1;min-width:0}
.sidebar__item .dur{
  display:block;font-family:var(--mono);font-size:10px;color:var(--muted);
  letter-spacing:.06em;margin-top:2px;font-weight:400;
}
.sidebar__item .ico{
  font-family:var(--mono);font-size:14px;color:var(--muted);min-width:14px;text-align:center;
  padding-top:1px;
}
.sidebar__item.is-done .ico{color:var(--furb-dark)}
.sidebar__item.is-active .ico{color:var(--furb)}

.sidebar__foot{
  padding:18px 22px 24px;border-top:1px solid var(--line-soft);
  font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:.06em;line-height:1.6;
}
.sidebar__foot a{color:var(--ink);font-weight:600}
.sidebar__foot a:hover{color:var(--furb-dark)}

/* ---------- MAIN ---------- */
.main{
  margin-left:var(--sidebar-w);margin-top:var(--topbar-h);
  min-height:calc(100vh - var(--topbar-h));
  background:var(--bg);
}
.main__inner{
  max-width:780px;margin:0 auto;padding:48px 56px 24px;
}

/* ---------- HERO ---------- */
.hero{
  padding-bottom:36px;border-bottom:1px solid var(--line-soft);margin-bottom:40px;
}
.hero__eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--furb-dark);font-weight:600;display:inline-flex;align-items:center;gap:10px;
  margin-bottom:18px;
}
.hero__eyebrow::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--furb);
}
.hero h1{
  font-family:var(--font);font-weight:800;font-size:clamp(32px,4vw,46px);
  letter-spacing:-.035em;line-height:1.05;margin:0 0 18px;color:var(--ink);
}
.hero h1 em{font-style:normal;font-weight:200;color:var(--ink-soft)}
.hero__lead{
  font-size:18px;line-height:1.55;color:var(--ink-soft);margin:0 0 22px;
  font-weight:300;letter-spacing:-.005em;
}
.hero__meta{
  display:flex;flex-wrap:wrap;gap:10px;
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);
}
.hero__meta span{
  background:var(--soft);border:1px solid var(--line-soft);padding:6px 12px;border-radius:6px;
  display:inline-flex;align-items:center;gap:8px;
}
.hero__meta b{color:var(--ink);font-weight:600}

/* ---------- CONTENT BLOCKS ---------- */
.content h2{
  font-family:var(--font);font-weight:700;font-size:26px;letter-spacing:-.025em;
  margin:48px 0 16px;color:var(--ink);line-height:1.2;
}
.content h2:first-child{margin-top:0}
.content h3{
  font-family:var(--font);font-weight:600;font-size:18px;letter-spacing:-.015em;
  margin:32px 0 10px;color:var(--ink);
}
.content p{
  font-size:15.5px;line-height:1.7;color:var(--ink-soft);margin:0 0 16px;
}
.content strong{color:var(--ink);font-weight:600}
.content ul,.content ol{margin:0 0 18px;padding-left:22px}
.content li{font-size:15.5px;line-height:1.7;color:var(--ink-soft);margin-bottom:6px}
.content li strong{color:var(--ink)}
.content a{color:var(--furb-dark);border-bottom:1px solid var(--furb-soft);transition:border-color .15s}
.content a:hover{border-color:var(--furb-dark)}

.section-eyebrow{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin:48px 0 6px;display:block;
}
.section-eyebrow + h2{margin-top:0}

/* ---------- KEY POINT CARDS ---------- */
.cards{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:24px 0 28px;
}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 22px;transition:border-color .15s;
}
.card:hover{border-color:var(--ink)}
.card__ico{
  width:34px;height:34px;border-radius:9px;background:var(--furb-soft);color:var(--furb-dark);
  display:flex;align-items:center;justify-content:center;margin-bottom:12px;
}
.card h4{
  font-family:var(--font);font-weight:700;font-size:15.5px;letter-spacing:-.015em;
  margin:0 0 6px;color:var(--ink);
}
.card p{font-size:13.5px;line-height:1.55;color:var(--ink-soft);margin:0}

/* ---------- RETENIR BOX ---------- */
.retenir{
  background:var(--furb-soft);border:1px solid #B8EFC6;border-radius:var(--radius);
  padding:24px 28px;margin:36px 0 24px;position:relative;
}
.retenir__eyebrow{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--furb-dark);font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:8px;
}
.retenir__eyebrow::before{
  content:"";width:8px;height:8px;border-radius:50%;background:var(--furb-dark);
}
.retenir h3{
  font-family:var(--font);font-weight:700;font-size:18px;margin:0 0 12px;color:var(--ink);letter-spacing:-.015em;
}
.retenir ul{list-style:none;padding:0;margin:0}
.retenir ul li{
  font-size:14.5px;line-height:1.55;color:var(--ink);margin-bottom:8px;
  padding-left:20px;position:relative;
}
.retenir ul li::before{
  content:"✓";position:absolute;left:0;top:0;color:var(--furb-dark);font-weight:700;font-size:13px;
}
.retenir ul li:last-child{margin-bottom:0}

/* ---------- INFO CALLOUT (neutre) ---------- */
.callout{
  background:var(--soft);border-left:3px solid var(--ink);
  padding:18px 22px;margin:22px 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0;
}
.callout__label{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin-bottom:6px;display:block;
}
.callout p{font-size:14.5px;margin:0;line-height:1.6;color:var(--ink-soft)}
.callout p strong{color:var(--ink)}

/* ---------- DATA TABLES ---------- */
.data{
  width:100%;border-collapse:collapse;margin:22px 0;font-size:14px;
}
.data th,.data td{
  text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);
  vertical-align:top;
}
.data th{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);font-weight:600;background:var(--soft);
}
.data td{color:var(--ink-soft);line-height:1.5}
.data td strong{color:var(--ink)}
.data tr:hover td{background:var(--soft)}

/* ---------- TIMELINE (lifecycle) ---------- */
.timeline{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:24px 0 32px;
}
.timeline__step{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 14px;position:relative;
}
.timeline__num{
  font-family:var(--mono);font-size:10.5px;color:var(--furb-dark);font-weight:600;
  letter-spacing:.08em;margin-bottom:6px;
}
.timeline__step h4{
  font-family:var(--font);font-weight:700;font-size:14px;margin:0 0 4px;color:var(--ink);
}
.timeline__step p{font-size:12.5px;line-height:1.45;color:var(--ink-soft);margin:0}

/* ---------- BOTTOM NAV ---------- */
.botnav{
  margin-top:64px;padding:28px 0 8px;border-top:1px solid var(--line-soft);
  display:flex;justify-content:space-between;gap:14px;align-items:stretch;
}
.botnav__btn{
  flex:1;max-width:340px;
  display:flex;flex-direction:column;gap:4px;
  padding:18px 22px;border:1px solid var(--line);border-radius:var(--radius);
  transition:border-color .15s,transform .15s,background .15s;
  cursor:pointer;background:#fff;color:inherit;text-align:left;
}
.botnav__btn:hover{border-color:var(--ink);transform:translateY(-1px)}
.botnav__btn--next{background:var(--ink);color:#fff;border-color:var(--ink);text-align:right}
.botnav__btn--next:hover{background:#000;border-color:#000;transform:translateY(-1px)}
.botnav__btn .dir{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);font-weight:600;display:flex;align-items:center;gap:6px;
}
.botnav__btn--next .dir{color:rgba(255,255,255,.6);justify-content:flex-end}
.botnav__btn .ttl{
  font-family:var(--font);font-weight:700;font-size:15px;letter-spacing:-.015em;color:var(--ink);
}
.botnav__btn--next .ttl{color:#fff}
.botnav__btn--disabled{opacity:.4;pointer-events:none}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;border-radius:10px;font-weight:600;font-size:14.5px;
  border:1px solid var(--ink);background:var(--ink);color:#fff;cursor:pointer;
  transition:transform .15s,background .15s,border-color .15s;text-decoration:none;
}
.btn:hover{background:#000;transform:translateY(-1px)}
.btn--green{background:var(--furb);border-color:var(--furb);color:var(--ink)}
.btn--green:hover{background:var(--furb-dark);border-color:var(--furb-dark);color:#fff}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--soft);transform:none}
.btn--lg{padding:16px 30px;font-size:15.5px}

/* ===========================================================
   INDEX (landing)
   =========================================================== */
.landing-hero{
  padding:60px 0 50px;border-bottom:1px solid var(--line-soft);margin-bottom:48px;
}
.landing-hero h1{
  font-family:var(--font);font-weight:800;font-size:clamp(40px,5.5vw,64px);
  letter-spacing:-.04em;line-height:1.02;margin:18px 0 22px;
}
.landing-hero h1 em{font-style:normal;font-weight:200;color:var(--ink-soft);display:block}
.landing-hero h1 .dot{color:var(--furb)}
.landing-hero__lead{
  font-size:19px;line-height:1.55;color:var(--ink-soft);max-width:620px;margin:0 0 28px;font-weight:300;
}
.landing-hero__facts{
  display:flex;flex-wrap:wrap;gap:12px;margin:28px 0 32px;
}
.landing-hero__fact{
  background:var(--soft);border:1px solid var(--line-soft);padding:14px 20px;border-radius:10px;
  display:flex;flex-direction:column;gap:2px;min-width:140px;
}
.landing-hero__fact .v{font-family:var(--font);font-weight:700;font-size:22px;color:var(--ink);letter-spacing:-.02em}
.landing-hero__fact .v em{font-style:normal;color:var(--furb-dark)}
.landing-hero__fact .l{font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}

.modules-grid{display:grid;grid-template-columns:1fr;gap:12px;margin:0 0 40px}
.module-card{
  display:grid;grid-template-columns:48px 1fr auto;gap:18px;align-items:center;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 22px;transition:border-color .15s,transform .15s;
}
.module-card:hover{border-color:var(--ink);transform:translateY(-1px)}
.module-card__num{
  font-family:var(--mono);font-weight:600;font-size:14px;color:var(--muted);
  width:36px;height:36px;background:var(--soft);border-radius:9px;
  display:flex;align-items:center;justify-content:center;letter-spacing:.04em;
}
.module-card.is-done .module-card__num{background:var(--furb-soft);color:var(--furb-dark)}
.module-card__body h3{
  font-family:var(--font);font-weight:700;font-size:16px;letter-spacing:-.015em;
  margin:0 0 3px;color:var(--ink);
}
.module-card__body p{font-size:13.5px;line-height:1.45;color:var(--ink-soft);margin:0}
.module-card__meta{
  display:flex;flex-direction:column;align-items:flex-end;gap:4px;
  font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:.06em;
}
.module-card__meta .status{
  color:var(--furb-dark);font-weight:600;font-size:11px;
}
.module-card--exam{
  background:var(--ink);color:#fff;border-color:var(--ink);
}
.module-card--exam:hover{background:#000;border-color:#000}
.module-card--exam .module-card__num{background:rgba(255,255,255,.08);color:var(--furb)}
.module-card--exam h3{color:#fff}
.module-card--exam p{color:rgba(255,255,255,.65)}
.module-card--exam .module-card__meta{color:rgba(255,255,255,.5)}

.cta-block{
  background:var(--soft);border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:36px 36px;display:flex;justify-content:space-between;align-items:center;gap:20px;
  margin:0 0 48px;flex-wrap:wrap;
}
.cta-block__txt h3{font-family:var(--font);font-weight:700;font-size:22px;letter-spacing:-.02em;margin:0 0 6px}
.cta-block__txt p{font-size:14px;color:var(--ink-soft);margin:0}

/* ===========================================================
   QCM
   =========================================================== */
.qcm{padding-bottom:80px}
.qcm__intro{
  background:var(--soft);border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:24px 28px;margin-bottom:32px;
}
.qcm__intro h2{margin-top:0;font-size:20px}
.qcm__intro p{margin:0;font-size:14.5px}
.question{
  border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;
  margin-bottom:14px;background:#fff;
}
.question__head{
  display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;
}
.question__num{
  font-family:var(--mono);font-size:11px;color:var(--furb-dark);font-weight:600;
  letter-spacing:.08em;background:var(--furb-soft);padding:4px 9px;border-radius:6px;
  flex-shrink:0;
}
.question__q{
  font-family:var(--font);font-weight:600;font-size:15.5px;letter-spacing:-.01em;
  color:var(--ink);line-height:1.45;margin:0;
}
.question__choices{display:flex;flex-direction:column;gap:8px;margin:0;padding:0;list-style:none}
.choice{
  display:flex;align-items:flex-start;gap:11px;padding:12px 16px;
  border:1px solid var(--line);border-radius:9px;cursor:pointer;
  font-size:14.5px;line-height:1.45;color:var(--ink-soft);transition:all .15s;
}
.choice:hover{border-color:var(--ink);background:var(--soft)}
.choice input{margin:3px 0 0;accent-color:var(--furb-dark)}
.choice.is-selected{border-color:var(--furb-dark);background:var(--furb-soft);color:var(--ink)}
.choice.is-correct{border-color:var(--furb-dark);background:var(--furb-soft);color:var(--ink)}
.choice.is-wrong{border-color:#E07474;background:#FFF1F1;color:var(--ink)}

.qcm__actions{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  margin-top:30px;flex-wrap:wrap;
}
.qcm__result{
  display:none;margin-top:30px;border-radius:var(--radius);padding:30px 32px;
  border:1px solid var(--line);
}
.qcm__result.pass{background:var(--furb-soft);border-color:#B8EFC6}
.qcm__result.fail{background:#FFF1F1;border-color:#F3C5C5}
.qcm__result h2{margin-top:0}
.qcm__result__score{
  font-family:var(--font);font-weight:800;font-size:54px;letter-spacing:-.04em;
  margin:6px 0 6px;color:var(--ink);
}
.qcm__result__score em{font-style:normal;color:var(--muted);font-weight:200;font-size:30px}
.qcm__result__msg{font-size:15.5px;color:var(--ink-soft);margin:0 0 22px}
.qcm__result__actions{display:flex;gap:12px;flex-wrap:wrap}

/* ===========================================================
   CERTIFICATE
   =========================================================== */
.cert-page{background:var(--soft);min-height:100vh}
.cert-wrap{
  max-width:900px;margin:0 auto;padding:48px 24px 60px;
}
.cert{
  background:#fff;border:6px double var(--ink);
  padding:60px 70px;text-align:center;position:relative;
  box-shadow:var(--shadow-md);
}
.cert::before{
  content:"";position:absolute;inset:14px;border:1px solid var(--line);pointer-events:none;
}
.cert__eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--furb-dark);font-weight:600;margin-bottom:14px;
}
.cert__logo{
  display:inline-flex;align-items:baseline;gap:0;
  font-family:var(--font);font-weight:800;letter-spacing:-.03em;font-size:42px;color:var(--ink);
  margin-bottom:20px;
}
.cert__logo span{color:var(--furb)}
.cert h1{
  font-family:var(--font);font-weight:800;font-size:42px;letter-spacing:-.035em;
  margin:0 0 14px;color:var(--ink);line-height:1.1;
}
.cert h1 em{font-style:normal;font-weight:200;color:var(--ink-soft);display:block;font-size:26px;margin-top:4px}
.cert__intro{
  font-family:var(--font);font-size:16px;color:var(--ink-soft);margin:8px 0 28px;font-weight:300;
}
.cert__name{
  font-family:'Inter',serif;font-weight:200;font-size:48px;letter-spacing:-.025em;
  color:var(--ink);border-bottom:1px solid var(--ink);padding:0 40px 8px;
  display:inline-block;margin:0 0 28px;
}
.cert__body{font-size:15px;color:var(--ink-soft);line-height:1.7;max-width:560px;margin:0 auto 32px}
.cert__body strong{color:var(--ink)}
.cert__seal{
  display:inline-flex;align-items:center;gap:14px;
  padding:14px 24px;border:1px solid var(--ink);border-radius:50px;
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);
  margin:16px 0 28px;font-weight:600;
}
.cert__seal::before{
  content:"";width:10px;height:10px;border-radius:50%;background:var(--furb);
}
.cert__meta{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;
  margin-top:32px;padding-top:28px;border-top:1px solid var(--line);
  text-align:left;
}
.cert__meta__item{}
.cert__meta__item .l{
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin-bottom:4px;
}
.cert__meta__item .v{
  font-family:var(--font);font-weight:700;font-size:15px;color:var(--ink);letter-spacing:-.01em;
}
.cert__sig{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:32px;text-align:left;
}
.cert__sig__line{
  border-top:1px solid var(--ink);padding-top:8px;font-family:var(--mono);font-size:11px;color:var(--muted);
  letter-spacing:.08em;
}
.cert__sig__line b{display:block;font-family:var(--font);color:var(--ink);font-size:13.5px;font-weight:700;margin-bottom:2px;letter-spacing:0}

.cert-actions{
  display:flex;gap:12px;justify-content:center;margin-top:32px;flex-wrap:wrap;
}

/* ===========================================================
   FURB LIFECYCLE DIAGRAM (custom)
   =========================================================== */
.lifecycle{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:28px 0;
  position:relative;
}
.lifecycle__node{
  background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:14px 12px;text-align:center;position:relative;
}
.lifecycle__node .ico{
  width:32px;height:32px;border-radius:8px;background:var(--furb-soft);color:var(--furb-dark);
  display:flex;align-items:center;justify-content:center;margin:0 auto 8px;
}
.lifecycle__node h4{
  font-family:var(--font);font-weight:700;font-size:13px;margin:0 0 2px;color:var(--ink);
}
.lifecycle__node p{font-family:var(--mono);font-size:10px;color:var(--muted);margin:0;letter-spacing:.06em}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:1000px){
  :root{--sidebar-w:0px}
  .menu-toggle{display:flex}
  .sidebar{
    transform:translateX(-100%);transition:transform .25s ease;
    width:300px;box-shadow:var(--shadow-md);
  }
  .sidebar.is-open{transform:translateX(0)}
  .main{margin-left:0}
  .main__inner{padding:32px 24px 24px}
  .topbar__crumb{display:none}
  .topbar{padding:0 16px}
  .cards{grid-template-columns:1fr}
  .timeline{grid-template-columns:repeat(2,1fr)}
  .lifecycle{grid-template-columns:repeat(2,1fr)}
  .cert__meta{grid-template-columns:1fr 1fr}
  .cert__sig{grid-template-columns:1fr;gap:24px}
  .cert{padding:36px 28px}
  .cert h1{font-size:30px}
  .cert__name{font-size:32px;padding:0 14px 6px}
}
@media (max-width:600px){
  .timeline{grid-template-columns:1fr}
  .lifecycle{grid-template-columns:1fr}
  .cert__meta{grid-template-columns:1fr}
  .botnav{flex-direction:column}
  .botnav__btn{max-width:none}
  .cta-block{flex-direction:column;align-items:flex-start;padding:24px}
  .landing-hero h1{font-size:32px}
}

/* ---------- PRINT (for certificate) ---------- */
@media print{
  .topbar,.sidebar,.cert-actions,.menu-toggle,.botnav{display:none!important}
  .cert-page{background:#fff;padding:0}
  .main{margin:0}
  .cert-wrap{padding:0;max-width:none}
  .cert{box-shadow:none;border-width:4px;page-break-inside:avoid;padding:50px 60px}
  body{font-size:13px}
}
