/* ===== Dare to Care Home Care — Caregiver Training LMS ===== */
:root{
  --green:#0D7C4D;
  --green-bright:#12A063;
  --green-deep:#0A5C39;
  --green-darkest:#073A24;
  --tint:#EDF5F0;
  --tint-2:#F4F9F6;
  --ink:#16201B;
  --slate:#5A6B62;
  --slate-light:#8A9890;
  --paper:#FAFCFB;
  --card:#FFFFFF;
  --border:#E2EAE5;
  --border-strong:#CBD8D0;
  --gold:#B7892F;
  --gold-light:#E9D9AE;
  --danger:#B5462E;
  --danger-tint:#F8ECE8;
  --shadow-sm:0 1px 2px rgba(7,58,36,.06), 0 1px 3px rgba(7,58,36,.05);
  --shadow-md:0 4px 14px rgba(7,58,36,.08), 0 2px 6px rgba(7,58,36,.05);
  --shadow-lg:0 18px 48px rgba(7,58,36,.14), 0 6px 16px rgba(7,58,36,.08);
  --r-sm:8px; --r-md:14px; --r-lg:22px;
  --ui:"Libre Franklin", system-ui, -apple-system, sans-serif;
  --serif:"Cormorant Garamond", Georgia, serif;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--ui);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
img{display:block;max-width:100%;}
::selection{background:rgba(13,124,77,.18);}

/* ---- App shell ---- */
.app{min-height:100vh;display:flex;flex-direction:column;}
.topbar{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;gap:18px;
  padding:0 28px;height:68px;
  background:rgba(250,252,251,.86);
  backdrop-filter:saturate(1.4) blur(12px);
  border-bottom:1px solid var(--border);
}
.topbar .brand{display:flex;align-items:center;gap:12px;cursor:pointer;}
.topbar .brand img{height:38px;width:auto;}
.topbar .brand .bn{font-weight:700;letter-spacing:-.01em;font-size:15px;color:var(--green-deep);line-height:1.05;}
.topbar .brand .bn small{display:block;font-weight:500;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--slate-light);}
.topbar .spacer{flex:1;}
.topbar .who{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--slate);}
.topbar .who .avatar{
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:var(--green);color:#fff;font-weight:700;font-size:13px;letter-spacing:.02em;
}
.nav-links{display:flex;gap:4px;}
.nav-links button{
  padding:8px 14px;border-radius:999px;font-size:13.5px;font-weight:600;color:var(--slate);
  transition:background .15s,color .15s;
}
.nav-links button:hover{background:var(--tint);color:var(--green-deep);}
.nav-links button.active{background:var(--green);color:#fff;}

.page{flex:1;width:100%;max-width:1120px;margin:0 auto;padding:40px 28px 88px;}
.page-wide{max-width:1240px;}

/* ---- Generic ---- */
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--green);}
h1.title{font-size:34px;line-height:1.1;letter-spacing:-.02em;margin:.2em 0 .15em;font-weight:700;}
.lead{font-size:17px;color:var(--slate);max-width:60ch;}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:13px 22px;border-radius:999px;font-weight:650;font-size:15px;
  background:var(--green);color:#fff;transition:transform .12s,box-shadow .15s,background .15s;
  box-shadow:var(--shadow-sm);
}
.btn:hover{background:var(--green-deep);transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn:active{transform:translateY(0);}
.btn:disabled{background:var(--border-strong);color:#fff;cursor:not-allowed;transform:none;box-shadow:none;}
.btn.ghost{background:#fff;color:var(--green-deep);border:1.5px solid var(--border-strong);box-shadow:none;}
.btn.ghost:hover{background:var(--tint);border-color:var(--green);}
.btn.gold{background:var(--gold);}
.btn.gold:hover{background:#9c7325;}
.btn.lg{padding:15px 28px;font-size:16px;}
.btn.sm{padding:9px 16px;font-size:13.5px;}
.btn.block{width:100%;}

/* ---- Progress ring / bars ---- */
.linkbtn{color:var(--green);font-weight:650;font-size:14px;display:inline-flex;align-items:center;gap:6px;}
.linkbtn:hover{color:var(--green-deep);text-decoration:underline;}

/* ===== SIGN IN ===== */
.signin{
  min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;
}
.signin .left{
  background:
    radial-gradient(120% 90% at 0% 0%, rgba(18,160,99,.16), transparent 55%),
    linear-gradient(160deg, var(--green-deep), var(--green-darkest));
  color:#eaf5ee;padding:64px 60px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;
}
.signin .left .infinity{position:absolute;right:-120px;bottom:-90px;width:520px;opacity:.07;}
.signin .left .logo-chip{background:#fff;border-radius:18px;padding:16px 20px;display:inline-flex;align-self:flex-start;box-shadow:var(--shadow-lg);}
.signin .left .logo-chip img{height:52px;}
.signin .left h2{font-size:40px;line-height:1.08;letter-spacing:-.02em;font-weight:700;margin:0 0 14px;}
.signin .left p{font-size:16.5px;color:#bfe0cd;max-width:38ch;}
.signin .left ul{list-style:none;padding:0;margin:22px 0 0;display:flex;flex-direction:column;gap:12px;}
.signin .left li{display:flex;align-items:center;gap:12px;font-size:15px;color:#dcefe3;}
.signin .left li .tick{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.16);display:grid;place-items:center;flex:none;}
.signin .right{display:flex;align-items:center;justify-content:center;padding:40px;}
.signin-card{width:100%;max-width:420px;}
.signin-card h3{font-size:26px;letter-spacing:-.01em;margin:0 0 6px;}
.signin-card .sub{color:var(--slate);margin:0 0 28px;font-size:15px;}
.field{margin-bottom:18px;}
.field label{display:block;font-size:13px;font-weight:650;color:var(--ink);margin-bottom:7px;}
.field input{
  width:100%;padding:13px 15px;border:1.5px solid var(--border-strong);border-radius:var(--r-sm);
  font-size:15.5px;font-family:inherit;color:var(--ink);background:#fff;transition:border .15s,box-shadow .15s;
}
.field input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(13,124,77,.12);}
.field .hint{font-size:12.5px;color:var(--slate-light);margin-top:6px;}

/* ===== DASHBOARD ===== */
.dash-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:8px;flex-wrap:wrap;}
.progress-summary{
  display:flex;align-items:center;gap:22px;background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:20px 26px;box-shadow:var(--shadow-sm);
}
.ring{position:relative;width:74px;height:74px;flex:none;}
.ring svg{transform:rotate(-90deg);}
.ring .pct{position:absolute;inset:0;display:grid;place-items:center;font-weight:750;font-size:18px;color:var(--green-deep);}
.progress-summary .meta b{font-size:15px;}
.progress-summary .meta div{font-size:13px;color:var(--slate);}

.course-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:26px;}
.course-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:24px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-sm);
  transition:transform .15s,box-shadow .2s,border-color .2s;position:relative;overflow:hidden;
}
.course-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-strong);}
.course-card .ribbon{position:absolute;top:0;left:0;width:5px;height:100%;background:var(--green);opacity:.0;transition:opacity .2s;}
.course-card.done .ribbon{opacity:1;background:var(--gold);}
.course-card .cc-top{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.cc-icon{width:50px;height:50px;border-radius:14px;background:var(--tint);display:grid;place-items:center;color:var(--green);flex:none;}
.cc-num{font-size:12px;font-weight:700;letter-spacing:.14em;color:var(--slate-light);}
.course-card h3{font-size:19px;line-height:1.2;letter-spacing:-.01em;margin:0;}
.course-card .blurb{font-size:14px;color:var(--slate);margin:0;flex:1;}
.cc-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:2px;}
.cc-meta{display:flex;align-items:center;gap:14px;font-size:12.5px;color:var(--slate-light);font-weight:600;}
.cc-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--border-strong);}
.status-pill{display:inline-flex;align-items:center;gap:7px;padding:6px 13px;border-radius:999px;font-size:12.5px;font-weight:700;}
.status-pill.todo{background:var(--tint);color:var(--green-deep);}
.status-pill.passed{background:#FBF3DE;color:var(--gold);}
.status-pill.progress{background:#E7F0FB;color:#2C6BB3;}

/* badges row in card */
.media-tag{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--slate-light);}

/* ===== COURSE PLAYER ===== */
.course-top{display:flex;align-items:center;gap:14px;margin-bottom:22px;flex-wrap:wrap;}
.crumb{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--slate);font-weight:600;}
.crumb:hover{color:var(--green-deep);}
.stepbar{display:flex;align-items:center;gap:0;margin:0 0 30px;}
.step{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:650;color:var(--slate-light);}
.step .si{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:var(--tint);color:var(--slate-light);font-size:13px;font-weight:700;border:1.5px solid var(--border);}
.step.active .si{background:var(--green);color:#fff;border-color:var(--green);}
.step.active{color:var(--green-deep);}
.step.complete .si{background:var(--green-deep);color:#fff;border-color:var(--green-deep);}
.step-line{flex:1;height:2px;background:var(--border);margin:0 14px;min-width:24px;}
.step-line.on{background:var(--green);}

.course-layout{display:grid;grid-template-columns:1fr 320px;gap:32px;align-items:start;}
@media(max-width:900px){.course-layout{grid-template-columns:1fr;}}

.lesson-panel{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);}
.video-wrap{position:relative;background:#06281a;aspect-ratio:16/9;}
.video-wrap video{width:100%;height:100%;display:block;object-fit:cover;background:#06281a;}

/* reading preview */
.reading-preview{position:absolute;inset:0;display:grid;place-items:center;overflow:hidden;
  background:radial-gradient(130% 100% at 20% 10%, #0f6f47, #073A24 70%);}
.reading-preview .pulse-rings{position:absolute;inset:0;display:grid;place-items:center;}
.reading-preview .pr{position:absolute;border:1.5px solid rgba(255,255,255,.18);border-radius:50%;animation:ripple 3.4s ease-out infinite;}
@keyframes ripple{0%{width:60px;height:60px;opacity:.0;}25%{opacity:.5;}100%{width:560px;height:560px;opacity:0;}}
.reading-preview .float-ico{position:absolute;color:rgba(255,255,255,.10);animation:floaty 7s ease-in-out infinite;}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(0);}50%{transform:translateY(-18px) rotate(6deg);}}
.reading-preview .center{position:relative;z-index:2;text-align:center;color:#eaf5ee;padding:30px;max-width:480px;}
.reading-preview .center .play-orb{width:84px;height:84px;border-radius:50%;background:rgba(255,255,255,.14);
  border:1.5px solid rgba(255,255,255,.3);display:grid;place-items:center;margin:0 auto 20px;animation:breathe 3s ease-in-out infinite;}
@keyframes breathe{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(255,255,255,.12);}50%{transform:scale(1.05);box-shadow:0 0 0 18px rgba(255,255,255,0);}}
.reading-preview .center h4{font-size:20px;margin:0 0 8px;font-weight:700;letter-spacing:-.01em;}
.reading-preview .center p{font-size:14px;color:#bfe0cd;margin:0 0 4px;}
.reading-preview .chip-reading{display:inline-flex;align-items:center;gap:7px;margin-top:16px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);color:#eaf5ee;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:7px 14px;border-radius:999px;}
.reading-preview .ticker{position:absolute;left:0;right:0;bottom:0;background:rgba(0,0,0,.22);padding:11px 0;overflow:hidden;white-space:nowrap;}
.reading-preview .ticker .track{display:inline-block;animation:scrollx 22s linear infinite;font-size:13px;color:#cdeadb;font-weight:600;}
.reading-preview .ticker .track span{margin:0 26px;}
@keyframes scrollx{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

.lesson-body{padding:28px 30px 32px;}
.lesson-body .intro{font-size:16px;color:var(--ink);margin:0 0 6px;}
.sec-list{display:flex;flex-direction:column;gap:2px;margin-top:18px;}
.sec{border-top:1px solid var(--border);padding:18px 0;display:grid;grid-template-columns:30px 1fr;gap:16px;}
.sec:first-child{border-top:none;}
.sec .sn{width:30px;height:30px;border-radius:9px;background:var(--tint);color:var(--green);display:grid;place-items:center;font-weight:750;font-size:13px;}
.sec h4{margin:3px 0 5px;font-size:16px;letter-spacing:-.01em;}
.sec p{margin:0;font-size:14.5px;color:var(--slate);}
.policy-review{margin-top:18px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--tint-2);padding:16px;display:flex;flex-direction:column;gap:14px;}
.policy-review-copy{display:flex;align-items:flex-start;gap:12px;}
.policy-review-copy h4{margin:1px 0 4px;font-size:15px;}
.policy-review-copy p{margin:0;font-size:13.5px;color:var(--slate);}
.policy-review-copy .btn{margin-left:auto;white-space:nowrap;}
.policy-icon{width:34px;height:34px;border-radius:11px;background:#fff;border:1px solid var(--border);color:var(--green);display:grid;place-items:center;flex:none;}
.policy-check{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;font-weight:650;color:var(--ink);background:#fff;border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 13px;}
.policy-check input{margin-top:2px;accent-color:var(--green);}

.lesson-cta{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 30px;border-top:1px solid var(--border);background:var(--tint-2);}
.lesson-cta .note{font-size:13px;color:var(--slate);}

/* side rail */
.rail{position:sticky;top:90px;display:flex;flex-direction:column;gap:16px;}
.rail-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);padding:20px;box-shadow:var(--shadow-sm);}
.rail-card h5{margin:0 0 12px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--slate-light);font-weight:700;}
.rail-obj{display:flex;gap:10px;font-size:13.5px;color:var(--slate);padding:7px 0;align-items:flex-start;}
.rail-obj .b{width:7px;height:7px;border-radius:50%;background:var(--green);margin-top:6px;flex:none;}
.watch-state{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:650;}
.watch-state .ic{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;flex:none;}
.watch-state.ok .ic{background:var(--green);color:#fff;}
.watch-state.no .ic{background:var(--tint);color:var(--slate-light);border:1.5px solid var(--border);}

/* ===== QUIZ ===== */
.quiz-wrap{max-width:760px;margin:0 auto;}
.quiz-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:34px 38px 30px;}
.quiz-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.quiz-meta .qcount{font-size:13px;font-weight:700;color:var(--slate-light);letter-spacing:.04em;}
.qprog{height:6px;border-radius:999px;background:var(--tint);overflow:hidden;margin:14px 0 26px;}
.qprog i{display:block;height:100%;background:var(--green);border-radius:999px;transition:width .35s cubic-bezier(.4,0,.2,1);}
.qtext{font-size:21px;line-height:1.32;letter-spacing:-.01em;font-weight:650;margin:0 0 22px;}
.opt{display:flex;align-items:center;gap:14px;width:100%;text-align:left;padding:16px 18px;border-radius:var(--r-md);
  border:1.5px solid var(--border-strong);background:#fff;margin-bottom:12px;font-size:15.5px;font-weight:550;color:var(--ink);
  transition:border .15s,background .15s,transform .1s;}
.opt:hover{border-color:var(--green);background:var(--tint-2);}
.opt .mk{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border-strong);display:grid;place-items:center;flex:none;font-size:13px;font-weight:700;color:var(--slate-light);transition:all .15s;}
.opt.sel{border-color:var(--green);background:var(--tint);}
.opt.sel .mk{background:var(--green);border-color:var(--green);color:#fff;}
.opt.correct{border-color:var(--green);background:#EAF6EF;}
.opt.correct .mk{background:var(--green);border-color:var(--green);color:#fff;}
.opt.wrong{border-color:var(--danger);background:var(--danger-tint);}
.opt.wrong .mk{background:var(--danger);border-color:var(--danger);color:#fff;}
.opt:disabled{cursor:default;}
.explain{font-size:14px;color:var(--slate);background:var(--tint-2);border-left:3px solid var(--green);padding:13px 16px;border-radius:0 var(--r-sm) var(--r-sm) 0;margin:4px 0 6px;}
.quiz-foot{display:flex;align-items:center;justify-content:space-between;margin-top:22px;gap:14px;}

/* result */
.result{max-width:620px;margin:0 auto;text-align:center;background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:48px 44px;}
.result .big-ring{width:128px;height:128px;margin:0 auto 22px;position:relative;}
.result .big-ring .v{position:absolute;inset:0;display:grid;place-items:center;font-size:32px;font-weight:800;}
.result h2{font-size:28px;margin:0 0 8px;letter-spacing:-.01em;}
.result p{font-size:16px;color:var(--slate);margin:0 0 8px;}
.result.pass h2{color:var(--green-deep);}
.result.fail h2{color:var(--danger);}
.score-line{display:inline-flex;gap:8px;align-items:center;margin:14px 0 26px;font-size:14px;color:var(--slate);}
.result-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* confetti */
.confetti{position:fixed;inset:0;pointer-events:none;z-index:60;overflow:hidden;}
.confetti i{position:absolute;top:-12px;width:9px;height:14px;opacity:.9;animation:fall linear forwards;}
@keyframes fall{to{transform:translateY(105vh) rotate(720deg);opacity:.9;}}

/* ===== CERTIFICATES PAGE ===== */
.cert-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px 24px;box-shadow:var(--shadow-sm);margin-bottom:26px;}
.cert-toolbar .cnt b{font-size:22px;}
.cert-toolbar .cnt div{font-size:13px;color:var(--slate);}
.cert-toolbar .actions{display:flex;gap:10px;flex-wrap:wrap;}
.cert-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;}
@media(max-width:820px){.cert-grid{grid-template-columns:1fr;}.course-grid{grid-template-columns:1fr;}.signin{grid-template-columns:1fr;}.signin .left{display:none;}}

@media(max-width:640px){
  .topbar{
    height:auto;
    min-height:68px;
    padding:10px 16px;
    gap:10px;
    flex-wrap:wrap;
  }
  .topbar .brand{gap:9px;min-width:0;}
  .topbar .brand img{height:32px;}
  .topbar .brand .bn{font-size:13px;max-width:150px;}
  .topbar .brand .bn small{font-size:9px;letter-spacing:.1em;line-height:1.15;}
  .topbar .spacer{display:none;}
  .topbar .who{margin-left:auto;}
  .topbar .who span:first-child{display:none;}
  .nav-links{order:3;width:100%;justify-content:center;}
  .nav-links button{padding:7px 12px;font-size:13px;}

  .page{padding:26px 18px 70px;}
  h1.title{font-size:28px;}
  .lead{font-size:15.5px;}
  .progress-summary{width:100%;justify-content:flex-start;padding:16px 18px;border-radius:14px;}
  .course-card{padding:20px;border-radius:14px;}
  .cc-foot{align-items:flex-start;flex-direction:column;}

  .course-top{gap:8px;margin-bottom:18px;}
  .stepbar{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
    margin-bottom:22px;
  }
  .step-line{display:none;}
  .step{justify-content:center;text-align:center;font-size:12px;gap:6px;line-height:1.2;flex-direction:column;}
  .step .si{width:30px;height:30px;}

  .video-wrap{min-height:250px;aspect-ratio:auto;}
  .reading-preview .center{padding:22px 18px;max-width:310px;}
  .reading-preview .center .play-orb{width:72px;height:72px;margin-bottom:14px;}
  .reading-preview .center h4{font-size:19px;}
  .reading-preview .center p{font-size:13px;}
  .reading-preview .ticker{display:none;}
  .lesson-body{padding:24px 22px 28px;}
  .policy-review-copy{flex-wrap:wrap;}
  .policy-review-copy .btn{width:100%;margin-left:0;}
  .lesson-cta{align-items:stretch;flex-direction:column;padding:18px 22px;}
  .lesson-cta > div{flex-wrap:wrap;}
  .lesson-cta .btn{width:100%;}
  .rail{position:static;}

  .quiz-card{padding:26px 22px 24px;}
  .quiz-meta,.quiz-foot{align-items:flex-start;flex-direction:column;}
  .quiz-foot .btn{width:100%;}
  .result{padding:36px 24px;}
  .cert-toolbar .actions,.cert-toolbar .actions .btn{width:100%;}
}
.cert-mini{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .15s;}
.cert-mini:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.cert-mini .thumb{aspect-ratio:1.414/1;background:var(--tint-2);position:relative;overflow:hidden;border-bottom:1px solid var(--border);}
.cert-mini .thumb .scaled{position:absolute;top:0;left:0;transform-origin:top left;}
.cert-mini .locked{position:absolute;inset:0;display:grid;place-items:center;background:repeating-linear-gradient(135deg,#f2f5f3,#f2f5f3 12px,#eef3f0 12px,#eef3f0 24px);color:var(--slate-light);text-align:center;gap:10px;}
.cert-mini .locked .lk{display:flex;flex-direction:column;align-items:center;gap:10px;}
.cert-mini .mini-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;}
.cert-mini .mini-foot b{font-size:14px;line-height:1.2;}
.cert-mini .mini-foot .when{font-size:12px;color:var(--slate-light);}

/* ===== CERTIFICATE (print artboard) ===== */
.cert-stage{background:#3a463f;padding:30px;border-radius:var(--r-lg);display:grid;place-items:center;overflow:auto;}
.certificate{
  width:1123px;height:794px;background:#fff;position:relative;overflow:hidden;flex:none;
  font-family:var(--serif);color:#16201B;
}
.certificate *{box-sizing:border-box;}
.cert-border-outer{position:absolute;inset:22px;border:2px solid var(--green);} 
.cert-border-inner{position:absolute;inset:30px;border:1px solid var(--gold);}
.cert-corner{position:absolute;width:54px;height:54px;border:2px solid var(--gold);}
.cert-corner.tl{top:38px;left:38px;border-right:none;border-bottom:none;}
.cert-corner.tr{top:38px;right:38px;border-left:none;border-bottom:none;}
.cert-corner.bl{bottom:38px;left:38px;border-right:none;border-top:none;}
.cert-corner.br{bottom:38px;right:38px;border-left:none;border-top:none;}
.cert-guilloche{position:absolute;inset:30px;opacity:.05;pointer-events:none;}
.cert-watermark{position:absolute;left:50%;top:54%;transform:translate(-50%,-50%);width:560px;opacity:.045;pointer-events:none;}
.cert-inner{position:absolute;inset:30px;padding:40px 70px 0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;}
.cert-logo{height:74px;margin-bottom:6px;}
.cert-org{font-family:var(--ui);font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--green-deep);font-weight:700;width:100%;}
.cert-kicker{font-family:var(--ui);font-size:12.5px;letter-spacing:.36em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-top:20px;width:100%;}
.cert-h1{font-size:50px;line-height:1;font-weight:700;letter-spacing:.01em;margin:6px 0 2px;color:var(--green-darkest);}
.cert-presented{font-family:var(--ui);font-size:13.5px;letter-spacing:.05em;color:var(--slate);margin-top:22px;width:100%;}
.cert-name{font-size:54px;font-weight:600;line-height:1.05;margin:6px 0 0;color:var(--green-deep);white-space:nowrap;}
.cert-nameline{width:480px;height:1px;background:var(--gold);margin:13px auto 0;}
.cert-body{font-family:var(--ui);font-size:14.5px;line-height:1.55;color:var(--slate);max-width:62ch;margin:20px auto 0;}
.cert-course{font-family:var(--serif);font-size:25px;font-weight:600;color:var(--green-darkest);margin:16px 0 0;font-style:italic;line-height:1.25;width:100%;white-space:nowrap;}
.cert-score{font-family:var(--ui);font-size:12.5px;color:var(--slate);margin-top:14px;letter-spacing:.02em;width:100%;}
.cert-foot{position:absolute;left:90px;right:90px;bottom:118px;display:flex;align-items:flex-end;justify-content:space-between;}
.cert-sig{font-family:var(--ui);text-align:center;width:252px;}
.cert-sig .sig-name{font-family:var(--serif);font-size:21px;color:var(--green-deep);border-bottom:1px solid #16201B;padding-bottom:6px;font-style:italic;white-space:nowrap;}
.cert-sig .sig-meta{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-top:7px;font-weight:600;}
.cert-date .sig-name{font-style:normal;font-family:var(--ui);font-size:18px;font-weight:600;color:var(--ink);}

/* seal */
.cert-seal{position:absolute;left:50%;bottom:54px;transform:translateX(-50%);width:112px;height:112px;}
.cert-seal .ring-text{position:absolute;inset:0;animation:none;}
.cert-seal .core{position:absolute;inset:20px;border-radius:50%;background:radial-gradient(circle at 35% 30%, var(--green-bright), var(--green-deep));
  display:grid;place-items:center;color:#fff;box-shadow:inset 0 0 0 3px rgba(255,255,255,.35), 0 4px 10px rgba(7,58,36,.3);}
.cert-seal .core .leaf{width:42px;height:42px;}
.cert-seal .core small{position:absolute;bottom:16px;font-family:var(--ui);font-size:7.5px;letter-spacing:.18em;font-weight:700;}

.cert-id{position:absolute;right:90px;bottom:44px;font-family:var(--ui);font-size:10px;letter-spacing:.06em;color:var(--slate);text-align:right;line-height:1.6;}
.cert-id b{color:var(--ink);}

/* modal */
.modal-scrim{position:fixed;inset:0;background:rgba(8,30,20,.55);backdrop-filter:blur(3px);z-index:80;display:grid;place-items:center;padding:24px;animation:fadein .2s;}
@keyframes fadein{from{opacity:0;}to{opacity:1;}}
.modal{background:var(--paper);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);max-width:min(1180px,96vw);width:100%;max-height:94vh;overflow:hidden;display:flex;flex-direction:column;}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 22px;border-bottom:1px solid var(--border);background:#fff;}
.modal-head h4{margin:0;font-size:16px;}
.modal-head .actions{display:flex;gap:10px;align-items:center;}
.modal-scroll{overflow:auto;padding:28px;display:grid;place-items:center;}
.iconbtn{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:var(--slate);background:var(--tint);}
.iconbtn:hover{background:var(--border);color:var(--ink);}

/* empty + misc */
.empty{text-align:center;padding:60px 20px;color:var(--slate);}
.empty .ei{width:64px;height:64px;border-radius:18px;background:var(--tint);display:grid;place-items:center;margin:0 auto 16px;color:var(--green);}
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:13px 22px;border-radius:999px;font-size:14px;font-weight:600;z-index:90;box-shadow:var(--shadow-lg);display:flex;gap:10px;align-items:center;animation:toastin .25s;}
@keyframes toastin{from{opacity:0;transform:translate(-50%,12px);}to{opacity:1;transform:translate(-50%,0);}}
.spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;}
.spinner.dark{border-color:rgba(13,124,77,.25);border-top-color:var(--green);}
@keyframes spin{to{transform:rotate(360deg);}}

/* all-done banner */
.alldone{background:linear-gradient(120deg,var(--green-deep),var(--green-darkest));color:#fff;border-radius:var(--r-lg);
  padding:30px 34px;display:flex;align-items:center;justify-content:space-between;gap:24px;box-shadow:var(--shadow-md);margin-bottom:26px;position:relative;overflow:hidden;flex-wrap:wrap;}
.alldone h3{margin:0 0 6px;font-size:22px;letter-spacing:-.01em;}
.alldone p{margin:0;color:#bfe0cd;font-size:14.5px;max-width:50ch;}
.alldone .badge-ico{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.14);display:grid;place-items:center;flex:none;}
