/* =============================================================================
   Food Hygiene Certificate — global stylesheet
   Hand-coded static rebuild. Design tokens pulled from the live site + mockup.
   Sections are ordered: tokens → base → layout → components → pages.
   ============================================================================= */

/* -----------------------------------------------------------------------------
   1. DESIGN TOKENS
   -------------------------------------------------------------------------- */
:root {
  --c-brand:        #00A4EE;  /* Primary CTA bright blue */
  --c-cart:         #2B7EE0;  /* Add to cart — denim blue */
  --c-brand-hover:  #008BCC;  /* CTA hover */
  --c-brand-dark:   #082A4D;  /* Hero / footer / headlines */
  --c-brand-soft:   #E1F4FD;  /* Tints, chips */
  --c-accent-green: #34A853;  /* Checkmarks, trust */
  --c-accent-soft:  #E6F5EC;
  --c-accent-orange:#F05022;  /* Secondary highlight */

  --c-ink:          #0D1B2A;
  --c-ink-soft:     #475467;
  --c-muted:        #8A94A6;
  --c-line:         #E6E8EE;
  --c-bg:           #ffffff;
  --c-bg-alt:       #F7F9FC;

  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --fs-display: clamp(2rem, 3.8vw, 3.25rem);
  --fs-h1:      clamp(1.625rem, 2.4vw, 2rem);
  --fs-h2:      clamp(1.25rem, 1.8vw, 1.5rem);
  --fs-body:    1rem;
  --fs-small:   0.875rem;
  --fs-xsmall:  0.75rem;

  /* spacing in rem so it scales with the root font-size (= px values at 16px root) */
  --s-1:0.25rem; --s-2:0.5rem; --s-3:0.75rem; --s-4:1rem;
  --s-5:1.5rem; --s-6:2rem; --s-7:3rem; --s-8:4rem; --s-9:6rem;

  --r-sm:6px; --r-md:10px; --r-lg:16px;
  --sh-sm: 0 1px 2px rgba(13,27,42,.04), 0 1px 3px rgba(13,27,42,.06);
  --sh-md: 0 6px 16px rgba(13,27,42,.06), 0 2px 4px rgba(13,27,42,.04);
  --sh-lg: 0 20px 40px rgba(13,27,42,.10);

  --container: 1200px;
  --ease: cubic-bezier(.2,.7,.2,1);
  --dur: 220ms;
  --nav-h: 84px;
}

/* -----------------------------------------------------------------------------
   2. BASE
   -------------------------------------------------------------------------- */
*,*::before,*::after { box-sizing: border-box; }
/* base scale nudges up on larger screens (≈+12.5%) so the site feels comfortable
   on big monitors without manual zoom; stays 16px on phones/tablets */
html { font-size: clamp(16px, 14px + 0.32vw, 18px); scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: 1.6;
  color: var(--c-ink);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
}
img,svg,video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
h1,h2,h3,h4,p { margin: 0; }
:focus-visible { outline: 3px solid var(--c-brand); outline-offset: 2px; border-radius: 3px; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *,*::before,*::after { animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
}

/* Accessibility helpers */
.sr-only {
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
.skip-link {
  position:absolute; left:var(--s-3); top:-60px; z-index:200;
  background:var(--c-brand-dark); color:#fff; padding:10px 16px;
  border-radius:var(--r-sm); font-weight:600; transition:top .2s var(--ease);
}
.skip-link:focus { top:var(--s-3); }

/* -----------------------------------------------------------------------------
   3. LAYOUT HELPERS
   -------------------------------------------------------------------------- */
.container { width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--s-5); }
.section { padding-block: var(--s-8); }
.section-head { margin-bottom: var(--s-6); max-width: 640px; }
.section-head.center { text-align:center; margin-inline:auto; }
.section-head h2 {
  font-size: var(--fs-h1); line-height:1.2; letter-spacing:-.015em;
  font-weight:700; margin: var(--s-2) 0 var(--s-3);
}
.section-head p { color: var(--c-ink-soft); font-size:1rem; }
.eyebrow {
  display:inline-block; font-size:var(--fs-xsmall); font-weight:600;
  color:var(--c-brand); letter-spacing:.08em; text-transform:uppercase;
}

/* Buttons */
.btn {
  display:inline-flex; align-items:center; gap:var(--s-2);
  padding:12px 20px; border-radius:var(--r-sm);
  font-weight:600; font-size:var(--fs-small);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease),
              transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  white-space:nowrap;
}
.btn-primary { background:var(--c-brand); color:#fff; box-shadow:var(--sh-sm); }
.btn-primary:hover { background:var(--c-brand-hover); transform:translateY(-1px); box-shadow:var(--sh-md); }
.btn-ghost { color:var(--c-ink); border:1px solid var(--c-line); background:#fff; }
.btn-ghost:hover { border-color:var(--c-ink); }
.btn-ghost-dark { background:transparent; color:#fff; border:1px solid rgba(255,255,255,.3); }
.btn-ghost-dark:hover { background:rgba(255,255,255,.1); }
.btn-sm { padding:8px 14px; font-size:var(--fs-xsmall); }
.btn-pill { border-radius:999px; justify-content:center; font-weight:700; padding:11px 22px; }
.btn-pill.btn-primary { background:var(--c-cart); box-shadow:0 4px 12px rgba(43,126,224,.30); }
.btn-pill.btn-primary:hover { background:#1E6AC9; }
.btn-outline { background:#fff; color:var(--c-cart); border:1.5px solid var(--c-cart); box-shadow:none; }
.btn-outline:hover { background:var(--c-cart); color:#fff; }

/* -----------------------------------------------------------------------------
   4. ANNOUNCEMENT BAR
   -------------------------------------------------------------------------- */
.announce {
  background:var(--c-brand-dark); color:#fff; padding:8px 0;
  font-size:var(--fs-xsmall); text-align:center; letter-spacing:.02em;
}
.announce a { text-decoration:underline; font-weight:600; }

/* -----------------------------------------------------------------------------
   5. HEADER / NAV
   -------------------------------------------------------------------------- */
.nav { position:sticky; top:0; z-index:50; background:#fff; border-bottom:1px solid var(--c-line); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; padding-block:var(--s-4); gap:var(--s-5); }
.logo { display:flex; align-items:center; gap:var(--s-3); line-height:1; }
.logo-img { display:block; height:52px; width:auto; max-width:100%; flex-shrink:0; }
.logo-img-light { height:60px; }
@media (max-width:640px){ .logo-img{ height:40px; } .logo-img-light{ height:48px; } }

.nav-links { display:none; gap:var(--s-6); font-size:var(--fs-small); color:var(--c-ink-soft); font-weight:500; align-items:center; }
.nav-links a { transition:color var(--dur) var(--ease); }
.nav-links a:hover { color:var(--c-ink); }
.nav-links .has-dropdown { position:relative; }
.nav-dropdown-toggle { display:inline-flex; align-items:center; gap:4px; font:inherit; color:inherit; font-weight:500; }
.nav-dropdown-toggle svg { transition:transform var(--dur) var(--ease); }
.nav-dropdown {
  position:absolute; top:100%; left:0; min-width:280px; background:#fff;
  border:1px solid var(--c-line); border-radius:var(--r-md);
  box-shadow:0 12px 32px rgba(13,27,42,.12), 0 2px 6px rgba(13,27,42,.06);
  padding:var(--s-2); margin-top:var(--s-3);
  opacity:0; visibility:hidden; transform:translateY(-4px);
  transition:opacity .15s var(--ease), transform .15s var(--ease), visibility .15s;
  display:flex; flex-direction:column; z-index:60;
}
.has-dropdown:hover .nav-dropdown,
.has-dropdown:focus-within .nav-dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.has-dropdown:hover .nav-dropdown-toggle svg { transform:rotate(180deg); }
.nav-dropdown a { display:block; padding:10px 12px; border-radius:var(--r-sm); color:var(--c-ink); font-size:var(--fs-small); font-weight:500; line-height:1.3; }
.nav-dropdown a:hover { background:var(--c-brand-soft); color:var(--c-brand-dark); }
.nav-dropdown a.is-finder { color:var(--c-brand); font-weight:600; }
.nav-dropdown-divider { height:1px; background:var(--c-line); margin:6px 4px; }

.nav-right { display:flex; align-items:center; gap:var(--s-4); }
.nav-phone { display:none; font-weight:600; color:var(--c-brand); font-size:var(--fs-small); }
.nav-cart {
  width:44px; height:44px; display:flex; align-items:center; justify-content:center;
  background:var(--c-brand-soft); border-radius:50%; color:var(--c-brand-dark);
  position:relative; transition:background var(--dur) var(--ease);
}
.nav-cart:hover { background:#D6E7F8; }
.nav-cart .count {
  position:absolute; top:-2px; right:-2px; background:#16B07A; color:#fff;
  font-size:11px; font-weight:700; min-width:20px; height:20px; padding:0 5px;
  border-radius:999px; display:flex; align-items:center; justify-content:center; border:2px solid #fff;
}
.nav-cart .count[hidden] { display:none; }

/* Mobile menu toggle */
.nav-toggle { display:inline-flex; flex-direction:column; justify-content:center; gap:5px; width:44px; height:44px; align-items:center; }
.nav-toggle span { width:22px; height:2px; background:var(--c-brand-dark); border-radius:2px; transition:transform var(--dur) var(--ease), opacity var(--dur) var(--ease); }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media (min-width:960px){
  .nav-links { display:flex; }
  .nav-phone { display:inline; }
  .nav-toggle { display:none; }
}

/* Mobile drawer nav */
.mobile-nav {
  position:fixed; inset:var(--nav-h) 0 0 0; z-index:49; background:#fff;
  padding:var(--s-5); overflow-y:auto;
  transform:translateX(100%); transition:transform .25s var(--ease);
  display:flex; flex-direction:column; gap:var(--s-2);
}
.mobile-nav.is-open { transform:translateX(0); }
.mobile-nav a { padding:14px 8px; border-bottom:1px solid var(--c-line); font-weight:600; color:var(--c-brand-dark); font-size:1.05rem; }
.mobile-nav .m-sub a { font-weight:500; font-size:.95rem; color:var(--c-ink-soft); padding-left:var(--s-4); border-bottom:1px dashed var(--c-line); }
.mobile-nav .m-finder { color:var(--c-brand); }
.mobile-nav .m-phone { margin-top:var(--s-4); color:var(--c-brand); }
@media (min-width:960px){ .mobile-nav{ display:none; } }

/* -----------------------------------------------------------------------------
   6. CART DRAWER
   -------------------------------------------------------------------------- */
.cart-overlay { position:fixed; inset:0; background:rgba(8,42,77,.5); z-index:99; opacity:0; visibility:hidden; transition:opacity .2s var(--ease), visibility .2s; }
.cart-overlay.is-open { opacity:1; visibility:visible; }
.cart-drawer {
  position:fixed; top:0; right:0; bottom:0; width:min(420px,92vw); z-index:100;
  background:#fff; box-shadow:-20px 0 50px rgba(8,42,77,.2);
  transform:translateX(100%); transition:transform .28s var(--ease);
  display:flex; flex-direction:column;
}
.cart-drawer.is-open { transform:translateX(0); }
.cart-head { display:flex; align-items:center; justify-content:space-between; padding:var(--s-5); border-bottom:1px solid var(--c-line); }
.cart-head h2 { font-size:1.125rem; font-weight:800; color:var(--c-brand-dark); }
.cart-close { width:36px; height:36px; display:flex; align-items:center; justify-content:center; border-radius:50%; color:var(--c-ink-soft); }
.cart-close:hover { background:var(--c-line); color:var(--c-ink); }
.cart-body { flex:1; overflow-y:auto; padding:var(--s-4) var(--s-5); }
.cart-empty { text-align:center; color:var(--c-ink-soft); padding:var(--s-7) var(--s-4); }
.cart-line { display:grid; grid-template-columns:56px 1fr auto; gap:var(--s-3); align-items:center; padding:var(--s-3) 0; border-bottom:1px solid var(--c-line); }
.cart-line img { width:56px; height:42px; object-fit:cover; border-radius:var(--r-sm); }
.cart-line-title { font-size:var(--fs-small); font-weight:700; color:var(--c-ink); line-height:1.3; }
.cart-line-meta { font-size:var(--fs-xsmall); color:var(--c-ink-soft); }
.cart-qty { display:inline-flex; align-items:center; border:1px solid var(--c-line); border-radius:999px; overflow:hidden; margin-top:4px; }
.cart-qty button { width:28px; height:28px; font-size:16px; color:var(--c-brand-dark); }
.cart-qty button:hover { background:var(--c-brand-soft); }
.cart-qty span { min-width:30px; text-align:center; font-weight:700; font-size:var(--fs-small); }
.cart-line-price { font-weight:700; color:var(--c-ink); font-size:var(--fs-small); }
.cart-remove { display:block; margin-top:6px; font-size:var(--fs-xsmall); color:var(--c-muted); text-decoration:underline; }
.cart-remove:hover { color:var(--c-accent-orange); }
.cart-foot { border-top:1px solid var(--c-line); padding:var(--s-5); }
.cart-summary { margin-bottom:var(--s-3); }
.cs-row { display:flex; justify-content:space-between; align-items:baseline; font-size:var(--fs-small); color:var(--c-ink-soft); padding:3px 0; }
.cs-row span:last-child { font-variant-numeric:tabular-nums; }
.cs-save { color:var(--c-accent-green); font-weight:600; }
.cs-total { margin-top:6px; padding-top:8px; border-top:1px solid var(--c-line); font-size:1.0625rem; font-weight:800; color:var(--c-brand-dark); }
.cart-note { font-size:var(--fs-xsmall); color:var(--c-ink-soft); margin-bottom:var(--s-4); }
.cart-checkout { width:100%; }

/* -----------------------------------------------------------------------------
   7. HERO
   -------------------------------------------------------------------------- */
.hero { background:var(--c-brand-dark); color:#fff; position:relative; overflow:hidden; }
.hero-container { max-width:var(--container); margin-inline:auto; padding-inline:var(--s-5); }
.hero-grid { display:grid; grid-template-columns:1fr; gap:0; align-items:stretch; min-height:520px; }
.hero-text { padding:var(--s-8) 0; display:flex; flex-direction:column; justify-content:center; max-width:620px; width:100%; }
.hero .eyebrow { color:var(--c-brand); font-size:.8125rem; margin-bottom:var(--s-4); font-weight:700; letter-spacing:.08em; }
.hero h1 { font-size:clamp(2.25rem,4.5vw,3.75rem); line-height:1.1; letter-spacing:-.025em; font-weight:800; color:#fff; margin:0 0 var(--s-5); }
.hero h1 .h1-levels { font-style:normal; color:var(--c-brand); font-weight:800; white-space:nowrap; }
.hero p.lede { font-size:1.0625rem; color:rgba(255,255,255,.82); max-width:500px; margin-bottom:var(--s-6); line-height:1.6; }
.hero-ctas { display:flex; flex-wrap:wrap; gap:var(--s-3); }
.btn-hero-primary {
  background:var(--c-brand); color:#fff; padding:14px 28px; border-radius:999px;
  font-weight:600; font-size:.9375rem; box-shadow:0 8px 24px rgba(0,164,238,.35);
  transition:all var(--dur) var(--ease); display:inline-flex; align-items:center; gap:var(--s-2);
}
.btn-hero-primary:hover { background:var(--c-brand-hover); transform:translateY(-1px); box-shadow:0 12px 28px rgba(0,164,238,.45); }
.btn-hero-ghost {
  background:#fff; color:var(--c-brand-dark); padding:14px 28px; border-radius:999px;
  font-weight:600; font-size:.9375rem; transition:all var(--dur) var(--ease);
  display:inline-flex; align-items:center; gap:var(--s-2);
}
.btn-hero-ghost:hover { background:var(--c-brand-soft); transform:translateY(-1px); }

.hero-visual-wrap { display:flex; align-items:center; justify-content:center; min-height:380px; position:relative; padding:var(--s-5) 0 var(--s-6); width:100%; min-width:0; }
.hero-visual-wrap::before { content:''; position:absolute; left:5%; right:5%; top:8%; bottom:8%; background:radial-gradient(ellipse at 50% 50%, rgba(0,164,238,.28) 0%, rgba(0,164,238,0) 60%); filter:blur(30px); z-index:0; pointer-events:none; }
@media (min-width:900px){
  .hero-grid { grid-template-columns:minmax(0,1fr) minmax(0,1fr); align-items:center; gap:var(--s-6); }
  .hero-text { padding:var(--s-9) var(--s-5) var(--s-9) 0; max-width:560px; }
  .hero-visual-wrap { min-height:600px; padding:var(--s-7) 0; }
}

/* Laptop mockup */
.laptop { width:100%; max-width:640px; position:relative; min-width:0; }
@media (max-width:899px){ .laptop{ max-width:560px; } }
.laptop .screen { background:#111827; border-radius:14px 14px 4px 4px; padding:14px; position:relative; box-shadow:0 30px 60px -15px rgba(0,0,0,.5); }
.laptop .screen .camera { width:5px; height:5px; background:#4B5563; border-radius:50%; position:absolute; top:5px; left:50%; transform:translateX(-50%); }
.laptop .ui { background:#fff; border-radius:6px; aspect-ratio:16/10; overflow:hidden; position:relative; color:var(--c-brand-dark); font-size:.72rem; }
.laptop .ui-top { background:#F3F4F6; padding:8px 12px; display:flex; align-items:center; gap:8px; border-bottom:1px solid #E5E7EB; }
.laptop .ui-top .dots { display:flex; gap:4px; }
.laptop .ui-top .dots span { width:9px; height:9px; border-radius:50%; background:#D1D5DB; }
.laptop .ui-top .url { flex:1; background:#fff; border-radius:4px; padding:4px 10px; font-size:.66rem; color:#6B7280; border:1px solid #E5E7EB; }
.laptop .ui-body { padding:14px; display:grid; grid-template-columns:minmax(0,120px) minmax(0,1fr); gap:12px; height:calc(100% - 34px); min-width:0; }
.laptop .ui-sidebar { background:var(--c-brand-dark); color:#fff; border-radius:6px; padding:12px 10px; font-size:.6rem; display:flex; flex-direction:column; gap:3px; }
.laptop .ui-sidebar .u-item { padding:6px 8px; border-radius:4px; }
.laptop .ui-sidebar .u-item.active { background:var(--c-brand); color:#fff; font-weight:600; }
.laptop .ui-main h3 { font-size:.82rem; font-weight:700; margin-bottom:6px; color:var(--c-brand-dark); }
.laptop .ui-main .progress-row { display:flex; justify-content:space-between; font-size:.6rem; color:#6B7280; margin-bottom:5px; }
.laptop .ui-main .progress-bar { background:#E5E7EB; height:5px; border-radius:99px; overflow:hidden; margin-bottom:10px; }
.laptop .ui-main .progress-bar span { display:block; height:100%; background:linear-gradient(90deg, var(--c-brand), #22C55E); width:72%; border-radius:99px; }
.laptop .ui-main .video-frame { aspect-ratio:16/9; background-size:cover; background-position:center; border-radius:5px; position:relative; margin-bottom:8px; }
.laptop .ui-main .video-frame::after { content:'▶'; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.4rem; background:rgba(0,0,0,.28); border-radius:5px; }
.laptop .ui-main .meta { display:flex; gap:8px; font-size:.6rem; color:#6B7280; }
.laptop .base { background:#374151; height:11px; border-radius:0 0 14px 14px; margin:0 -10px; position:relative; }
.laptop .base::after { content:''; position:absolute; top:0; left:50%; transform:translateX(-50%); width:70px; height:3px; background:#1F2937; border-radius:0 0 4px 4px; }
.laptop .floating-badge { position:absolute; top:-22px; right:-12px; background:#22C55E; color:#fff; padding:10px 18px; border-radius:999px; font-size:.8125rem; font-weight:700; box-shadow:0 10px 24px rgba(34,197,94,.4); z-index:3; transform:rotate(6deg); white-space:nowrap; }

/* -----------------------------------------------------------------------------
   8. TRUST BAR + TRUSTED-BY STRIP
   -------------------------------------------------------------------------- */
.trust-bar { background:#fff; border-bottom:1px solid #EEF2F6; padding-block:var(--s-5); }
.trust-grid { display:grid; grid-template-columns:1fr; gap:var(--s-4); }
.trust-item { display:flex; align-items:center; gap:14px; }
.trust-icon { width:44px; height:44px; border-radius:12px; background:var(--c-brand-soft); color:var(--c-brand-dark); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.trust-txt strong { display:block; font-size:1.125rem; font-weight:800; color:var(--c-brand-dark); line-height:1.1; margin-bottom:2px; letter-spacing:-.01em; }
.trust-txt span { font-size:.8125rem; color:var(--c-ink-soft); }
@media (min-width:720px){ .trust-grid{ grid-template-columns:repeat(2,1fr); gap:var(--s-5); } }
@media (min-width:1024px){ .trust-grid{ grid-template-columns:repeat(4,1fr); gap:var(--s-6); } }

.trusted-by { background:var(--c-bg-alt); padding-block:var(--s-7); }
.trusted-by .container { display:flex; flex-direction:column; align-items:center; gap:var(--s-4); }
.tb-label { font-size:.75rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--c-ink-soft); flex-shrink:0; }
.tb-row { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:var(--s-5) var(--s-6); width:100%; }
.tb-logo { height:44px; display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; }
.tb-logo img { max-height:100%; width:auto; max-width:160px; object-fit:contain; opacity:.8; transition:opacity var(--dur) var(--ease); }
.tb-logo:hover img { opacity:1; }
.tb-logo--tall { height:88px; }
@media (min-width:720px){ .trusted-by .container{ flex-direction:row; gap:var(--s-6); justify-content:space-between; } .tb-row{ width:auto; flex:1; justify-content:flex-end; } }

/* -----------------------------------------------------------------------------
   9. COURSES GRID
   -------------------------------------------------------------------------- */
.courses-grid { display:grid; grid-template-columns:1fr; gap:var(--s-4); }
@media (min-width:640px){ .courses-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .courses-grid{ grid-template-columns:repeat(3,1fr); } }
.course { border:1px solid var(--c-line); border-radius:var(--r-md); background:#fff; padding:var(--s-4); display:flex; flex-direction:column; position:relative; transition:box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.course:hover { box-shadow:var(--sh-md); transform:translateY(-3px); border-color:transparent; }
.course.is-popular { border:2px solid var(--c-brand); box-shadow:0 18px 40px -12px rgba(0,164,238,.25); transform:translateY(-4px); }
.course-popular { position:absolute; top:-14px; right:16px; z-index:3; background:linear-gradient(135deg,#FF6B35 0%,#F05022 100%); color:#fff; font-size:12px; font-weight:800; padding:8px 14px 8px 12px; border-radius:8px; letter-spacing:.06em; text-transform:uppercase; box-shadow:0 8px 20px rgba(240,80,34,.45), 0 0 0 3px rgba(255,255,255,.9); display:inline-flex; align-items:center; gap:6px; white-space:nowrap; animation:pop-pulse 2.4s ease-in-out infinite; }
.course-popular::before { content:'\2605'; color:#fff; font-size:14px; line-height:1; filter:drop-shadow(0 1px 2px rgba(0,0,0,.2)); }
@keyframes pop-pulse { 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-2px); } }
.course-thumb { position:relative; aspect-ratio:16/10; border-radius:var(--r-sm); margin-bottom:var(--s-3); overflow:hidden; background:var(--c-bg-alt); }
.course-thumb img { width:100%; height:100%; object-fit:cover; object-position:center; }
.course-chips { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:var(--s-3); }
.course-chip { display:inline-block; background:var(--c-brand-soft); color:var(--c-brand-dark); font-size:11px; font-weight:600; padding:3px 10px; border-radius:999px; letter-spacing:.02em; }
.course h3 { font-size:1.0625rem; font-weight:700; line-height:1.3; margin-bottom:var(--s-2); }
.course p { color:var(--c-ink-soft); font-size:var(--fs-small); margin-bottom:var(--s-4); flex-grow:1; }
.course-foot { display:flex; flex-direction:column; gap:var(--s-3); align-items:stretch; padding-top:var(--s-3); border-top:1px solid var(--c-line); }
.course-foot .course-price { align-self:flex-start; }
.course-btns { display:flex; flex-direction:column; gap:10px; }
.course-price { font-weight:700; font-size:1.125rem; color:var(--c-ink); }
.course-price span { font-size:12px; color:var(--c-muted); font-weight:500; }
.course-urgency { display:inline-flex; align-items:center; gap:8px; background:#FFF7E6; color:#B45309; padding:5px 10px; border-radius:999px; font-size:.75rem; font-weight:600; margin-bottom:10px; border:1px solid #FEE7B8; width:fit-content; }
.course-urgency .u-dot { width:7px; height:7px; background:#F59E0B; border-radius:50%; animation:u-pulse 1.6s infinite; }
@keyframes u-pulse { 0%,100%{ box-shadow:0 0 0 0 rgba(245,158,11,.6); } 50%{ box-shadow:0 0 0 6px rgba(245,158,11,0); } }

.quiz-card { border:1px dashed var(--c-line); border-radius:var(--r-md); padding:var(--s-5); background:var(--c-bg-alt); display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; min-height:100%; }
.quiz-card .icon { width:48px; height:48px; border-radius:50%; background:#fff; border:1px solid var(--c-line); display:flex; align-items:center; justify-content:center; font-size:20px; margin-bottom:var(--s-3); }
.quiz-card h3 { font-weight:700; margin-bottom:var(--s-2); font-size:1.0625rem; }
.quiz-card p { color:var(--c-ink-soft); font-size:var(--fs-small); margin-bottom:var(--s-4); }

/* -----------------------------------------------------------------------------
   10. COMPARISON TABLE
   -------------------------------------------------------------------------- */
.compare { border:1px solid var(--c-line); border-radius:var(--r-md); overflow:hidden; }
.compare-row { display:grid; grid-template-columns:1.2fr 1.2fr 1fr; padding:var(--s-4); border-top:1px solid var(--c-line); align-items:center; gap:var(--s-3); position:relative; }
.compare-row:first-child { border-top:0; }
.compare-head { background:var(--c-brand-dark); font-size:var(--fs-xsmall); font-weight:600; color:#fff; text-transform:uppercase; letter-spacing:.06em; }
.compare-row:not(.compare-head):nth-child(even){ background:#F6FAFE; }
.compare-row:not(.compare-head):hover{ background:#EAF4FC; }
.compare-row.is-popular { background:linear-gradient(90deg, rgba(0,164,238,.08) 0%, rgba(0,164,238,.02) 100%); border-left:4px solid var(--c-brand); padding-left:calc(var(--s-4) - 4px); }
.lvl-chip { display:inline-flex; align-items:center; font-weight:700; font-size:var(--fs-small); color:var(--c-ink); }
.compare-course { font-weight:700; font-size:var(--fs-small); }
.compare-who, .compare-meta { font-size:var(--fs-small); color:var(--c-ink-soft); }
.compare-price { font-weight:700; color:var(--c-ink); }
.compare-link { color:var(--c-brand); font-weight:600; font-size:var(--fs-small); }
.compare-link:hover { color:var(--c-brand-dark); }
@media (min-width:768px){ .compare-row{ grid-template-columns:.8fr 1.8fr .8fr .8fr .8fr; } }

/* -----------------------------------------------------------------------------
   11. TEAM PACKS + CONFIGURATOR MODAL
   -------------------------------------------------------------------------- */
.team-packs { background:linear-gradient(180deg,#F7FAFD 0%,#fff 100%); padding-block:var(--s-9); }
.tp-head { text-align:center; max-width:640px; margin:0 auto var(--s-7); }
.tp-head h2 { font-size:clamp(1.6rem,2.4vw + 1rem,2.2rem); color:var(--c-brand-dark); margin:var(--s-3) 0; letter-spacing:-.02em; line-height:1.15; }
.tp-head p { color:var(--c-muted); margin:0; font-size:1rem; }
.tp-head p strong { color:var(--c-ink); font-weight:700; }
.bulk-illus { display:flex; justify-content:center; margin-bottom:var(--s-4); }
.bulk-illus img { width:auto; max-width:170px; height:auto; }
.tp-tiers { display:grid; grid-template-columns:repeat(2,1fr); gap:var(--s-3); max-width:560px; margin:var(--s-5) auto 0; }
@media (min-width:640px){ .tp-tiers{ grid-template-columns:repeat(4,1fr); } }
.tp-tier { background:var(--c-brand-soft); border:1px solid #CDE9F8; border-radius:var(--r-md); padding:var(--s-3) var(--s-2); text-align:center; line-height:1.1; }
.tp-tier strong { display:block; font-size:1.25rem; font-weight:800; color:var(--c-brand-dark); letter-spacing:-.01em; }
.tp-tier span { display:block; font-size:.7rem; color:var(--c-muted); text-transform:uppercase; letter-spacing:.06em; margin-top:2px; }
.tp-tier em { display:block; font-style:normal; font-weight:700; font-size:.875rem; color:var(--c-brand); margin-top:6px; }
.tp-grid { display:grid; grid-template-columns:1fr; gap:var(--s-4); margin-bottom:var(--s-5); }
@media (min-width:720px){ .tp-grid{ grid-template-columns:repeat(3,1fr); } }
.tp-card { position:relative; background:#fff; border:1.5px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-5); display:flex; flex-direction:column; transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease); }
.tp-card:hover { border-color:var(--c-brand); box-shadow:0 20px 40px -24px rgba(0,164,238,.3); transform:translateY(-2px); }
.tp-card.is-popular { border-color:var(--c-brand); box-shadow:0 20px 40px -24px rgba(0,164,238,.3); }
.tp-popular-flag { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--c-brand); color:#fff; font-size:.7rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:5px 12px; border-radius:999px; white-space:nowrap; }
.tp-tier-name { font-size:.75rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--c-brand); margin-bottom:var(--s-2); }
.tp-seats { font-size:2rem; font-weight:800; color:var(--c-brand-dark); line-height:1; margin-bottom:4px; letter-spacing:-.02em; }
.tp-seats-sub { color:var(--c-muted); font-size:.9rem; margin-bottom:var(--s-4); }
.tp-price-row { display:flex; align-items:baseline; gap:var(--s-3); margin-bottom:var(--s-4); padding-bottom:var(--s-4); border-bottom:1px solid var(--c-line); }
.tp-price { font-size:1.8rem; font-weight:700; color:var(--c-brand-dark); letter-spacing:-.01em; }
.tp-price-old { text-decoration:line-through; color:var(--c-muted); font-size:1rem; }
.tp-save { margin-left:auto; background:rgba(52,168,83,.12); color:var(--c-accent-green); font-size:.78rem; font-weight:700; padding:4px 10px; border-radius:999px; }
.tp-includes { list-style:none; padding:0; margin:0 0 var(--s-5); display:grid; gap:var(--s-2); flex:1; }
.tp-includes li { display:flex; align-items:flex-start; gap:10px; font-size:.9rem; color:var(--c-ink); }
.tp-includes li svg { color:var(--c-accent-green); flex-shrink:0; margin-top:3px; }
.tp-btn { display:block; text-align:center; width:100%; background:var(--c-cart); color:#fff; padding:12px 18px; border-radius:999px; font-weight:600; font-size:.95rem; transition:background var(--dur) var(--ease), transform var(--dur) var(--ease); }
.tp-btn:hover { background:#1F6DCB; transform:translateY(-1px); }
.tp-card.is-popular .tp-btn { background:var(--c-brand); }
.tp-card.is-popular .tp-btn:hover { background:#0088CC; }

.tp-manager { background:linear-gradient(135deg,var(--c-brand-dark) 0%,#0B3A66 100%); color:#fff; border-radius:var(--r-lg); padding:var(--s-6); display:grid; grid-template-columns:1fr; gap:var(--s-5); align-items:center; position:relative; overflow:hidden; }
@media (min-width:900px){ .tp-manager{ grid-template-columns:1.3fr 1fr; gap:var(--s-7); padding:var(--s-7); } }
.tp-manager::after { content:''; position:absolute; top:-40%; right:-10%; width:400px; height:400px; background:radial-gradient(circle, rgba(0,164,238,.35) 0%, transparent 60%); pointer-events:none; }
.tp-manager-body { position:relative; z-index:1; }
.tp-manager-eyebrow { display:inline-block; font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--c-brand); background:rgba(0,164,238,.18); padding:5px 11px; border-radius:999px; margin-bottom:var(--s-3); }
.tp-manager h3 { font-size:clamp(1.4rem,1.8vw + 1rem,1.8rem); color:#fff; margin:0 0 var(--s-3); letter-spacing:-.02em; line-height:1.2; }
.tp-manager p { color:rgba(255,255,255,.82); margin:0 0 var(--s-4); line-height:1.55; }
.tp-manager-list { list-style:none; padding:0; margin:0 0 var(--s-5); display:grid; gap:8px; }
.tp-manager-list li { display:flex; align-items:flex-start; gap:10px; color:rgba(255,255,255,.9); font-size:.92rem; }
.tp-manager-list li svg { color:var(--c-brand); flex-shrink:0; margin-top:3px; }
.tp-manager-side { position:relative; z-index:1; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:var(--r-md); padding:var(--s-5); }
.tp-manager-mix { display:grid; grid-template-columns:auto 1fr; gap:var(--s-3); align-items:center; padding:var(--s-3) 0; border-bottom:1px dashed rgba(255,255,255,.15); }
.tp-manager-mix:last-of-type { border-bottom:none; }
.tp-manager-mix-count { font-size:1.8rem; font-weight:800; color:var(--c-brand); min-width:56px; line-height:1; }
.tp-manager-mix-course strong { display:block; color:#fff; font-size:.95rem; }
.tp-manager-mix-course span { color:rgba(255,255,255,.65); font-size:.8rem; }
.tp-manager-price { margin-top:var(--s-5); display:flex; align-items:baseline; gap:var(--s-3); padding-top:var(--s-4); border-top:1px solid rgba(255,255,255,.12); }
.tp-manager-price .p-now { font-size:1.8rem; font-weight:700; color:#fff; }
.tp-manager-price .p-old { text-decoration:line-through; color:rgba(255,255,255,.5); font-size:.95rem; }
.tp-manager-price .p-save { margin-left:auto; color:#7DD492; font-size:.85rem; font-weight:700; }
.tp-manager-btn { display:inline-flex; align-items:center; gap:8px; margin-top:var(--s-5); background:var(--c-brand); color:#fff; padding:13px 22px; border-radius:999px; font-weight:600; transition:background var(--dur) var(--ease), transform var(--dur) var(--ease); }
.tp-manager-btn:hover { background:#0088CC; transform:translateY(-1px); }
.tp-custom { text-align:center; color:var(--c-muted); font-size:.9rem; margin-top:var(--s-5); }
.tp-custom a { color:var(--c-brand); font-weight:600; }
.tp-custom a:hover { text-decoration:underline; }

/* Configurator modal */
.tpc-modal[hidden] { display:none; }
.tpc-modal { position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center; padding:var(--s-4); }
.tpc-backdrop { position:absolute; inset:0; background:rgba(8,42,77,.55); animation:tpcFadeIn .18s var(--ease); }
.tpc-panel { position:relative; width:100%; max-width:720px; max-height:90vh; background:#fff; border-radius:var(--r-lg); box-shadow:0 40px 80px rgba(8,42,77,.35); display:flex; flex-direction:column; overflow:hidden; animation:tpcSlideUp .22s var(--ease); }
@keyframes tpcFadeIn { from{ opacity:0 } to{ opacity:1 } }
@keyframes tpcSlideUp { from{ opacity:0; transform:translateY(12px) } to{ opacity:1; transform:translateY(0) } }
.tpc-header { display:flex; align-items:center; justify-content:space-between; padding:var(--s-5) var(--s-6); border-bottom:1px solid var(--c-line); }
.tpc-header h3 { font-size:1.25rem; font-weight:800; color:var(--c-brand-dark); letter-spacing:-.01em; }
.tpc-header p { margin:4px 0 0; color:var(--c-ink-soft); font-size:var(--fs-small); }
.tpc-close { width:36px; height:36px; display:flex; align-items:center; justify-content:center; border-radius:50%; color:var(--c-ink-soft); transition:background var(--dur) var(--ease); }
.tpc-close:hover { background:var(--c-line); color:var(--c-ink); }
.tpc-body { padding:var(--s-5) var(--s-6); overflow-y:auto; flex:1; }
.tpc-row { display:grid; grid-template-columns:1fr auto; align-items:center; gap:var(--s-4); padding:var(--s-3) 0; border-bottom:1px solid #F1F4F8; }
.tpc-row:last-child { border-bottom:0; }
.tpc-row-info strong { display:block; font-size:.95rem; font-weight:700; color:var(--c-ink); }
.tpc-row-info span { font-size:.8125rem; color:var(--c-ink-soft); }
.tpc-stepper { display:inline-flex; align-items:center; border:1px solid var(--c-line); border-radius:999px; overflow:hidden; }
.tpc-stepper button { width:36px; height:36px; background:#fff; font-size:18px; font-weight:600; color:var(--c-brand-dark); transition:background var(--dur) var(--ease); }
.tpc-stepper button:hover:not([disabled]){ background:var(--c-brand-soft); }
.tpc-stepper button[disabled]{ color:var(--c-line); cursor:not-allowed; }
.tpc-stepper input { width:56px; height:36px; border:0; border-left:1px solid var(--c-line); border-right:1px solid var(--c-line); text-align:center; font:inherit; font-weight:700; color:var(--c-ink); -moz-appearance:textfield; }
.tpc-stepper input::-webkit-outer-spin-button, .tpc-stepper input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.tpc-summary { background:#F6F9FC; border-top:1px solid var(--c-line); padding:var(--s-5) var(--s-6); }
.tpc-summary-grid { display:grid; grid-template-columns:1fr auto; gap:6px 16px; font-size:var(--fs-small); color:var(--c-ink-soft); }
.tpc-summary-grid .tpc-final-label, .tpc-summary-grid .tpc-final-value { color:var(--c-brand-dark); font-weight:800; font-size:1.25rem; padding-top:8px; border-top:1px dashed #D5DEE8; margin-top:4px; }
.tpc-summary-grid .tpc-value { text-align:right; color:var(--c-ink); font-weight:600; }
.tpc-summary-grid .tpc-save-row { color:var(--c-accent-green); font-weight:700; }
.tpc-tier-pill { display:inline-flex; align-items:center; gap:6px; background:var(--c-brand-soft); color:var(--c-brand-dark); padding:4px 10px; border-radius:999px; font-weight:700; font-size:.75rem; letter-spacing:.04em; text-transform:uppercase; }
.tpc-tier-hint { font-size:.8125rem; color:var(--c-ink-soft); margin-top:8px; }
.tpc-tier-hint strong { color:var(--c-brand-dark); }
.tpc-cta { width:100%; margin-top:var(--s-4); background:var(--c-brand); color:#fff; padding:14px 22px; border-radius:999px; font-weight:700; font-size:1rem; transition:background var(--dur) var(--ease), transform var(--dur) var(--ease); }
.tpc-cta:hover { background:#0088CC; transform:translateY(-1px); }
.tpc-cta[disabled]{ background:#C7D3E0; cursor:not-allowed; transform:none; }
@media (max-width:640px){ .tpc-header,.tpc-body,.tpc-summary{ padding-left:var(--s-5); padding-right:var(--s-5); } .tpc-row{ grid-template-columns:1fr; gap:var(--s-3); } .tpc-stepper{ justify-self:start; } }

/* -----------------------------------------------------------------------------
   12. PILLAR + WHO NEEDS + ACCREDITATIONS
   -------------------------------------------------------------------------- */
.pillar { background:var(--c-bg-alt); }
.pillar-grid { display:grid; grid-template-columns:1fr; gap:var(--s-6); }
@media (min-width:900px){ .pillar-grid{ grid-template-columns:1.3fr 1fr; gap:var(--s-7); } }
.pillar-body h2 { font-size:var(--fs-h1); line-height:1.2; letter-spacing:-.015em; font-weight:700; margin:var(--s-2) 0 var(--s-4); }
.pillar-body p { color:var(--c-ink-soft); margin-bottom:var(--s-4); }
.pillar-body a { color:var(--c-brand); font-weight:500; }
.pillar-body a:hover { color:var(--c-brand-dark); text-decoration:underline; }
.pillar-card { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-md); padding:var(--s-6) var(--s-5); display:flex; flex-direction:column; justify-content:center; height:100%; }
.pillar-card h3 { font-size:1.0625rem; font-weight:800; color:var(--c-ink); margin-bottom:var(--s-4); padding-bottom:var(--s-3); border-bottom:1px solid var(--c-line); }
.check-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:14px; }
.check-list li { display:flex; gap:var(--s-3); align-items:center; font-size:var(--fs-small); color:var(--c-ink); font-weight:500; }
.check-list .tick { flex-shrink:0; width:22px; height:22px; border-radius:50%; background:rgba(52,168,83,.12); color:var(--c-accent-green); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:800; }

.who-grid { display:grid; grid-template-columns:1fr; gap:var(--s-3); }
@media (min-width:640px){ .who-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .who-grid{ grid-template-columns:repeat(3,1fr); } }
.who-card { background:#EAF2FA; border:1px solid #D4E4F2; border-radius:var(--r-md); padding:var(--s-5); transition:background var(--dur) var(--ease), border-color var(--dur) var(--ease), transform var(--dur) var(--ease); }
.who-card:hover { border-color:var(--c-brand); background:var(--c-brand-soft); transform:translateY(-2px); }
.who-card h3 { font-size:.9375rem; font-weight:700; margin-bottom:var(--s-2); }
.who-card p { color:var(--c-ink-soft); font-size:var(--fs-small); margin:0; }

.accred-section { background:var(--c-brand-dark); padding-block:var(--s-7); }
.accred-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:var(--s-3); }
@media (min-width:640px){ .accred-grid{ grid-template-columns:repeat(4,1fr); } }
/* Definite height (not aspect-ratio) so the logos' percentage max-height resolves
   on iOS Safari — with aspect-ratio the cards' height is indefinite there and the
   images collapse to 0. */
.accred-card { height:104px; background:#fff; border:1px solid var(--c-line); border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; padding:var(--s-4); }
@media (min-width:640px){ .accred-card{ height:150px; } }
.accred-card img { max-width:82%; max-height:82%; width:auto; height:auto; object-fit:contain; }

/* -----------------------------------------------------------------------------
   13. CERTIFICATE PREVIEW
   -------------------------------------------------------------------------- */
.cert-preview { background:linear-gradient(180deg,#F4F7FA 0%,#fff 100%); }
.cp-grid { display:grid; grid-template-columns:1fr; gap:var(--s-6); align-items:center; }
@media (min-width:900px){ .cp-grid{ grid-template-columns:1fr 1.1fr; gap:var(--s-7); } }
.cp-copy .eyebrow { color:var(--c-brand); font-weight:700; font-size:.8125rem; letter-spacing:.14em; margin-bottom:var(--s-3); display:block; }
.cp-copy h2 { font-size:clamp(1.75rem,3vw,2.25rem); line-height:1.2; font-weight:800; color:var(--c-brand-dark); letter-spacing:-.015em; margin-bottom:var(--s-4); }
.cp-copy > p { color:var(--c-ink-soft); font-size:1rem; line-height:1.6; margin-bottom:var(--s-5); max-width:520px; }
.cp-list { list-style:none; padding:0; margin:0 0 var(--s-5); }
.cp-list li { display:flex; align-items:flex-start; gap:12px; padding:8px 0; font-size:.9375rem; color:var(--c-ink); }
.cp-tick { display:inline-flex; align-items:center; justify-content:center; width:22px; height:22px; flex-shrink:0; background:var(--c-accent-soft); color:var(--c-accent-green); border-radius:50%; font-weight:800; font-size:.75rem; margin-top:1px; }
.cp-visual { display:flex; justify-content:center; position:relative; padding:var(--s-4); }
.cp-cert { width:100%; max-width:560px; background:#fff; border-radius:6px; padding:14px; box-shadow:0 30px 70px -20px rgba(0,0,0,.3), 0 0 0 1px rgba(0,0,0,.05); position:relative; transform:rotate(-2deg); transition:transform .3s var(--ease); color:#1a2232; }
.cp-cert:hover { transform:rotate(0deg); }
.cp-cert-border { border:3px double #C9AA58; border-radius:4px; padding:20px 22px 18px; display:flex; flex-direction:column; background:radial-gradient(circle at top right, rgba(0,164,238,.04), transparent 40%), radial-gradient(circle at bottom left, rgba(201,170,88,.05), transparent 40%), #fff; position:relative; }
.cp-cert-top { display:flex; justify-content:space-between; align-items:flex-start; padding-bottom:10px; border-bottom:1px solid #F0E8D0; }
.cp-cert-logo-img { height:44px; width:auto; max-width:160px; object-fit:contain; }
.cp-cert-ref { font-size:.55rem; color:#6B7280; text-align:right; line-height:1.2; letter-spacing:.05em; text-transform:uppercase; }
.cp-cert-ref strong { display:block; color:#1a2232; font-size:.7rem; font-weight:700; font-family:monospace; letter-spacing:.1em; }
.cp-cert-body { flex:1; display:flex; flex-direction:column; justify-content:center; align-items:center; text-align:center; padding:8px 0; }
.cp-cert-eyebrow { font-family:Georgia, serif; font-style:italic; color:#C9AA58; font-size:.75rem; letter-spacing:.15em; text-transform:uppercase; margin-bottom:4px; }
.cp-cert-hint { font-size:.65rem; color:#6B7280; margin-bottom:4px; }
.cp-cert-hint.small { font-size:.6rem; margin-top:4px; }
.cp-cert-name { font-family:Georgia, serif; font-size:1.5rem; font-weight:700; color:#1a2232; margin:4px 0; letter-spacing:-.01em; border-bottom:1px solid #E5EAF0; padding-bottom:6px; padding-inline:40px; }
.cp-cert-course { font-family:Georgia, serif; font-size:1.1rem; font-weight:600; color:var(--c-brand-dark); margin:8px 0 2px; }
.cp-cert-sign { display:grid; grid-template-columns:1fr 1fr; gap:20px; width:100%; margin-top:auto; padding-top:12px; align-items:end; }
.cp-cert-sign-col { text-align:center; }
.cp-cert-sig { font-family:'Brush Script MT', cursive, serif; font-size:1rem; color:#1a2232; padding-bottom:2px; }
.cp-cert-sig.cp-cert-sig-date { font-weight:600; font-size:.78rem; letter-spacing:.02em; font-family:var(--font-sans); }
.cp-cert-sig-line { border-top:1px solid #6B7280; margin-bottom:4px; }
.cp-cert-sig-label { font-size:.55rem; color:#6B7280; letter-spacing:.1em; text-transform:uppercase; }
.cp-cert-footer { display:flex; gap:12px; align-items:center; justify-content:center; margin-top:14px; }
.cp-badge-img { height:38px; width:auto; max-width:80px; object-fit:contain; }
.cp-download-chip { position:absolute; top:20px; right:-8px; background:var(--c-accent-green); color:#fff; padding:10px 16px; border-radius:999px; font-size:.8125rem; font-weight:700; box-shadow:0 10px 24px rgba(52,168,83,.4); z-index:2; transform:rotate(6deg); }

/* -----------------------------------------------------------------------------
   14. HOW IT WORKS
   -------------------------------------------------------------------------- */
.how-it-works { background:var(--c-brand-dark); color:#fff; position:relative; overflow:hidden; padding-block:var(--s-8); }
.how-it-works::before { content:''; position:absolute; top:-20%; right:-10%; width:600px; height:600px; background:radial-gradient(circle, rgba(0,164,238,.15), transparent 70%); pointer-events:none; }
.how-it-works::after { content:''; position:absolute; bottom:-30%; left:-5%; width:500px; height:500px; background:radial-gradient(circle, rgba(0,164,238,.08), transparent 70%); pointer-events:none; }
.how-it-works .container { position:relative; z-index:1; }
.hiw-head { text-align:center; max-width:720px; margin-inline:auto; margin-bottom:var(--s-7); }
.hiw-head .eyebrow { color:var(--c-brand); font-weight:700; font-size:.8125rem; letter-spacing:.14em; display:block; margin-bottom:var(--s-2); }
.hiw-head h2 { font-size:clamp(1.5rem,2.2vw + 1rem,2.25rem); line-height:1.15; font-weight:800; letter-spacing:-.015em; margin-bottom:var(--s-3); color:#fff; }
.hiw-intro { color:rgba(255,255,255,.8); font-size:1.0625rem; line-height:1.6; }
.hiw-grid { display:grid; grid-template-columns:1fr; gap:var(--s-4); position:relative; }
.hiw-step { background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)); border:1px solid rgba(255,255,255,.08); border-radius:16px; padding:var(--s-5) var(--s-5) var(--s-6); position:relative; transition:transform .25s var(--ease), border-color .25s var(--ease); }
.hiw-step:hover { transform:translateY(-4px); border-color:rgba(0,164,238,.35); }
.hiw-icon { width:56px; height:56px; border-radius:14px; background:linear-gradient(135deg, var(--c-brand), #0078B8); color:#fff; display:flex; align-items:center; justify-content:center; margin-bottom:var(--s-4); box-shadow:0 14px 30px -8px rgba(0,164,238,.5); }
.hiw-num { display:inline-block; font-size:.75rem; font-weight:700; letter-spacing:.12em; color:var(--c-brand); text-transform:uppercase; margin-bottom:var(--s-2); }
.hiw-step h3 { font-size:1.25rem; font-weight:700; line-height:1.3; margin-bottom:var(--s-3); color:#fff; }
.hiw-step p { color:rgba(255,255,255,.8); font-size:.9375rem; line-height:1.6; margin:0; }
@media (min-width:900px){
  .hiw-grid { grid-template-columns:repeat(3,1fr); gap:var(--s-4); }
  .hiw-grid::before { content:''; position:absolute; top:calc(var(--s-5) + 28px); left:16%; right:16%; height:2px; background:repeating-linear-gradient(90deg, rgba(0,164,238,.35) 0 8px, transparent 8px 14px); z-index:0; pointer-events:none; }
  .hiw-step { z-index:1; }
}

/* -----------------------------------------------------------------------------
   15. FAQ (semantic <details>)
   -------------------------------------------------------------------------- */
.faq-list { display:flex; flex-direction:column; gap:var(--s-3); }
.faq-item { border:0; border-radius:10px; overflow:hidden; background:transparent; }
.faq-item > summary { display:flex; justify-content:space-between; align-items:center; gap:var(--s-3); padding:16px 22px; background:#EAF2FA; color:var(--c-brand-dark); font-weight:600; font-size:.9375rem; line-height:1.4; cursor:pointer; border-radius:8px; transition:background var(--dur) var(--ease); list-style:none; }
.faq-item > summary::-webkit-details-marker { display:none; }
.faq-item > summary:hover { background:#DBE8F5; }
.faq-item > summary .icon { color:var(--c-brand-dark); font-size:20px; line-height:1; flex-shrink:0; transition:transform var(--dur) var(--ease); opacity:.7; }
.faq-item[open] > summary .icon { transform:rotate(45deg); }
.faq-item[open] > summary { border-radius:8px 8px 0 0; }
.faq-answer { padding:18px 22px; color:var(--c-ink-soft); font-size:var(--fs-small); line-height:1.6; background:#fff; border:1px solid #EEF2F6; border-top:0; border-radius:0 0 10px 10px; }
.faq-answer p { margin-bottom:var(--s-3); }
.faq-answer p:last-child { margin-bottom:0; }
.faq-footer { margin-top:var(--s-6); padding:var(--s-4) var(--s-5); background:#EAF2FA; border-radius:12px; text-align:center; font-size:.9375rem; color:var(--c-ink-soft); }
.faq-footer a { color:var(--c-brand-dark); font-weight:600; border-bottom:1.5px solid var(--c-brand); }
.faq-footer a:hover { color:var(--c-brand); }

/* -----------------------------------------------------------------------------
   16. FINAL CTA
   -------------------------------------------------------------------------- */
.final-cta { padding-block:var(--s-8); }
.final-cta-card { background:var(--c-brand-dark); color:#fff; border-radius:var(--r-lg); padding:var(--s-7) var(--s-6); position:relative; overflow:hidden; display:grid; grid-template-columns:180px 1fr; align-items:center; gap:var(--s-6); }
.final-cta-card::before { content:''; position:absolute; top:-40%; left:-10%; width:400px; height:400px; background:radial-gradient(circle, rgba(24,95,165,.5), transparent 70%); z-index:0; pointer-events:none; }
.cta-illus { position:relative; z-index:1; display:flex; align-items:center; justify-content:center; }
.cta-illus img { width:100%; max-width:160px; height:auto; opacity:.35; filter:brightness(0) invert(1); transform:rotate(-6deg); }
.cta-copy { position:relative; z-index:1; text-align:left; }
.cta-copy .eyebrow { color:#8BB8E4; }
.cta-copy h2 { font-size:var(--fs-h1); line-height:1.2; letter-spacing:-.015em; margin-bottom:var(--s-3); }
.cta-copy p { opacity:.85; max-width:620px; margin:0 0 var(--s-5) 0; }
.cta-copy .btn-group { display:flex; gap:var(--s-3); flex-wrap:wrap; }
.cta-copy .btn-white { background:#fff; color:var(--c-brand-dark); }
@media (max-width:768px){
  .final-cta-card { grid-template-columns:1fr; text-align:center; padding:var(--s-6) var(--s-5); gap:var(--s-4); }
  .cta-illus img { max-width:90px; opacity:.28; }
  .cta-copy { text-align:center; }
  .cta-copy p { margin:0 auto var(--s-5); }
  .cta-copy .btn-group { justify-content:center; }
}

/* -----------------------------------------------------------------------------
   17. FOOTER
   -------------------------------------------------------------------------- */
footer.site-footer { background:var(--c-brand-dark); color:rgba(255,255,255,.72); padding-block:var(--s-7) var(--s-5); font-size:var(--fs-small); }
.foot-grid { display:grid; gap:var(--s-6); grid-template-columns:1fr; margin-bottom:var(--s-6); }
@media (min-width:768px){ .foot-grid{ grid-template-columns:2fr 1fr 1fr 1fr; } }
.foot-col h2 { color:#fff; font-size:var(--fs-small); text-transform:uppercase; letter-spacing:.06em; margin-bottom:var(--s-3); font-weight:700; }
.foot-col ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:var(--s-2); }
.foot-col a:hover { color:#fff; }
.foot-intro { max-width:340px; }
.foot-contact { margin-top:var(--s-4); }
.foot-contact a { color:#fff; font-weight:600; }
.foot-bottom { border-top:1px solid rgba(255,255,255,.12); padding-top:var(--s-4); display:flex; justify-content:space-between; flex-wrap:wrap; gap:var(--s-3); font-size:var(--fs-xsmall); }
.foot-bottom a:hover { color:#fff; text-decoration:underline; }

/* -----------------------------------------------------------------------------
   18. STICKY SCROLL CTA
   -------------------------------------------------------------------------- */
.sticky-cta { position:fixed; right:20px; bottom:20px; z-index:90; background:#fff; border-radius:999px; box-shadow:0 20px 50px -10px rgba(0,0,0,.25), 0 0 0 1px rgba(0,0,0,.05); padding:10px 10px 10px 20px; display:flex; align-items:center; transform:translateY(140%); opacity:0; transition:transform .35s var(--ease), opacity .35s var(--ease); max-width:calc(100vw - 40px); }
.sticky-cta.is-visible { transform:translateY(0); opacity:1; }
.sticky-cta-inner { display:flex; align-items:center; gap:16px; }
.sticky-cta-left { display:flex; flex-direction:column; line-height:1.15; }
.sticky-cta-price { font-weight:800; font-size:.9375rem; color:var(--c-brand-dark); }
.sticky-cta-sub { font-size:.6875rem; color:var(--c-ink-soft); letter-spacing:.01em; }
.sticky-cta-btn { padding:10px 18px; font-size:.8125rem; white-space:nowrap; }
@media (max-width:480px){ .sticky-cta{ right:12px; bottom:12px; padding:8px 8px 8px 14px; } .sticky-cta-sub{ display:none; } .sticky-cta-btn{ padding:9px 14px; font-size:.75rem; } }
.scroll-anchor { scroll-margin-top:100px; }

/* -----------------------------------------------------------------------------
   19. BREADCRUMBS
   -------------------------------------------------------------------------- */
.breadcrumb { padding-block:var(--s-4); }
.breadcrumb ol { list-style:none; display:flex; flex-wrap:wrap; gap:8px; padding:0; margin:0; font-size:var(--fs-small); color:var(--c-ink-soft); align-items:center; }
.breadcrumb li { display:flex; align-items:center; gap:8px; }
.breadcrumb li::after { content:'/'; color:var(--c-muted); }
.breadcrumb li:last-child::after { content:none; }
.breadcrumb a { color:var(--c-brand); }
.breadcrumb a:hover { text-decoration:underline; }
.breadcrumb [aria-current="page"] { color:var(--c-ink-soft); }

/* -----------------------------------------------------------------------------
   20. PRODUCT PAGE
   -------------------------------------------------------------------------- */
.product-hero { padding-block:var(--s-6) var(--s-8); }
.product-grid { display:grid; grid-template-columns:1fr; gap:var(--s-6); align-items:start; }
@media (min-width:960px){ .product-grid{ grid-template-columns:1.4fr 1fr; gap:var(--s-7); } }
.product-media img { width:100%; max-height:300px; object-fit:cover; border-radius:var(--r-lg); border:1px solid var(--c-line); background:var(--c-bg-alt); }
.product-tags { display:flex; flex-wrap:wrap; gap:8px; margin:var(--s-4) 0; }
.product-tag { display:inline-flex; align-items:center; gap:6px; background:var(--c-brand-soft); color:var(--c-brand-dark); font-size:var(--fs-xsmall); font-weight:600; padding:5px 12px; border-radius:999px; }
.product-info h1 { font-size:clamp(1.75rem,3vw,2.5rem); line-height:1.15; letter-spacing:-.02em; color:var(--c-brand-dark); margin-bottom:var(--s-3); }
.product-lede { color:var(--c-ink-soft); font-size:1.0625rem; margin-bottom:var(--s-5); }
.product-accred-logos { display:flex; flex-wrap:wrap; gap:var(--s-4); align-items:center; margin-top:var(--s-5); }
.product-accred-logos img { height:54px; width:auto; object-fit:contain; }

.buy-box { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-5); box-shadow:var(--sh-md); position:sticky; top:calc(var(--nav-h) + 16px); max-height:calc(100vh - var(--nav-h) - 32px); overflow-y:auto; }
@media (max-width:959px){ .buy-box { position:static; max-height:none; overflow:visible; } }
.buy-price { display:flex; align-items:baseline; gap:8px; margin-bottom:var(--s-3); }
.buy-price .now { font-size:2rem; font-weight:800; color:var(--c-brand-dark); letter-spacing:-.02em; }
.buy-price .vat { font-size:var(--fs-small); color:var(--c-muted); }
.buy-price .buy-price-unit { font-size:var(--fs-small); color:var(--c-muted); }
.buy-points { list-style:none; padding:0; margin:0 0 var(--s-5); display:grid; gap:10px; }
.buy-points li { display:flex; align-items:flex-start; gap:10px; font-size:var(--fs-small); color:var(--c-ink); }
.buy-points li svg { color:var(--c-accent-green); flex-shrink:0; margin-top:2px; }
.buy-qty-row { display:flex; align-items:center; gap:var(--s-3); margin-bottom:var(--s-4); }
.qty-stepper { display:inline-flex; align-items:center; border:1px solid var(--c-line); border-radius:999px; overflow:hidden; }
.qty-stepper button { width:40px; height:40px; font-size:18px; color:var(--c-brand-dark); }
.qty-stepper button:hover { background:var(--c-brand-soft); }
.qty-stepper input { width:54px; height:40px; border:0; border-left:1px solid var(--c-line); border-right:1px solid var(--c-line); text-align:center; font:inherit; font-weight:700; -moz-appearance:textfield; }
.qty-stepper input::-webkit-outer-spin-button, .qty-stepper input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.buy-actions { display:grid; gap:10px; }
.buy-discount { display:flex; align-items:center; gap:8px; margin-top:var(--s-4); font-size:var(--fs-small); color:var(--c-ink-soft); }
.buy-discount svg { color:var(--c-brand); flex-shrink:0; }
/* Live total summary in the buy box */
.buy-summary { margin:var(--s-4) 0; padding:var(--s-3) 0; border-top:1px solid var(--c-line); display:grid; gap:6px; }
.bs-row { display:flex; justify-content:space-between; align-items:baseline; font-size:var(--fs-small); color:var(--c-ink-soft); }
.bs-row .bs-val { font-weight:600; color:var(--c-ink); }
.bs-save, .bs-save .bs-val { color:var(--c-accent-green); }
.bs-total { padding-top:6px; border-top:1px dashed var(--c-line); font-size:1rem; }
.bs-total span, .bs-total .bs-val { color:var(--c-brand-dark); }
.bs-total .bs-val { font-weight:800; }
/* Per-course bulk pricing tiers */
.tier-table { margin-top:var(--s-4); padding-top:var(--s-4); border-top:1px solid var(--c-line); display:grid; gap:6px; }
.tier-table-label { font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--c-muted); margin-bottom:2px; }
.tier-row { display:flex; align-items:center; justify-content:space-between; gap:var(--s-3); padding:9px 12px; border-radius:var(--r-sm); background:var(--c-bg-alt); border:1.5px solid transparent; transition:background var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.tier-row.is-active { background:var(--c-brand-soft); border-color:var(--c-brand); }
.tier-qty { display:flex; align-items:center; gap:8px; color:var(--c-ink); font-weight:600; font-size:var(--fs-small); }
.tier-qty svg { color:var(--c-brand); flex-shrink:0; }
.tier-val { text-align:right; white-space:nowrap; line-height:1.2; }
.tier-val b { color:var(--c-brand-dark); font-size:.9375rem; }
.tier-val .ea { color:var(--c-muted); font-weight:500; font-size:.8em; }
.tier-val .off { display:block; font-size:.72rem; color:var(--c-accent-green); font-weight:700; }
/* Fix: the .bs-row display:flex rule would otherwise override the [hidden] attribute */
.bs-row[hidden] { display:none; }
/* Collapsible bulk-pricing table inside the (now compact) sticky buy box */
.tier-details { margin-top:var(--s-4); }
.tier-details > summary { list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:8px; font-size:var(--fs-small); font-weight:600; color:var(--c-brand-dark); padding:10px 0; border-top:1px solid var(--c-line); }
.tier-details > summary::-webkit-details-marker { display:none; }
.tier-details .td-chev { color:var(--c-muted); transition:transform var(--dur) var(--ease); }
.tier-details[open] .td-chev { transform:rotate(180deg); }
.tier-details .tier-table { margin-top:var(--s-2); padding-top:0; border-top:0; }
.buy-fineprint { font-size:var(--fs-xsmall); color:var(--c-muted); margin-top:var(--s-3); }

/* Feature split: copy + illustration (product content sections) */
.feature-split { display:grid; grid-template-columns:1fr; gap:var(--s-6); align-items:center; }
@media (min-width:900px){ .feature-split { grid-template-columns:1.15fr .85fr; gap:var(--s-8); } .feature-split.media-left .feature-text { order:2; } .feature-split.media-left .feature-media { order:1; } }
.feature-media { display:flex; justify-content:center; }
.feature-media img { width:100%; max-width:360px; height:auto; }
.content-card { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-6); box-shadow:var(--sh-sm); }
.content-card ol, .content-card ul { padding-left:var(--s-5); }
/* Assessment card with certificate illustration */
.assess-card { display:grid; grid-template-columns:1fr; gap:var(--s-5); background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-6); box-shadow:var(--sh-sm); align-items:center; }
@media (min-width:720px){ .assess-card { grid-template-columns:170px 1fr; gap:var(--s-7); } }
.assess-media { display:flex; justify-content:center; }
.assess-media img { width:100%; max-width:170px; height:auto; }

.product-section { padding-block:var(--s-7); }
.product-section.alt { background:var(--c-bg-alt); }
.learn-grid { display:grid; grid-template-columns:1fr; gap:var(--s-3); }
@media (min-width:640px){ .learn-grid{ grid-template-columns:repeat(2,1fr); } }
.learn-item { display:flex; gap:12px; align-items:flex-start; background:#fff; border:1px solid var(--c-line); border-radius:var(--r-md); padding:var(--s-4); }
.learn-item svg { color:var(--c-accent-green); flex-shrink:0; margin-top:2px; }
.learn-item strong { display:block; font-size:var(--fs-small); }
/* Real "what you'll learn" list migrated from source: check-style bullets */
.learn-list ul { list-style:none; padding-left:0; margin:0; display:grid; gap:12px; }
@media (min-width:720px){ .learn-list ul { grid-template-columns:repeat(2,1fr); } }
.learn-list li { position:relative; padding-left:30px; color:var(--c-ink); }
.learn-list li::before { content:"✓"; position:absolute; left:0; top:0; width:20px; height:20px; display:flex; align-items:center; justify-content:center; background:var(--c-accent-soft); color:var(--c-accent-green); border-radius:50%; font-size:.7rem; font-weight:800; }

/* -----------------------------------------------------------------------------
   20b. RICH PRODUCT PAGE (Level 1 showcase) — spec grid, module accordion,
        team cards, benefit grid, callout. Reusable across products.
   -------------------------------------------------------------------------- */
/* Course at a glance */
.spec-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--c-line); border:1px solid var(--c-line); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-sm); margin:0; }
@media (min-width:640px){ .spec-grid{ grid-template-columns:repeat(4,1fr); } }
.spec-tile { background:#fff; padding:var(--s-4); display:flex; flex-direction:column; gap:6px; }
.spec-tile .spec-ico { color:var(--c-brand); width:22px; height:22px; }
.spec-tile dt { font-size:.7rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--c-muted); }
.spec-tile dd { margin:0; font-size:.95rem; font-weight:700; color:var(--c-brand-dark); line-height:1.25; }

/* Course content — numbered module accordion */
.module-list { display:grid; gap:var(--s-3); }
.module-item { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-md); box-shadow:var(--sh-sm); transition:border-color var(--dur) var(--ease); }
.module-item[open] { border-color:var(--c-brand); }
.module-item > summary { display:flex; gap:var(--s-3); align-items:center; padding:var(--s-4) var(--s-5); cursor:pointer; list-style:none; }
.module-item > summary::-webkit-details-marker { display:none; }
.module-num { flex-shrink:0; width:32px; height:32px; border-radius:9px; background:var(--c-brand-soft); color:var(--c-brand-dark); font-weight:800; font-size:.95rem; display:flex; align-items:center; justify-content:center; }
.module-head { flex:1; min-width:0; }
.module-title { display:block; font-size:1.0625rem; font-weight:700; color:var(--c-brand-dark); line-height:1.3; }
.module-sub { display:block; font-weight:400; color:var(--c-ink-soft); font-size:.875rem; margin-top:3px; }
.module-chev { flex-shrink:0; color:var(--c-muted); transition:transform var(--dur) var(--ease); }
.module-item[open] .module-chev { transform:rotate(180deg); }
.module-body { padding:0 var(--s-5) var(--s-5) calc(var(--s-5) + 32px + var(--s-3)); }
@media (max-width:560px){ .module-body { padding-left:var(--s-5); } }
.module-body .ms-label { font-size:.7rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--c-brand); margin:0 0 var(--s-2); }
.module-body ul { list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.module-body li { position:relative; padding-left:26px; color:var(--c-ink-soft); font-size:.925rem; line-height:1.5; }
.module-body li::before { content:""; position:absolute; left:2px; top:8px; width:7px; height:7px; border-radius:50%; background:var(--c-brand); }

/* Training your team — feature cards */
.team-grid { display:grid; grid-template-columns:1fr; gap:var(--s-4); }
@media (min-width:640px){ .team-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:980px){ .team-grid{ grid-template-columns:repeat(3,1fr); } }
.team-card { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-5); box-shadow:var(--sh-sm); transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.team-card:hover { transform:translateY(-2px); box-shadow:var(--sh-md); }
.team-ico { width:46px; height:46px; border-radius:12px; background:var(--c-brand-soft); color:var(--c-brand); display:flex; align-items:center; justify-content:center; margin-bottom:var(--s-3); }
.team-card h3 { font-size:1.0625rem; color:var(--c-brand-dark); margin-bottom:6px; }
.team-card p { color:var(--c-ink-soft); font-size:.925rem; margin:0; line-height:1.55; }

/* Why train with us — benefit grid */
.benefit-grid { display:grid; grid-template-columns:1fr; gap:var(--s-5); }
@media (min-width:640px){ .benefit-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:980px){ .benefit-grid{ grid-template-columns:repeat(3,1fr); } }
.benefit { display:flex; gap:var(--s-3); align-items:flex-start; }
.benefit .b-ico { flex-shrink:0; width:26px; height:26px; border-radius:50%; background:var(--c-accent-soft); color:var(--c-accent-green); display:flex; align-items:center; justify-content:center; margin-top:2px; }
.benefit b { display:block; color:var(--c-brand-dark); font-size:.975rem; margin-bottom:2px; }
.benefit span { color:var(--c-ink-soft); font-size:.9rem; line-height:1.5; }

/* Callout (e.g. choose-your-level note) */
.callout { display:flex; gap:var(--s-3); background:var(--c-brand-soft); border:1px solid #CDE9F8; border-left:4px solid var(--c-brand); border-radius:var(--r-md); padding:var(--s-4) var(--s-5); color:var(--c-ink); margin-top:var(--s-5); }
.callout .co-ico { flex-shrink:0; color:var(--c-brand); margin-top:2px; }
.callout p { margin:0; }
.callout strong { color:var(--c-brand-dark); }
.callout a { color:var(--c-brand); font-weight:600; text-decoration:underline; }

/* Certificate hero — show the whole certificate (no crop), with a soft frame */
.product-media.is-cert { background:transparent; border:0; box-shadow:none; }
.product-media.is-cert img { max-height:none; height:auto; object-fit:contain; border:1px solid var(--c-line); border-radius:var(--r-lg); background:#fff; box-shadow:var(--sh-md); }

/* Centered intro prose */
.prose.center { margin-inline:auto; text-align:center; }
.prose.center ul, .prose.center ol { text-align:left; }

/* -----------------------------------------------------------------------------
   20c. THANK-YOU / ORDER CONFIRMATION
   -------------------------------------------------------------------------- */
.ty-grid { display:grid; grid-template-columns:1fr; gap:var(--s-6); align-items:start; }
@media (min-width:860px){ .ty-grid{ grid-template-columns:1fr 1fr; gap:var(--s-7); } }
.ty-card { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-6); box-shadow:var(--sh-sm); }
.ty-summary h2, .ty-next h2 { font-size:1.375rem; color:var(--c-brand-dark); margin-bottom:var(--s-4); letter-spacing:-.01em; }
.ty-products { display:grid; gap:var(--s-3); }
.ty-loading { color:var(--c-ink-soft); }
.ty-prod { display:flex; align-items:center; gap:var(--s-3); padding-bottom:var(--s-3); border-bottom:1px solid var(--c-line); }
.ty-prod img { width:64px; height:48px; object-fit:cover; border-radius:var(--r-sm); border:1px solid var(--c-line); flex-shrink:0; background:var(--c-bg-alt); }
.ty-prod-info { flex:1; min-width:0; }
.ty-prod-name { font-weight:600; color:var(--c-ink); font-size:.95rem; line-height:1.3; }
.ty-prod-qty { font-size:var(--fs-small); color:var(--c-muted); }
.ty-note { font-size:var(--fs-xsmall); color:var(--c-accent-green); font-weight:600; margin-top:2px; }
.ty-price { text-align:right; white-space:nowrap; }
.ty-now { font-weight:700; color:var(--c-brand-dark); }
.ty-was { display:block; font-size:var(--fs-xsmall); color:var(--c-muted); text-decoration:line-through; }
.ty-totals { margin-top:var(--s-4); padding-top:var(--s-4); border-top:1px solid var(--c-line); }
.ty-row { display:flex; justify-content:space-between; align-items:baseline; }
.ty-grand { font-size:1.125rem; font-weight:800; color:var(--c-brand-dark); }
.ty-steps { list-style:none; padding:0; margin:0 0 var(--s-5); display:grid; gap:var(--s-3); }
.ty-steps li { display:flex; gap:10px; align-items:flex-start; color:var(--c-ink-soft); font-size:.95rem; line-height:1.5; }
.ty-steps li svg { color:var(--c-accent-green); flex-shrink:0; margin-top:3px; }
.ty-steps a { color:var(--c-brand); font-weight:600; text-decoration:underline; }
.ty-more p { color:var(--c-ink-soft); margin-bottom:var(--s-3); }

/* In-page section nav — sticks just below the main header */
.section-nav { position:sticky; top:var(--nav-h); z-index:40; background:rgba(255,255,255,.92); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); border-bottom:1px solid var(--c-line); }
.section-nav-inner { display:flex; gap:var(--s-1); overflow-x:auto; scrollbar-width:none; -ms-overflow-style:none; -webkit-overflow-scrolling:touch; }
.section-nav-inner::-webkit-scrollbar { display:none; }
.section-nav a { flex:0 0 auto; padding:13px 14px; font-size:.875rem; font-weight:600; color:var(--c-ink-soft); white-space:nowrap; border-bottom:2px solid transparent; transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.section-nav a:hover { color:var(--c-brand-dark); }
.section-nav a.is-current { color:var(--c-brand-dark); border-bottom-color:var(--c-brand); }
/* offset anchored headings so the two sticky bars don't cover them on jump */
.has-subnav :where(h1,h2)[id] { scroll-margin-top: calc(var(--nav-h) + 64px); }

/* Sticky bottom buy bar */
.buy-bar { position:fixed; left:0; right:0; bottom:0; z-index:80; background:#fff; border-top:1px solid var(--c-line); box-shadow:0 -8px 30px -12px rgba(8,42,77,.2); transform:translateY(110%); visibility:hidden; transition:transform .35s var(--ease), visibility .35s var(--ease); }
.buy-bar.is-visible { transform:translateY(0); visibility:visible; }
.buy-bar-inner { display:flex; align-items:center; justify-content:space-between; gap:var(--s-4); padding-block:11px; }
.buy-bar-info { display:flex; flex-direction:column; line-height:1.25; min-width:0; }
.buy-bar-title { font-weight:700; color:var(--c-brand-dark); font-size:.95rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.buy-bar-sub { font-size:.78rem; color:var(--c-ink-soft); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.buy-bar-actions { display:flex; align-items:center; gap:var(--s-3); flex-shrink:0; }
.buy-bar-price { font-weight:800; color:var(--c-brand-dark); font-size:1.0625rem; white-space:nowrap; }
.buy-bar-price .ea { font-weight:500; font-size:.75rem; color:var(--c-ink-soft); }
.buy-bar-btn { padding:11px 22px; white-space:nowrap; }
@media (max-width:560px){
  .buy-bar-info { display:none; }
  .buy-bar-actions { flex:1 1 auto; justify-content:space-between; gap:var(--s-3); }
  .buy-bar-price { font-size:1.125rem; }
  .buy-bar-btn { padding:12px 22px; font-size:.875rem; }
}

/* -----------------------------------------------------------------------------
   21. PROSE (legal / about / blog post)
   -------------------------------------------------------------------------- */
.page-header { background:var(--c-brand-dark); color:#fff; padding-block:var(--s-8); }
.page-header h1 { font-size:clamp(1.875rem,3.5vw,2.75rem); line-height:1.15; letter-spacing:-.02em; margin-bottom:var(--s-3); }
.page-header p { color:rgba(255,255,255,.82); max-width:640px; font-size:1.0625rem; }
.page-header .eyebrow { color:var(--c-brand); display:block; margin-bottom:var(--s-3); }
.prose { max-width:760px; }
.prose h2 { font-size:1.5rem; font-weight:700; color:var(--c-brand-dark); margin:var(--s-7) 0 var(--s-3); letter-spacing:-.01em; }
.prose h3 { font-size:1.1875rem; font-weight:700; color:var(--c-ink); margin:var(--s-5) 0 var(--s-2); }
.prose p { color:var(--c-ink-soft); margin-bottom:var(--s-4); }
.prose ul, .prose ol { color:var(--c-ink-soft); margin:0 0 var(--s-4); padding-left:var(--s-5); display:grid; gap:8px; }
.prose a { color:var(--c-brand); font-weight:500; text-decoration:underline; }
.prose a:hover { color:var(--c-brand-dark); }
.prose strong { color:var(--c-ink); }
.prose .lead { font-size:1.125rem; color:var(--c-ink); }
.prose hr { border:0; border-top:1px solid var(--c-line); margin:var(--s-6) 0; }
.prose-meta { color:var(--c-muted); font-size:var(--fs-small); margin-bottom:var(--s-5); }

/* -----------------------------------------------------------------------------
   22. CONTACT
   -------------------------------------------------------------------------- */
.contact-grid { display:grid; grid-template-columns:minmax(0,1fr); gap:var(--s-7); align-items:start; }
@media (min-width:900px){ .contact-grid{ grid-template-columns:minmax(0,1fr) minmax(0,1.2fr); } }
.contact-cards { display:grid; gap:var(--s-3); }
.contact-card { display:flex; gap:14px; align-items:flex-start; background:#fff; border:1px solid var(--c-line); border-radius:var(--r-md); padding:var(--s-5); }
.contact-card .ci { width:44px; height:44px; border-radius:12px; background:var(--c-brand-soft); color:var(--c-brand-dark); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact-card strong { display:block; color:var(--c-brand-dark); }
.contact-card a { color:var(--c-brand); font-weight:600; }
.contact-card > div { min-width:0; }
.contact-card a, .contact-card strong { overflow-wrap:anywhere; }
.form { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-6); box-shadow:var(--sh-sm); }
@media (max-width:560px){ .form { padding:var(--s-5) var(--s-3); } }   /* tighter horizontal padding so the ~300px Turnstile widget fits */
.form-row { margin-bottom:var(--s-4); }
.form-row.two { display:grid; grid-template-columns:1fr; gap:var(--s-4); }
@media (min-width:560px){ .form-row.two{ grid-template-columns:1fr 1fr; } }
.form label { display:block; font-weight:600; font-size:var(--fs-small); margin-bottom:6px; color:var(--c-ink); }
.form input, .form textarea, .form select { width:100%; padding:12px 14px; border:1px solid var(--c-line); border-radius:var(--r-sm); font:inherit; color:var(--c-ink); background:#fff; transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.form input:focus, .form textarea:focus, .form select:focus { border-color:var(--c-brand); box-shadow:0 0 0 3px rgba(0,164,238,.15); outline:none; }
.form textarea { min-height:140px; resize:vertical; }
.form .req { color:var(--c-accent-orange); }
.form-hint { font-size:var(--fs-xsmall); color:var(--c-muted); margin-top:var(--s-3); }
.cf-turnstile { margin:var(--s-4) 0; max-width:100%; overflow:hidden; }
.form-status { font-size:0.95rem; line-height:1.4; margin-top:var(--s-3); padding:0.75rem 1rem; border-radius:8px; }
.form-status.is-ok { background:#e8f6ec; color:#1b6b34; border:1px solid #b6e0c2; }
.form-status.is-err { background:#fdeaea; color:#9b1c1c; border:1px solid #f3c0c0; }

/* Support FAQ grid (contact page) */
.support-grid { display:grid; grid-template-columns:1fr; gap:var(--s-4); }
@media (min-width:640px){ .support-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .support-grid{ grid-template-columns:repeat(3,1fr); } }
.support-card { background:var(--c-bg-alt); border:1px solid var(--c-line); border-radius:var(--r-md); padding:var(--s-5); }
.support-card h3 { font-size:1rem; font-weight:700; color:var(--c-brand-dark); margin-bottom:var(--s-3); }
.support-card p { color:var(--c-ink-soft); font-size:var(--fs-small); margin-bottom:var(--s-3); }
.support-card p:last-child { margin-bottom:0; }
.support-card a { color:var(--c-brand); font-weight:600; word-break:break-word; }
.support-card a:hover { text-decoration:underline; }
.support-card strong { color:var(--c-ink); font-weight:700; }

/* -----------------------------------------------------------------------------
   BLOG ARTICLE (post) — TOC sidebar, lead paragraph, related
   -------------------------------------------------------------------------- */
.article-meta { display:flex; flex-wrap:wrap; gap:10px; align-items:center; color:rgba(255,255,255,.82); font-size:var(--fs-small); }
.article-meta .dot { opacity:.5; }

/* byline in the dark article header */
.article-byline { display:flex; align-items:center; gap:14px; margin-top:var(--s-5); }
.article-byline .ab-avatar { width:48px; height:48px; border-radius:50%; flex-shrink:0; border:2px solid rgba(255,255,255,.28); object-fit:cover; }
.article-byline .ab-line { margin:0; color:rgba(255,255,255,.8); font-size:.95rem; line-height:1.4; }
.article-byline .ab-line strong { color:#fff; font-weight:700; }
.article-byline .ab-line .dot { opacity:.5; }

/* reading progress bar */
.read-progress { position:fixed; top:0; left:0; right:0; height:3px; z-index:60; background:transparent; pointer-events:none; }
.read-progress-bar { height:100%; width:0; background:linear-gradient(90deg,var(--c-brand),var(--c-accent-green)); }

/* article hero: breadcrumb + title + byline on the left, featured image on the right */
.page-header.article-hero { padding-block:var(--s-9); }
.article-header-grid { display:grid; grid-template-columns:1fr; gap:var(--s-6); align-items:center; }
@media (min-width:900px){ .article-header-grid { grid-template-columns:1.15fr 0.85fr; gap:var(--s-8); } }
.article-header-media { margin:0; }
.article-header-media img { width:100%; height:auto; display:block; border-radius:16px; box-shadow:0 24px 60px -24px rgba(0,0,0,.6); }
/* breadcrumb sits inside the dark header */
.page-header .breadcrumb { padding-block:0; margin-bottom:var(--s-4); }
.page-header .breadcrumb a { color:rgba(255,255,255,.82); }
.page-header .breadcrumb a:hover { color:#fff; }
.page-header .breadcrumb [aria-current="page"] { color:rgba(255,255,255,.6); }
.page-header .breadcrumb li::after { color:rgba(255,255,255,.4); }
/* buttons must never inherit the prose link underline OR colour */
.btn, .prose a.btn, .prose .btn { text-decoration:none; }
.prose a.btn-primary { color:#fff; }

/* layout: wide article (left) · sidebar with TOC + course CTA (right) */
.article-layout { display:grid; grid-template-columns:1fr; gap:var(--s-6); align-items:start; }
@media (min-width:1000px){ .article-layout { grid-template-columns:minmax(0,1fr) 340px; gap:var(--s-7); } }
@media (min-width:1280px){ .article-page .container { max-width:1340px; } }
.article-aside { display:grid; gap:var(--s-5); }
@media (min-width:1000px){
  /* cap the sticky sidebar to the viewport; the course card stays fully visible,
     the TOC takes the remaining space and scrolls internally */
  .article-aside { position:sticky; top:calc(var(--nav-h) + 16px); max-height:calc(100vh - var(--nav-h) - 32px); display:flex; flex-direction:column; gap:var(--s-5); }
  .article-toc { min-height:0; display:flex; flex-direction:column; }
  .article-toc ol { min-height:0; max-height:none; }
  .aside-cta { flex:0 0 auto; }
}
/* on mobile the sidebar moves above the article — keep the compact TOC, hide the course CTA */
@media (max-width:999px){ .article-aside { order:-1; } .aside-cta { display:none; } }

/* table of contents (collapsible) */
.article-toc { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); box-shadow:var(--sh-sm); overflow:hidden; }
.article-toc > summary { list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:8px; padding:var(--s-4) var(--s-5); font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; color:var(--c-muted); font-weight:700; }
.article-toc > summary::-webkit-details-marker { display:none; }
.article-toc .toc-chev { transition:transform var(--dur) var(--ease); color:var(--c-muted); flex-shrink:0; }
.article-toc[open] .toc-chev { transform:rotate(180deg); }
@media (min-width:1000px){ .article-toc[open] > summary { border-bottom:1px solid var(--c-line); } }
.article-toc ol { list-style:none; margin:0; padding:var(--s-3) var(--s-4) var(--s-5); display:flex; flex-direction:column; gap:1px; max-height:max(180px, calc(100vh - var(--nav-h) - 320px)); overflow-y:auto; counter-reset:toc; }
.article-toc li:last-child { margin-bottom:var(--s-2); }
.article-toc li { counter-increment:toc; }
.article-toc a { display:block; position:relative; padding:7px 10px 7px 36px; color:var(--c-ink-soft); line-height:1.35; font-size:var(--fs-small); border-radius:var(--r-sm); transition:background var(--dur) var(--ease), color var(--dur) var(--ease); }
.article-toc a::before { content:counter(toc); position:absolute; left:8px; top:6px; width:20px; height:20px; font-size:.62rem; font-weight:700; display:flex; align-items:center; justify-content:center; border-radius:50%; background:var(--c-bg-alt); color:var(--c-muted); }
.article-toc a:hover { background:var(--c-bg-alt); color:var(--c-brand-dark); }
.article-toc a.is-current { background:var(--c-brand-soft); color:var(--c-brand-dark); font-weight:600; }
.article-toc a.is-current::before { background:var(--c-brand); color:#fff; }

/* sidebar course CTA */
.aside-cta { background:linear-gradient(160deg,var(--c-brand-dark),#0b3a66); color:#fff; border-radius:var(--r-lg); padding:var(--s-5); box-shadow:var(--sh-md); }
.aside-cta .ac-eyebrow { color:#8FD0F5; font-size:.7rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; margin-bottom:var(--s-2); }
.aside-cta h3 { color:#fff; font-size:1.05rem; line-height:1.25; margin-bottom:var(--s-3); letter-spacing:-.01em; }
.aside-cta ul { list-style:none; padding:0; margin:0 0 var(--s-4); display:grid; gap:7px; }
.aside-cta li { display:flex; gap:8px; align-items:flex-start; font-size:.82rem; color:rgba(255,255,255,.9); }
.aside-cta li svg { color:var(--c-accent-green); flex-shrink:0; margin-top:2px; }
.aside-cta .btn { width:100%; margin-bottom:7px; padding-block:10px; font-size:.85rem; }
.aside-cta .btn:last-child { margin-bottom:0; }
.aside-cta .btn-primary { background:#fff; color:var(--c-brand-dark); }
.aside-cta .btn-primary:hover { background:#eaf6fe; }
.aside-cta .btn-outline { background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.4); }
.aside-cta .btn-outline:hover { background:rgba(255,255,255,.12); color:#fff; }

/* article body */
.article-body { max-width:none; }
.article-body > p:first-of-type { font-size:1.1875rem; line-height:1.65; color:var(--c-ink); }
.article-body h2 { scroll-margin-top:calc(var(--nav-h) + 20px); font-size:1.6rem; margin-top:var(--s-8); }
.article-body h2::before { content:""; display:block; width:42px; height:3px; border-radius:3px; background:var(--c-brand); margin-bottom:var(--s-3); }
.article-body h3 { scroll-margin-top:calc(var(--nav-h) + 20px); }
/* custom list markers for body lists (not the stat grid) */
.article-body ul:not(.stat-grid) { list-style:none; padding-left:0; }
.article-body ul:not(.stat-grid) li { position:relative; padding-left:26px; }
.article-body ul:not(.stat-grid) li::before { content:""; position:absolute; left:5px; top:9px; width:7px; height:7px; border-radius:50%; background:var(--c-brand); }

/* tables */
.table-wrap { overflow-x:auto; margin:0 0 var(--s-5); border:1px solid var(--c-line); border-radius:var(--r-lg); -webkit-overflow-scrolling:touch; }
.article-body table { width:100%; border-collapse:collapse; font-size:.9rem; margin:0; }
.article-body th, .article-body td { padding:11px 14px; text-align:left; border-bottom:1px solid var(--c-line); }
.article-body thead th, .article-body tr:first-child th { background:var(--c-brand-dark); color:#fff; font-weight:700; font-size:.8rem; }
.article-body tbody tr:nth-child(even) { background:var(--c-bg-alt); }
.article-body tbody tr:last-child td { border-bottom:0; }

/* key-stats card grid (the overview list) */
.stat-grid { list-style:none !important; padding:0 !important; margin:0 0 var(--s-5) !important; display:grid !important; gap:var(--s-3) !important; grid-template-columns:1fr; }
@media (min-width:560px){ .stat-grid { grid-template-columns:1fr 1fr; } }
.stat-grid li { position:relative; padding:var(--s-4) var(--s-4) var(--s-4) var(--s-5) !important; background:#fff; border:1px solid var(--c-line); border-left:3px solid var(--c-brand); border-radius:var(--r-md); color:var(--c-ink); font-size:.95rem; line-height:1.5; box-shadow:var(--sh-sm); }
.stat-grid li::before { display:none !important; }

/* author bio card */
.author-bio { display:flex; gap:var(--s-4); align-items:flex-start; margin-top:var(--s-7); padding:var(--s-6); background:var(--c-bg-alt); border:1px solid var(--c-line); border-radius:var(--r-lg); }
.author-bio img { width:64px; height:64px; border-radius:50%; flex-shrink:0; border:2px solid #fff; box-shadow:var(--sh-sm); object-fit:cover; }
.author-bio .au-name { font-weight:800; color:var(--c-brand-dark); }
.author-bio .au-role { font-size:var(--fs-small); color:var(--c-brand); font-weight:600; margin-bottom:var(--s-2); }
.author-bio p { margin:0; color:var(--c-ink-soft); font-size:.95rem; line-height:1.6; }

/* inline bottom CTA */
.article-cta { margin-top:var(--s-7); padding:var(--s-6); background:var(--c-brand-soft); border:1px solid #CDE9F8; border-radius:var(--r-lg); text-align:center; }
.article-cta p { margin-bottom:var(--s-4); color:var(--c-brand-dark); font-weight:600; font-size:1.05rem; }

/* social share bar */
.share-bar { display:flex; align-items:center; gap:var(--s-4); flex-wrap:wrap; margin-top:var(--s-7); padding-top:var(--s-5); border-top:1px solid var(--c-line); }
.share-label { font-weight:700; color:var(--c-brand-dark); font-size:.95rem; }
.share-links { display:flex; gap:10px; flex-wrap:wrap; }
.share-btn { width:42px; height:42px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; border:1px solid var(--c-line); background:#fff; color:var(--c-brand-dark); cursor:pointer; text-decoration:none; transition:transform var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.share-btn svg { width:18px; height:18px; }
.share-btn:hover { transform:translateY(-2px); color:#fff; }
.share-fb:hover { background:#1877F2; border-color:#1877F2; }
.share-x:hover { background:#000; border-color:#000; }
.share-li:hover { background:#0A66C2; border-color:#0A66C2; }
.share-ig:hover { background:#E1306C; border-color:#E1306C; }
.share-copy:hover { background:var(--c-brand); border-color:var(--c-brand); }

/* -----------------------------------------------------------------------------
   TESTIMONIALS
   -------------------------------------------------------------------------- */
.testimonial-grid { display:grid; grid-template-columns:1fr; gap:var(--s-4); }
@media (min-width:768px){ .testimonial-grid { grid-template-columns:repeat(3,1fr); } }
.testimonial-card { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-5); display:flex; flex-direction:column; box-shadow:var(--sh-sm); }
.testimonial-stars { color:#F5A623; letter-spacing:3px; font-size:1rem; line-height:1; margin-bottom:var(--s-3); }
.testimonial-quote { color:var(--c-ink); font-size:1rem; line-height:1.6; margin:0 0 var(--s-5); flex:1; }
.testimonial-author { display:flex; align-items:center; gap:12px; }
.testimonial-avatar { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg, var(--c-brand), #0078B8); color:#fff; font-weight:700; font-size:.875rem; display:flex; align-items:center; justify-content:center; flex-shrink:0; letter-spacing:.02em; }
.testimonial-name { font-weight:700; color:var(--c-brand-dark); font-size:.9375rem; line-height:1.25; }
.testimonial-role { color:var(--c-muted); font-size:var(--fs-small); }

/* -----------------------------------------------------------------------------
   23. BLOG INDEX
   -------------------------------------------------------------------------- */
.blog-grid { display:grid; grid-template-columns:1fr; gap:var(--s-5); }
@media (min-width:640px){ .blog-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .blog-grid{ grid-template-columns:repeat(3,1fr); } }
.post-card { position:relative; display:flex; flex-direction:column; background:#fff; border:1px solid var(--c-line); border-radius:var(--r-md); overflow:hidden; transition:box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease); }
.post-card:hover { box-shadow:var(--sh-md); transform:translateY(-3px); }
/* Stretched link: the title anchor covers the whole card so the entire card (incl. "Read more") is clickable */
.post-card h2 a::after, .post-card h3 a::after { content:""; position:absolute; inset:0; z-index:1; }
.post-card:hover .post-more { text-decoration:underline; }
.post-card .post-body { padding:var(--s-5); display:flex; flex-direction:column; flex:1; }
.post-cat { font-size:var(--fs-xsmall); font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--c-brand); margin-bottom:var(--s-2); }
.post-card h2 { font-size:1.125rem; font-weight:700; line-height:1.3; color:var(--c-brand-dark); margin-bottom:var(--s-2); }
.post-card p { color:var(--c-ink-soft); font-size:var(--fs-small); flex:1; margin-bottom:var(--s-3); }
.post-card .post-more { color:var(--c-brand); font-weight:600; font-size:var(--fs-small); }
.post-thumb { display:block; aspect-ratio:3/2; overflow:hidden; background:var(--c-bg-alt); border-bottom:1px solid var(--c-line); }
.post-thumb img { width:100%; height:100%; object-fit:cover; display:block; }

/* -----------------------------------------------------------------------------
   24. QUIZ
   -------------------------------------------------------------------------- */
.quiz-wrap { max-width:720px; margin-inline:auto; }
.quiz-progress { height:8px; background:var(--c-line); border-radius:999px; overflow:hidden; margin-bottom:var(--s-6); }
.quiz-progress span { display:block; height:100%; background:linear-gradient(90deg, var(--c-brand), #22C55E); border-radius:999px; transition:width .3s var(--ease); width:33%; }
.quiz-screen { display:none; }
.quiz-screen.is-active { display:block; animation:tpcFadeIn .25s var(--ease); }
.quiz-step-label { font-size:var(--fs-xsmall); font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--c-brand); margin-bottom:var(--s-2); }
.quiz-screen h1, .quiz-screen h2 { font-size:clamp(1.4rem,2.4vw,1.875rem); color:var(--c-brand-dark); letter-spacing:-.01em; margin-bottom:var(--s-5); line-height:1.2; }
.quiz-options { display:grid; gap:var(--s-3); margin-bottom:var(--s-6); }
.quiz-option { position:relative; display:flex; gap:var(--s-3); align-items:center; border:1.5px solid var(--c-line); border-radius:var(--r-md); padding:var(--s-4); cursor:pointer; transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease); }
.quiz-option:hover { border-color:var(--c-brand); background:var(--c-brand-soft); }
.quiz-option input { position:absolute; opacity:0; }
.quiz-option input:checked + .quiz-option-body { color:var(--c-brand-dark); }
.quiz-option:has(input:checked) { border-color:var(--c-brand); background:var(--c-brand-soft); box-shadow:0 0 0 3px rgba(0,164,238,.12); }
.quiz-option-body strong { display:block; font-size:1rem; }
.quiz-option-body span { font-size:var(--fs-small); color:var(--c-ink-soft); }
.quiz-nav { display:flex; justify-content:space-between; gap:var(--s-3); }
.quiz-result-card { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-6); box-shadow:var(--sh-md); }
.quiz-result-card .qr-badge { display:inline-block; background:var(--c-accent-soft); color:var(--c-accent-green); font-weight:700; font-size:var(--fs-xsmall); padding:5px 12px; border-radius:999px; margin-bottom:var(--s-4); }
.quiz-result-card h2 { margin-bottom:var(--s-2); }
.quiz-result-price { font-size:1.5rem; font-weight:800; color:var(--c-brand-dark); margin:var(--s-3) 0; }
.quiz-addon { margin-top:var(--s-4); padding-top:var(--s-4); border-top:1px dashed var(--c-line); }

/* -----------------------------------------------------------------------------
   25. UTILITIES
   -------------------------------------------------------------------------- */
.bg-alt { background:var(--c-bg-alt); }
.text-center { text-align:center; }
.mt-0 { margin-top:0; }
.toast { position:fixed; left:50%; bottom:24px; transform:translateX(-50%) translateY(120%); background:var(--c-brand-dark); color:#fff; padding:12px 20px; border-radius:999px; font-size:var(--fs-small); font-weight:600; box-shadow:var(--sh-lg); z-index:300; opacity:0; transition:transform .3s var(--ease), opacity .3s var(--ease); }
.toast.is-visible { transform:translateX(-50%) translateY(0); opacity:1; }
