/* ============================================================
   CareCPD — shared design system (Direction A · The Standards Body)
   ============================================================ */
:root{
  --ink:#142a23; --ink-2:#3f5249; --ink-3:#6a7d74;
  --green:#2e7d5b; --green-700:#256a4c; --green-900:#163d2c; --green-300:#5aa17e;
  --soft:#eef4ef; --soft-2:#d8e8dc; --line:#e1e9e4; --line-2:#d6e0da;
  --bg:#ffffff; --bg-2:#f6faf7; --sand:#e8d9c4; --sand-deep:#c9a86f;
  --warn:#c98a3c; --danger:#c25b5b;
  --maxw:1160px; --r:16px;
  --shadow-sm:0 1px 2px rgba(20,42,35,.04);
  --shadow-md:0 24px 48px -36px rgba(20,42,35,.34);
  --shadow-lg:0 34px 70px -44px rgba(20,42,35,.42);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:"Hanken Grotesk",system-ui,sans-serif;color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;line-height:1.55;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.wrap--narrow{max-width:880px;}
.eyebrow{display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--green);margin-bottom:18px;}
.lede{font-size:18.5px;color:var(--ink-2);}
h1,h2,h3,h4{letter-spacing:-.02em;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-weight:600;
  font-size:15px;border-radius:999px;padding:11px 20px;cursor:pointer;border:1px solid transparent;transition:.18s ease;white-space:nowrap;}
.btn--lg{padding:14px 26px;font-size:15.5px;}
.btn--sm{padding:9px 15px;font-size:13.5px;}
.btn--block{width:100%;}
.btn--solid{background:var(--green);color:#fff;}
.btn--solid:hover{background:var(--green-700);}
.btn--outline{background:#fff;color:var(--ink);border-color:var(--line);}
.btn--outline:hover{border-color:var(--green-300);color:var(--green-700);}
.btn--ghost{background:transparent;color:var(--ink);}
.btn--ghost:hover{color:var(--green-700);}
.btn--white{background:#fff;color:var(--green-700);}
.btn--white:hover{background:#f0f5f1;}
.btn--ghostlight{background:transparent;color:#fff;border-color:rgba(255,255,255,.4);}
.btn--ghostlight:hover{background:rgba(255,255,255,.1);}

/* ---------- header ---------- */
.hdr{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.82);backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid var(--line);box-shadow:0 1px 0 rgba(20,42,35,.02);}
.hdr__inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px;}
.brand{display:flex;align-items:center;gap:11px;}
.brand__mark{width:30px;height:30px;border-radius:10px;background:var(--green);display:grid;place-items:center;flex:none;
  box-shadow:0 6px 14px -7px rgba(46,125,91,.7),inset 0 0 0 1px rgba(255,255,255,.12);}
.brand__name{font-weight:800;font-size:19.5px;letter-spacing:-.02em;}
.brand__name span{color:var(--green);}
.hdr__right{display:flex;align-items:center;gap:30px;}
.nav{display:flex;gap:28px;align-items:center;}
.nav a{font-size:14.5px;color:var(--ink-2);font-weight:500;transition:color .15s;position:relative;padding:4px 0;white-space:nowrap;}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--green);border-radius:2px;
  transition:right .22s cubic-bezier(.2,.7,.2,1);}
.nav a:hover{color:var(--green-700);}
.nav a:hover::after{right:0;}
.nav a.is-active{color:var(--green-700);font-weight:600;}
.nav a.is-active::after{right:0;}
.btn--verify{padding:11px 20px;box-shadow:0 10px 22px -10px rgba(46,125,91,.7);}
.btn--verify svg{margin-right:-1px;}
.btn--verify.is-here{background:var(--green-700);box-shadow:0 0 0 4px var(--soft),0 10px 22px -12px rgba(46,125,91,.6);}
.hdr__burger{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:12px;background:#fff;
  cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:4px;transition:.15s;}
.hdr__burger:hover{border-color:var(--green-300);}
.hdr__burger span{width:18px;height:2px;background:var(--ink);border-radius:2px;}
.mobnav{display:none;border-top:1px solid var(--line);background:#fff;padding:12px 0;}
.mobnav.open{display:block;}
.mobnav a{display:block;padding:13px 28px;font-size:16px;color:var(--ink-2);font-weight:500;}
.mobnav a:hover{background:var(--bg-2);color:var(--green-700);}
.mobnav__cta{display:flex;gap:10px;padding:14px 28px 6px;}

/* ---------- page header band ---------- */
.pagehead{background:linear-gradient(180deg,#f6faf7,#ffffff);border-bottom:1px solid var(--line);padding:54px 0 56px;}
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-3);margin-bottom:20px;white-space:nowrap;flex-wrap:wrap;}
.crumbs a:hover{color:var(--green-700);}
.crumbs span{opacity:.5;}
.pagehead h1{font-size:clamp(34px,4.2vw,52px);line-height:1.04;margin:0 0 16px;font-weight:800;max-width:780px;}
.pagehead .lede{max-width:620px;margin:0;}
.pagehead__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px;}

/* ---------- generic sections ---------- */
.sect{padding:84px 0;}
.sect--tight{padding:60px 0;}
.sect--alt{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.sect__head{margin-bottom:42px;max-width:680px;}
.sect__head--center{margin-left:auto;margin-right:auto;text-align:center;}
.sect__h2{font-size:clamp(28px,3.2vw,40px);line-height:1.08;margin:0;font-weight:800;}
.sect__sub{font-size:17px;color:var(--ink-2);margin:14px 0 0;}

/* ---------- cards / grid utils ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;}
.card--hover{transition:.2s ease;}
.card--hover:hover{border-color:var(--green-300);box-shadow:var(--shadow-md);transform:translateY(-3px);}
.icontile{width:54px;height:54px;border-radius:15px;background:var(--soft);display:grid;place-items:center;margin-bottom:18px;}
.tag-eyebrow{font-size:12.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--green);margin-bottom:12px;}

.checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;}
.checklist li{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:var(--ink-2);}
.checklist svg{flex:none;margin-top:2px;}

/* ---------- trust bar ---------- */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);}
.trust__inner{display:grid;grid-template-columns:repeat(4,1fr);}
.trust__item{padding:30px 18px;text-align:center;border-right:1px solid var(--line);}
.trust__item:last-child{border-right:none;}
.trust__n{font-size:30px;font-weight:800;color:var(--green-700);}
.trust__l{font-size:14px;color:var(--ink-3);margin-top:2px;}

/* ---------- steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);}
.step{padding:30px 28px 30px 0;border-right:1px solid var(--line);}
.step:last-child{border-right:none;padding-right:0;}
.step:not(:first-child){padding-left:28px;}
.step__n{font-size:14px;font-weight:800;color:var(--green);letter-spacing:.06em;margin-bottom:16px;}
.step__h{font-size:18px;margin:0 0 8px;font-weight:700;}
.step__p{font-size:14.5px;color:var(--ink-2);margin:0;}

/* ---------- seal ---------- */
.sealcard{background:#fff;border:1px solid var(--line);border-radius:24px;padding:32px;box-shadow:var(--shadow-lg);
  display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;}
.sealcard::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;border-radius:24px 24px 0 0;
  background:linear-gradient(90deg,var(--green-300),var(--green));opacity:.85;}
.sealcard__txt{margin-top:14px;}
.sealcard__k{font-weight:800;font-size:16px;line-height:1.25;}
.sealcard__v{font-size:13px;color:var(--ink-3);}
.sealcard__rule{height:1px;background:var(--line);width:100%;margin:22px 0 18px;}
.sealcard__cert{width:100%;text-align:left;background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:6px 16px;}
.sealcard__certrow{display:flex;justify-content:space-between;gap:16px;font-size:14px;padding:10px 0;border-bottom:1px dashed var(--line-2);}
.sealcard__certrow:last-of-type{border-bottom:none;}
.sealcard__certrow span{color:var(--ink-3);}
.sealcard__certrow b{font-weight:700;}
.sealcard__status{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:14px;width:100%;background:var(--soft);color:var(--green-700);
  font-weight:700;font-size:13.5px;padding:11px 14px;border-radius:11px;}

/* ---------- quotes ---------- */
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px;margin:0;display:flex;flex-direction:column;}
.quote blockquote{margin:0 0 20px;font-size:16.5px;line-height:1.5;color:var(--ink);}
.quote figcaption{display:flex;align-items:center;gap:12px;margin-top:auto;}
.quote__avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#cfe0d5,#9ec3ad);flex:none;}
.quote figcaption b{display:block;font-size:14.5px;}
.quote figcaption em{font-style:normal;font-size:13px;color:var(--ink-3);}

/* ---------- CTA band ---------- */
.cta{background:var(--ink);color:#fff;padding:84px 0;}
.cta__inner{text-align:center;max-width:680px;margin:0 auto;}
.cta__h{font-size:clamp(30px,3.4vw,44px);margin:0 0 14px;font-weight:800;}
.cta__p{font-size:18px;color:rgba(255,255,255,.78);margin:0 0 28px;}
.cta__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* ---------- footer ---------- */
.ftr{background:#0f211b;color:rgba(255,255,255,.74);padding:60px 0 30px;}
.ftr__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;}
.ftr .brand__name{color:#fff;}
.ftr__tag{font-size:14.5px;max-width:300px;margin:16px 0 20px;}
.ftr__seal{display:flex;align-items:center;gap:12px;font-size:12.5px;line-height:1.4;color:rgba(255,255,255,.6);}
.ftr__col h4{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:#fff;margin:0 0 16px;}
.ftr__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;}
.ftr__col a{font-size:14.5px;color:rgba(255,255,255,.72);}
.ftr__col a:hover{color:#fff;}
.ftr__base{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(255,255,255,.12);
  margin-top:46px;padding-top:24px;font-size:13px;color:rgba(255,255,255,.5);}
.ftr__legal{display:flex;gap:20px;}

/* ---------- placeholder ---------- */
.ph{background:repeating-linear-gradient(135deg,#eef4ef,#eef4ef 11px,#e6efe9 11px,#e6efe9 22px);
  border:1px solid var(--line);display:grid;place-items:center;border-radius:14px;}
.ph__tag{font-family:ui-monospace,Menlo,monospace;font-size:12px;color:var(--ink-3);background:rgba(255,255,255,.8);
  padding:5px 10px;border-radius:6px;}

/* ---------- pills / badges ---------- */
.pill-badge{display:inline-flex;align-items:center;gap:7px;background:var(--soft);color:var(--green-700);font-weight:700;
  font-size:13px;padding:7px 13px;border-radius:999px;}
.divider{height:1px;background:var(--line);border:none;margin:0;}

/* ---------- responsive (shared) ----------
   Header collapses to a menu earlier than content, so compact
   laptops keep the multi-column layout instead of dropping to mobile. */
@media(max-width:1024px){
  .hdr__right{display:none;}
  .hdr__burger{display:flex;}
}
@media(max-width:1000px){
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:840px){
  .grid-2{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr 1fr;}
  .step{border-bottom:1px solid var(--line);padding:24px 20px;}
  .step:nth-child(odd){padding-left:0;}
  .trust__inner{grid-template-columns:repeat(2,1fr);}
  .trust__item:nth-child(2){border-right:none;}
  .ftr__grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:640px){
  .grid-3,.grid-4{grid-template-columns:1fr;}
  .trust__inner{grid-template-columns:1fr;}
  .trust__item{border-right:none;}
  .steps{grid-template-columns:1fr;}
  .ftr__grid{grid-template-columns:1fr;}
  .wrap{padding:0 20px;}
  .sect{padding:60px 0;}
  .pagehead{padding:40px 0 42px;}
}

/* ============================================================
   Refinement layer — polish applied site-wide
   ============================================================ */
::selection{background:var(--soft-2);color:var(--green-900);}
a,button{-webkit-tap-highlight-color:transparent;}
:focus-visible{outline:2px solid var(--green-300);outline-offset:3px;border-radius:5px;}
/* sticky-header offset for in-page anchors (#apply, #reviewers, #standards…) */
:target,[id]{scroll-margin-top:92px;}

/* button tactility */
.btn--solid{box-shadow:0 8px 18px -11px rgba(46,125,91,.65);}
.btn--solid:hover{transform:translateY(-1px);box-shadow:0 14px 24px -12px rgba(46,125,91,.7);}
.btn--solid:active{transform:translateY(0);box-shadow:0 6px 14px -10px rgba(46,125,91,.6);}
.btn--outline:hover,.btn--white:hover{transform:translateY(-1px);}
.btn--white{box-shadow:0 10px 22px -14px rgba(0,0,0,.5);}

/* refined eyebrow — small leading rule for an editorial, standards-body feel */
.eyebrow{position:relative;}

/* page-header: faint seal-tone wash + hairline base */
.pagehead{position:relative;overflow:hidden;}
.pagehead::after{content:"";position:absolute;right:-90px;top:-90px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle at center,rgba(46,125,91,.07),rgba(46,125,91,0) 64%);pointer-events:none;}
.pagehead > .wrap{position:relative;z-index:1;}

/* hero: subtle depth */
.hero{position:relative;overflow:hidden;}
.hero::after{content:"";position:absolute;left:-160px;bottom:-160px;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle at center,rgba(90,161,126,.08),rgba(90,161,126,0) 66%);pointer-events:none;}
.hero > .wrap{position:relative;z-index:1;}

/* CTA band: faint concentric seal motif */
.cta{position:relative;overflow:hidden;}
.cta::before{content:"";position:absolute;right:-120px;top:50%;transform:translateY(-50%);width:420px;height:420px;border-radius:50%;
  border:1px solid rgba(255,255,255,.08);box-shadow:0 0 0 40px rgba(255,255,255,.03),0 0 0 90px rgba(255,255,255,.02);pointer-events:none;}
.cta > .wrap{position:relative;z-index:1;}

/* thin scrollbars for in-card scroll regions */
.sp__list,.dtable{scrollbar-width:thin;scrollbar-color:var(--line-2) transparent;}
.sp__list::-webkit-scrollbar{width:8px;}
.sp__list::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px;}
.sp__list::-webkit-scrollbar-track{background:transparent;}

/* keep the seal-card label tidy at any width */
.sealcard__k{line-height:1.25;}

/* links inside prose get a gentle underline cue */
.split__lead a,.wcard__p a{color:var(--green-700);text-decoration:underline;text-underline-offset:3px;}

@media(prefers-reduced-motion:reduce){*{animation:none!important;}}

/* ============================================================
   CareCPD — page-specific styles
   ============================================================ */

/* ---------- hero (home) ---------- */
.hero{padding:78px 0 64px;background:linear-gradient(180deg,#f6faf7 0%,#ffffff 100%);}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center;}
.hero__h1{font-size:clamp(38px,4.6vw,58px);line-height:1.04;margin:0 0 20px;font-weight:800;}
.hero__sub{font-size:18.5px;color:var(--ink-2);max-width:540px;margin:0 0 30px;}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px;}
.hero__assure{list-style:none;display:flex;flex-wrap:wrap;gap:8px 22px;padding:0;margin:0;}
.hero__assure li{display:flex;align-items:center;gap:8px;font-size:14.5px;color:var(--ink-2);font-weight:500;}

/* ---------- who cards ---------- */
.wcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;display:flex;flex-direction:column;transition:.2s ease;}
.wcard:hover{border-color:var(--green-300);box-shadow:var(--shadow-md);transform:translateY(-3px);}
.wcard__tag{font-size:12.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--green);margin-bottom:14px;}
.wcard__h{font-size:22px;margin:0 0 10px;font-weight:800;}
.wcard__p{color:var(--ink-2);font-size:15.5px;margin:0 0 18px;}
.wcard__list{list-style:none;padding:0;margin:auto 0 0;display:flex;flex-direction:column;gap:10px;}
.wcard__list li{display:flex;align-items:flex-start;gap:9px;font-size:14.5px;color:var(--ink-2);}
.wcard__list svg{flex:none;margin-top:2px;}
.wcard__more{margin-top:18px;font-weight:600;font-size:14.5px;color:var(--green-700);display:inline-flex;align-items:center;gap:6px;}
.wcard__more:hover{gap:10px;}

/* ---------- demo module (verify/search) ---------- */
.demo{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);}
.demo__tabs{display:flex;background:var(--bg-2);border-bottom:1px solid var(--line);padding:6px;gap:6px;}
.demo__tab{flex:1;font-family:inherit;font-weight:600;font-size:14.5px;color:var(--ink-2);background:transparent;border:none;
  border-radius:12px;padding:11px;cursor:pointer;transition:.16s;}
.demo__tab.is-on{background:#fff;color:var(--green-700);box-shadow:0 2px 8px -3px rgba(20,42,35,.25);}
.demo__body{padding:26px;}

.vp__label{font-size:13px;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;}
.vp__row{display:flex;gap:10px;margin-top:9px;}
.vp__row--shake{animation:shake .4s;}
@keyframes shake{0%,100%{transform:translateX(0);}20%,60%{transform:translateX(-6px);}40%,80%{transform:translateX(6px);}}
.field{font-family:inherit;font-size:15px;padding:13px 15px;border:1px solid var(--line);border-radius:12px;background:#fff;
  color:var(--ink);outline:none;transition:.16s;width:100%;}
.field:focus{border-color:var(--green-300);box-shadow:0 0 0 4px var(--soft);}
.vp__input{flex:1;}
.vp__examples{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:14px;font-size:13px;color:var(--ink-3);}
.chip{font-family:inherit;font-size:13px;font-weight:600;color:var(--ink-2);background:var(--bg-2);border:1px solid var(--line);
  border-radius:999px;padding:7px 13px;cursor:pointer;transition:.16s;}
.chip:hover{border-color:var(--green-300);color:var(--green-700);}
.chip--on{background:var(--green);border-color:var(--green);color:#fff;}
.chip--ghost{background:#fff;font-size:12.5px;}

.vr{margin-top:20px;border-radius:14px;padding:20px;border:1px solid var(--line);animation:rise .3s ease;}
@keyframes rise{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.vr--valid{background:var(--soft);border-color:var(--soft-2);}
.vr--warn{background:#fbf3ec;border-color:#ecd9c4;}
.vr--none{background:#fbf0f0;border-color:#f0d6d6;}
.vr__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;}
.vr__badge{display:inline-flex;align-items:center;gap:6px;background:var(--green);color:#fff;font-weight:700;font-size:13px;padding:6px 12px;border-radius:999px;}
.vr__badge--warn{background:var(--warn);}
.vr__badge--none{background:var(--danger);}
.vr__id{font-size:13px;color:var(--ink-3);font-weight:600;}
.vr__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 24px;}
.vr__grid dt{font-size:12px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em;font-weight:700;}
.vr__grid dd{margin:2px 0 0;font-size:15px;font-weight:600;}
.vr__msg{margin:0;font-size:14.5px;color:var(--ink-2);}

.sp__search{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:12px;padding:0 14px;background:#fff;}
.sp__search:focus-within{border-color:var(--green-300);box-shadow:0 0 0 4px var(--soft);}
.sp__search .field{border:none;padding:13px 0;box-shadow:none;}
.sp__chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;}
.sp__count{font-size:13px;color:var(--ink-3);margin:16px 2px 10px;font-weight:600;}
.sp__list{display:flex;flex-direction:column;gap:8px;max-height:330px;overflow:auto;padding-right:4px;}
.course{display:flex;align-items:center;justify-content:space-between;gap:16px;border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;background:#fff;transition:.14s;text-align:left;}
.course:hover{border-color:var(--green-300);background:var(--bg-2);}
.course__title{font-weight:700;font-size:15px;}
.course__meta{font-size:13px;color:var(--ink-3);margin-top:2px;}
.course__side{display:flex;align-items:center;gap:14px;flex:none;}
.course__cat{font-size:12px;color:var(--green-700);background:var(--soft);border-radius:999px;padding:5px 11px;font-weight:600;white-space:nowrap;}
.course__pts{font-size:13px;color:var(--ink-2);white-space:nowrap;}
.sp__empty{padding:24px;text-align:center;color:var(--ink-3);font-size:14px;}

/* ---------- two-col verify section ---------- */
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:start;}
.split--center{align-items:center;}
.split__lead{font-size:17px;color:var(--ink-2);margin:0 0 22px;}

/* ---------- directory page ---------- */
.dir{display:grid;grid-template-columns:260px 1fr;gap:36px;align-items:start;}
.dir__filters{position:sticky;top:90px;}
.fgroup{margin-bottom:26px;}
.fgroup h4{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);margin:0 0 12px;}
.fopt{display:flex;align-items:center;gap:10px;padding:7px 0;font-size:14.5px;color:var(--ink-2);cursor:pointer;}
.fopt input{accent-color:var(--green);width:16px;height:16px;}
.fopt .cnt{margin-left:auto;font-size:12px;color:var(--ink-3);background:var(--bg-2);border-radius:6px;padding:2px 7px;}
.dir__toolbar{display:flex;align-items:center;gap:14px;margin-bottom:20px;}
.dir__results{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.cocard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px;display:flex;flex-direction:column;transition:.18s;}
.cocard:hover{border-color:var(--green-300);box-shadow:var(--shadow-md);transform:translateY(-2px);}
.cocard__top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;}
.cocard__cat{font-size:11.5px;color:var(--green-700);background:var(--soft);border-radius:999px;padding:5px 11px;font-weight:700;letter-spacing:.02em;}
.cocard__pts{text-align:right;}
.cocard__pts b{font-size:22px;font-weight:800;color:var(--green-700);display:block;line-height:1;}
.cocard__pts span{font-size:11px;color:var(--ink-3);}
.cocard__h{font-size:18px;font-weight:800;margin:0 0 6px;}
.cocard__prov{font-size:13.5px;color:var(--ink-3);margin:0 0 16px;}
.cocard__foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:16px;border-top:1px solid var(--line);
  font-size:13px;color:var(--ink-3);}
.cocard__rating{color:var(--sand-deep);font-weight:700;}

/* ---------- standards page ---------- */
.std{display:flex;gap:22px;align-items:flex-start;padding:28px 0;border-top:1px solid var(--line);}
.std__num{font-size:15px;font-weight:800;color:#fff;background:var(--green);width:40px;height:40px;border-radius:11px;
  display:grid;place-items:center;flex:none;}
.std__body h3{font-size:20px;margin:0 0 8px;font-weight:800;}
.std__body p{margin:0 0 14px;color:var(--ink-2);font-size:15.5px;}

/* ---------- pricing ---------- */
.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch;}
.price{background:#fff;border:1px solid var(--line);border-radius:20px;padding:32px;display:flex;flex-direction:column;}
.price--feature{border-color:var(--green);box-shadow:var(--shadow-md);position:relative;}
.price__flag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--green);color:#fff;font-size:12px;
  font-weight:700;padding:6px 14px;border-radius:999px;}
.price__name{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--green-700);}
.price__amt{font-size:42px;font-weight:800;margin:14px 0 2px;letter-spacing:-.03em;}
.price__amt small{font-size:16px;font-weight:600;color:var(--ink-3);}
.price__desc{font-size:14.5px;color:var(--ink-2);margin:0 0 22px;min-height:44px;}
.price .checklist{margin-bottom:26px;}
.price .btn{margin-top:auto;}

/* ---------- FAQ accordion ---------- */
.faq{border-top:1px solid var(--line);}
.faq__item{border-bottom:1px solid var(--line);}
.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;text-align:left;background:none;border:none;
  font-family:inherit;font-size:17px;font-weight:600;color:var(--ink);padding:22px 0;cursor:pointer;}
.faq__q:hover{color:var(--green-700);}
.faq__icon{width:24px;height:24px;flex:none;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;
  transition:.2s;color:var(--green-700);font-size:18px;}
.faq__item.open .faq__icon{transform:rotate(45deg);background:var(--green);color:#fff;border-color:var(--green);}
.faq__a{max-height:0;overflow:hidden;transition:max-height .28s ease;}
.faq__a-inner{padding:0 0 22px;color:var(--ink-2);font-size:15.5px;max-width:760px;}

/* ---------- forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.formrow{display:flex;flex-direction:column;gap:7px;}
.formrow--full{grid-column:1 / -1;}
.formrow label{font-size:13.5px;font-weight:600;color:var(--ink-2);}
.formrow textarea.field{resize:vertical;min-height:120px;font-family:inherit;}
.formnote{font-size:13px;color:var(--ink-3);margin-top:6px;}
.formcard{background:#fff;border:1px solid var(--line);border-radius:20px;padding:34px;box-shadow:var(--shadow-md);}
.formsuccess{text-align:center;padding:18px 0;}
.formsuccess__seal{margin:0 auto 18px;width:72px;height:72px;border-radius:50%;background:var(--soft);display:grid;place-items:center;}

/* ---------- dashboard / portal ---------- */
.dash{display:grid;grid-template-columns:236px 1fr;min-height:calc(100vh - 0px);}
.dash__side{background:#0f211b;color:rgba(255,255,255,.72);padding:24px 18px;position:sticky;top:0;height:100vh;}
.dash__brand{display:flex;align-items:center;gap:10px;margin-bottom:30px;padding:0 8px;}
.dash__brand .brand__name{color:#fff;}
.dash__nav{display:flex;flex-direction:column;gap:4px;}
.dash__nav a{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:11px;font-size:14.5px;color:rgba(255,255,255,.72);font-weight:500;}
.dash__nav a:hover{background:rgba(255,255,255,.07);color:#fff;}
.dash__nav a.on{background:var(--green);color:#fff;}
.dash__user{position:absolute;bottom:24px;left:18px;right:18px;display:flex;align-items:center;gap:11px;padding:10px;border-radius:12px;
  background:rgba(255,255,255,.06);}
.dash__avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#cfe0d5,#5aa17e);flex:none;}
.dash__main{padding:30px 34px 60px;background:var(--bg-2);}
.dash__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;}
.dash__title{font-size:26px;font-weight:800;margin:0;}
.dash__sub{font-size:14px;color:var(--ink-3);margin:4px 0 0;}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:26px;}
.kpi{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;}
.kpi__l{font-size:13px;color:var(--ink-3);}
.kpi__n{font-size:30px;font-weight:800;color:var(--ink);margin-top:6px;letter-spacing:-.02em;}
.kpi__d{font-size:12.5px;font-weight:600;margin-top:4px;}
.kpi__d.up{color:var(--green-700);}
.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px 24px;margin-bottom:20px;}
.panel__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.panel__head h3{font-size:17px;margin:0;font-weight:800;}
.dtable{width:100%;border-collapse:collapse;}
.dtable th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);font-weight:700;
  padding:0 14px 12px;border-bottom:1px solid var(--line);}
.dtable td{padding:14px;border-bottom:1px solid var(--line);font-size:14px;}
.dtable tr:last-child td{border-bottom:none;}
.dtable tr:hover td{background:var(--bg-2);}
.status{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;padding:5px 10px;border-radius:999px;}
.status--ok{background:var(--soft);color:var(--green-700);}
.status--review{background:#fbf3ec;color:var(--warn);}
.status--draft{background:#eef1f0;color:var(--ink-3);}
.dash__cols{display:grid;grid-template-columns:1.6fr 1fr;gap:20px;}

/* ---------- course detail ---------- */
.cdetail{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:start;}
.cdetail__aside{position:sticky;top:90px;}
.modlist{counter-reset:mod;list-style:none;padding:0;margin:0;}
.modlist li{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--line);align-items:flex-start;}
.modlist li::before{counter-increment:mod;content:counter(mod,decimal-leading-zero);font-weight:800;color:var(--green);font-size:14px;
  width:28px;flex:none;}
.modlist b{font-size:15.5px;}
.modlist span{font-size:13px;color:var(--ink-3);display:block;margin-top:2px;}
.buycard{background:#fff;border:1px solid var(--line);border-radius:20px;padding:26px;box-shadow:var(--shadow-md);}
.buycard__pts{display:flex;align-items:baseline;gap:8px;margin-bottom:6px;}
.buycard__pts b{font-size:38px;font-weight:800;color:var(--green-700);}
.buycard dl{display:grid;grid-template-columns:1fr auto;gap:10px 16px;margin:18px 0;font-size:14px;}
.buycard dt{color:var(--ink-3);}
.buycard dd{margin:0;font-weight:600;text-align:right;}

/* ---------- about / reviewers ---------- */
.people{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.person{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;}
.person__photo{aspect-ratio:1/1;}
.person__body{padding:20px;}
.person__name{font-size:17px;font-weight:800;margin:0;}
.person__role{font-size:13.5px;color:var(--green-700);font-weight:600;margin:2px 0 8px;}
.person__bio{font-size:13.5px;color:var(--ink-2);margin:0;}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start;}
.contactway{display:flex;gap:14px;padding:18px 0;border-bottom:1px solid var(--line);}
.contactway__icon{width:44px;height:44px;border-radius:12px;background:var(--soft);display:grid;place-items:center;flex:none;}
.contactway h4{margin:0 0 3px;font-size:15.5px;}
.contactway p{margin:0;font-size:14px;color:var(--ink-2);}

/* ---------- responsive ---------- */
@media(max-width:960px){
  .hero__grid,.split{grid-template-columns:1fr;gap:38px;}
}
@media(max-width:880px){
  .cdetail{grid-template-columns:1fr;}
  .cdetail__aside{position:static;}
  .contact-grid{grid-template-columns:1fr;gap:32px;}
  .prices{grid-template-columns:1fr;max-width:440px;margin:0 auto;}
}
@media(max-width:1000px){
  .dir{grid-template-columns:200px 1fr;gap:26px;}
  .people{grid-template-columns:repeat(3,1fr);}
  .kpis{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:820px){
  .dir{grid-template-columns:1fr;}
  .dir__filters{position:static;}
  .form-grid{grid-template-columns:1fr;}
  .dash{grid-template-columns:1fr;}
  .dash__side{display:none;}
  .dash__cols{grid-template-columns:1fr;}
  .people{grid-template-columns:1fr 1fr;}
}
@media(max-width:640px){
  .dir__results{grid-template-columns:1fr;}
  .people{grid-template-columns:1fr;}
  .kpis{grid-template-columns:1fr;}
  .vr__grid{grid-template-columns:1fr;}
  .demo__body{padding:20px;}
}


/* ============================================================
   CareCPD — static export additions (icons, seals, verify)
   ============================================================ */
.ic{display:inline-flex;align-items:center;justify-content:center;line-height:0;flex:none;}
[data-seal]{display:inline-flex;line-height:0;}

/* verify panel */
.vp__hint{font-size:13px;color:var(--ink-3);margin:12px 2px 0;}
.vp__result{margin-top:4px;}
.vp__result:empty{margin-top:0;}
.vr--loading{margin-top:20px;display:flex;align-items:center;gap:13px;background:var(--bg-2);border:1px solid var(--line);
  border-radius:14px;padding:18px 20px;color:var(--ink-2);font-size:14.5px;font-weight:600;}
.spinner{width:22px;height:22px;border-radius:50%;border:2.5px solid var(--soft-2);border-top-color:var(--green);
  animation:spin .7s linear infinite;flex:none;}
@keyframes spin{to{transform:rotate(360deg);}}
.vr--error{background:#fbf6ee;border-color:#ecdcc4;}
.vr__badge--error{background:var(--ink-3);}
.vr__grid dd{word-break:break-word;}
.vr__note{margin:14px 0 0;padding-top:13px;border-top:1px dashed var(--line-2);font-size:13px;color:var(--ink-3);}
.btn[disabled]{opacity:.62;cursor:default;transform:none!important;box-shadow:none;}
@media(prefers-reduced-motion:reduce){.spinner{animation-duration:1.4s;}}
