/* =============================================================================
   First Aid Course (Skills Training Group) — shared theme
   Fresh hand-built theme for the Newcastle / Liverpool / Manchester city sites.
   Pure CSS, design-token driven. Only JS on the site is nav + contact form.
   Order: tokens -> base -> layout -> components -> pages -> utilities.
   ============================================================================= */

/* -----------------------------------------------------------------------------
   1. DESIGN TOKENS
   -------------------------------------------------------------------------- */
:root {
  /* Brand — trust blue + green action + first-aid red accent */
  --c-brand:        #1366C6;  /* primary blue (links, accents)        */
  --c-brand-hover:  #0F549F;  /* blue hover                           */
  --c-brand-dark:   #0A2A4A;  /* hero / footer / headlines (navy)     */
  --c-brand-deep:   #0C355E;  /* gradient partner to brand-dark       */
  --c-brand-soft:   #E8F1FC;  /* tints, chips, soft fills             */
  --c-brand-line:   #CFE0F5;  /* soft blue borders                    */

  --c-action:       #15803D;  /* green CTA — Book / convert (AA on white) */
  --c-action-hover: #126A33;  /* green hover                           */
  --c-action-soft:  #E7F6ec;  /* green tint (tick backgrounds)         */
  --c-red:          #E11D2A;  /* first-aid cross + urgency dot         */

  --c-ink:          #0E1B2A;  /* primary text                          */
  --c-ink-soft:     #475467;  /* secondary text                        */
  --c-muted:        #6B7787;  /* tertiary text                         */
  --c-line:         #E5E9F0;  /* hairline borders                      */
  --c-bg:           #ffffff;
  --c-bg-alt:       #F5F8FC;  /* alt section background                */
  --c-star:         #F5A623;  /* review stars                          */

  /* Typography */
  --font-head: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --fs-display: clamp(2.1rem, 1.3rem + 3.4vw, 3.5rem);
  --fs-h1:      clamp(1.75rem, 1.2rem + 2.1vw, 2.6rem);
  --fs-h2:      clamp(1.45rem, 1.1rem + 1.4vw, 2rem);
  --fs-h3:      clamp(1.125rem, 1rem + 0.5vw, 1.3rem);
  --fs-body:    1rem;
  --fs-small:   0.875rem;
  --fs-xsmall:  0.78rem;

  /* Spacing scale (rem) */
  --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:8px; --r-md:12px; --r-lg:18px; --r-xl:24px; --r-pill:999px;
  --sh-sm: 0 1px 2px rgba(14,27,42,.05), 0 1px 3px rgba(14,27,42,.07);
  --sh-md: 0 6px 18px rgba(14,27,42,.07), 0 2px 6px rgba(14,27,42,.05);
  --sh-lg: 0 22px 48px rgba(14,27,42,.12);
  --sh-blue: 0 12px 28px rgba(19,102,198,.28);
  --sh-green: 0 10px 22px rgba(21,128,61,.30);

  --container: 1180px;
  --container-narrow: 820px;
  --ease: cubic-bezier(.2,.7,.2,1);
  --dur: 220ms;
  --nav-h: 76px;
}

/* -----------------------------------------------------------------------------
   2. BASE
   -------------------------------------------------------------------------- */
*,*::before,*::after { box-sizing: border-box; }
html {
  font-size: clamp(16px, 15px + 0.2vw, 18px);
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  scroll-padding-top: calc(var(--nav-h) + 16px);
}
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--c-ink);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img,svg,video { max-width: 100%; display: block; height: auto; }
a { color: var(--c-brand); text-decoration: none; }
a:hover { color: var(--c-brand-hover); }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
h1,h2,h3,h4 { font-family: var(--font-head); margin: 0; line-height: 1.18; letter-spacing: -.02em; font-weight: 700; color: var(--c-brand-dark); }
p { margin: 0; }
ul,ol { margin: 0; }
strong { font-weight: 700; }
: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; }
}

.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); }
.container--narrow { max-width:var(--container-narrow); }
.section { padding-block: clamp(var(--s-7), 4vw, var(--s-9)); }
.section--tint { background:var(--c-bg-alt); }
.section--dark { background:var(--c-brand-dark); color:#fff; }
.section--dark h2, .section--dark h3 { color:#fff; }
.section-head { max-width: 660px; margin-bottom: var(--s-6); }
.section-head.center { text-align:center; margin-inline:auto; }
.section-head h2 { font-size: var(--fs-h2); margin-bottom: var(--s-3); }
.section-head p { color: var(--c-ink-soft); font-size: 1.05rem; }
.section--dark .section-head p { color: rgba(255,255,255,.82); }
.eyebrow { display:inline-block; font-family:var(--font-head); font-size:var(--fs-xsmall); font-weight:700; color:var(--c-brand); letter-spacing:.1em; text-transform:uppercase; margin-bottom:var(--s-2); }
.section--dark .eyebrow { color:#7FB4F2; }
.lede { font-size:1.1rem; color:var(--c-ink-soft); line-height:1.6; }

/* Buttons */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:var(--s-2); padding:13px 24px; border-radius:var(--r-pill); font-family:var(--font-head); font-weight:600; font-size:var(--fs-small); line-height:1; white-space:nowrap; transition: background var(--dur) var(--ease), color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.btn svg { width:18px; height:18px; }
.btn--primary { background:var(--c-action); color:#fff; box-shadow:var(--sh-green); }
.btn--primary:hover { background:var(--c-action-hover); color:#fff; transform:translateY(-2px); }
.btn--blue { background:var(--c-brand); color:#fff; box-shadow:var(--sh-blue); }
.btn--blue:hover { background:var(--c-brand-hover); color:#fff; transform:translateY(-2px); }
.btn--ghost { background:#fff; color:var(--c-brand-dark); border:1.5px solid var(--c-line); }
.btn--ghost:hover { border-color:var(--c-brand); color:var(--c-brand); }
.btn--on-dark { background:#fff; color:var(--c-brand-dark); }
.btn--on-dark:hover { background:var(--c-brand-soft); color:var(--c-brand-dark); transform:translateY(-2px); }
.btn--outline-dark { background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.4); }
.btn--outline-dark:hover { background:rgba(255,255,255,.12); color:#fff; }
.btn--lg { padding:16px 30px; font-size:1rem; }
.btn--sm { padding:9px 16px; font-size:var(--fs-xsmall); }
.btn--block { width:100%; }

/* -----------------------------------------------------------------------------
   4. UTILITY BAR (thin top bar)
   -------------------------------------------------------------------------- */
.utilbar { background:var(--c-brand-dark); color:#fff; font-size:var(--fs-xsmall); }
.utilbar .container { display:flex; align-items:center; justify-content:space-between; gap:var(--s-4); padding-block:8px; flex-wrap:wrap; }
.utilbar a { color:#fff; }
.utilbar a:hover { color:#fff; text-decoration:underline; }
.utilbar__left { display:flex; align-items:center; gap:6px; opacity:.92; }
.utilbar__right { display:flex; align-items:center; gap:var(--s-4); }
.utilbar__right a { display:inline-flex; align-items:center; gap:6px; font-weight:600; }
.utilbar__right svg { width:14px; height:14px; }
@media (max-width:600px){ .utilbar__left { display:none; } .utilbar .container { justify-content:center; } }

/* -----------------------------------------------------------------------------
   5. HEADER / NAV
   -------------------------------------------------------------------------- */
.site-header { position:sticky; top:0; z-index:60; background:#fff; border-bottom:1px solid var(--c-line); }
.site-header__inner { display:flex; align-items:center; justify-content:space-between; gap:var(--s-5); min-height:var(--nav-h); }

/* Brand wordmark + cross icon */
.brand { display:inline-flex; align-items:center; gap:10px; }
.brand__mark { flex:none; width:40px; height:40px; border-radius:10px; background:linear-gradient(135deg, var(--c-brand) 0%, var(--c-brand-dark) 100%); display:flex; align-items:center; justify-content:center; box-shadow:var(--sh-sm); }
.brand__mark svg { width:24px; height:24px; }
.brand__text { display:flex; flex-direction:column; line-height:1.05; }
.brand__name { font-family:var(--font-head); font-weight:800; font-size:1.06rem; color:var(--c-brand-dark); letter-spacing:-.02em; }
.brand__sub { font-size:.66rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--c-muted); }
@media (max-width:480px){ .brand__name { font-size:.95rem; } .brand__mark { width:36px; height:36px; } }

.mainnav { display:none; align-items:center; gap:var(--s-6); }
.mainnav > ul { display:flex; align-items:center; gap:var(--s-5); list-style:none; padding:0; margin:0; font-family:var(--font-head); font-weight:500; font-size:var(--fs-small); }
.mainnav a:not(.btn) { color:var(--c-ink); }
.mainnav a:not(.btn):hover { color:var(--c-brand); }
.mainnav .has-mega { position:relative; }
.mainnav .has-mega > a { display:inline-flex; align-items:center; gap:5px; }
.mainnav .has-mega > a::after { content:""; width:7px; height:7px; border-right:2px solid currentColor; border-bottom:2px solid currentColor; transform:rotate(45deg) translateY(-2px); transition:transform var(--dur) var(--ease); opacity:.6; }
.mainnav .has-mega:hover > a::after, .mainnav .has-mega:focus-within > a::after { transform:rotate(225deg) translateY(-2px); }

.mega { position:absolute; top:calc(100% + 14px); left:50%; transform:translateX(-50%) translateY(-6px); width:min(680px, 90vw); background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); box-shadow:var(--sh-lg); padding:var(--s-5); opacity:0; visibility:hidden; transition:opacity .16s var(--ease), transform .16s var(--ease), visibility .16s; z-index:70; }
.has-mega:hover .mega, .has-mega:focus-within .mega { opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.mega::before { content:""; position:absolute; top:-14px; left:0; right:0; height:14px; }
.mega__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-4) var(--s-5); }
.mega__col h3 { font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--c-muted); margin-bottom:var(--s-2); padding-bottom:6px; border-bottom:1px solid var(--c-line); }
.mega__col ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:2px; }
.mega__col a { display:block; padding:6px 8px; border-radius:var(--r-sm); font-weight:500; font-size:var(--fs-small); color:var(--c-ink-soft); line-height:1.3; }
.mega__col a:hover { background:var(--c-brand-soft); color:var(--c-brand-dark); }
.mega__foot { margin-top:var(--s-4); padding-top:var(--s-4); border-top:1px solid var(--c-line); display:flex; align-items:center; justify-content:space-between; gap:var(--s-4); }
.mega__foot span { font-size:var(--fs-small); color:var(--c-ink-soft); }

.header-cta { display:flex; align-items:center; gap:var(--s-3); }
.header-phone { display:none; font-family:var(--font-head); font-weight:700; color:var(--c-brand-dark); font-size:.95rem; white-space:nowrap; }
.header-phone span { display:block; font-size:.62rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--c-muted); }

.nav-toggle { display:inline-flex; flex-direction:column; justify-content:center; gap:5px; width:46px; height:46px; align-items:center; border-radius:var(--r-sm); }
.nav-toggle span { width:24px; 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:1000px){
  .mainnav { display:flex; }
  .header-phone { display:block; }
  .nav-toggle { display:none; }
}

/* Mobile drawer */
.mobile-nav { position:fixed; inset:var(--nav-h) 0 0 0; z-index:55; 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-1); }
.mobile-nav.is-open { transform:translateX(0); }
.mobile-nav > a:not(.btn), .mobile-nav details > summary { padding:14px 8px; border-bottom:1px solid var(--c-line); font-family:var(--font-head); font-weight:600; color:var(--c-brand-dark); font-size:1.05rem; }
.mobile-nav details > summary { list-style:none; display:flex; align-items:center; justify-content:space-between; cursor:pointer; }
.mobile-nav details > summary::-webkit-details-marker { display:none; }
.mobile-nav details > summary::after { content:"+"; font-size:1.3rem; color:var(--c-brand); }
.mobile-nav details[open] > summary::after { content:"\2212"; }
.mobile-nav .m-sub { display:flex; flex-direction:column; padding:var(--s-2) 0 var(--s-3); }
.mobile-nav .m-sub a { padding:9px 8px 9px 18px; font-weight:500; font-size:.95rem; color:var(--c-ink-soft); border-bottom:1px dashed var(--c-line); }
.mobile-nav .m-cta { margin-top:var(--s-4); }
@media (min-width:1000px){ .mobile-nav { display:none; } }

/* -----------------------------------------------------------------------------
   6. HERO (home)
   -------------------------------------------------------------------------- */
.hero { background:linear-gradient(160deg, var(--c-brand-dark) 0%, var(--c-brand-deep) 60%, #0E3E6E 100%); color:#fff; position:relative; overflow:hidden; }
.hero::after { content:""; position:absolute; top:-30%; right:-10%; width:560px; height:560px; background:radial-gradient(circle, rgba(19,102,198,.45) 0%, transparent 65%); pointer-events:none; }
.hero__grid { display:grid; grid-template-columns:1fr; gap:var(--s-6); align-items:center; padding-block:clamp(var(--s-7), 5vw, var(--s-9)); position:relative; z-index:1; }
.hero__rating { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18); padding:6px 14px; border-radius:var(--r-pill); font-size:var(--fs-small); margin-bottom:var(--s-4); }
.hero__rating .stars { color:var(--c-star); display:inline-flex; gap:1px; vertical-align:middle; }
.hero h1 { color:#fff; font-size:var(--fs-display); font-weight:800; margin-bottom:var(--s-4); }
.hero h1 .hl { color:#7FB4F2; }
.hero p.lede { color:rgba(255,255,255,.86); max-width:560px; margin-bottom:var(--s-6); }
.hero__ctas { display:flex; flex-wrap:wrap; gap:var(--s-3); margin-bottom:var(--s-6); }
.hero__points { display:flex; flex-wrap:wrap; gap:var(--s-3) var(--s-5); }
.hero__points li { display:flex; align-items:center; gap:8px; list-style:none; font-size:var(--fs-small); color:rgba(255,255,255,.9); }
.hero__points svg { width:18px; height:18px; color:#4ADE80; flex:none; }
.hero__media { position:relative; }
.hero__media img { width:100%; border-radius:var(--r-xl); box-shadow:var(--sh-lg); aspect-ratio:4/3; object-fit:cover; }
.hero__badge { position:absolute; bottom:-18px; left:-18px; background:#fff; color:var(--c-ink); border-radius:var(--r-md); box-shadow:var(--sh-lg); padding:12px 16px; display:flex; align-items:center; gap:12px; max-width:240px; }
.hero__badge .ico { flex:none; width:40px; height:40px; border-radius:10px; background:var(--c-action-soft); color:var(--c-action); display:flex; align-items:center; justify-content:center; }
.hero__badge strong { display:block; font-family:var(--font-head); font-size:1.05rem; color:var(--c-brand-dark); line-height:1; }
.hero__badge span { font-size:var(--fs-xsmall); color:var(--c-ink-soft); }
@media (min-width:900px){
  .hero__grid { grid-template-columns:1.05fr .95fr; gap:var(--s-8); }
  .hero__media { padding-left:var(--s-4); }
}
@media (max-width:899px){ .hero__media { display:none; } }

/* -----------------------------------------------------------------------------
   7. PAGE HERO (inner pages) + breadcrumbs
   -------------------------------------------------------------------------- */
.page-hero { background:linear-gradient(160deg, var(--c-brand-dark) 0%, var(--c-brand-deep) 100%); color:#fff; padding-block:var(--s-7); }
.page-hero h1 { color:#fff; font-size:var(--fs-h1); margin-bottom:var(--s-3); }
.page-hero p { color:rgba(255,255,255,.85); max-width:680px; font-size:1.05rem; }
.breadcrumbs { margin-bottom:var(--s-4); font-size:var(--fs-xsmall); }
.breadcrumbs ol { list-style:none; display:flex; flex-wrap:wrap; gap:6px; padding:0; margin:0; color:rgba(255,255,255,.6); }
.breadcrumbs a { color:rgba(255,255,255,.8); }
.breadcrumbs a:hover { color:#fff; text-decoration:underline; }
.breadcrumbs li+li::before { content:"/"; margin-right:6px; opacity:.5; }
.breadcrumbs [aria-current="page"] { color:#fff; }

/* -----------------------------------------------------------------------------
   8. TRUST STRIP (stats) + ACCREDITATION LOGOS
   -------------------------------------------------------------------------- */
.stat-strip { background:#fff; border-bottom:1px solid var(--c-line); }
.stat-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:var(--s-4); padding-block:var(--s-6); }
.stat { text-align:center; }
.stat strong { display:block; font-family:var(--font-head); font-size:clamp(1.5rem,1rem + 1.6vw,2rem); font-weight:800; color:var(--c-brand); line-height:1; }
.stat span { font-size:var(--fs-small); color:var(--c-ink-soft); }
@media (min-width:760px){ .stat-grid { grid-template-columns:repeat(4,1fr); } }

.logos { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:var(--s-5) var(--s-7); }
.logos img { height:54px; width:auto; object-fit:contain; opacity:.92; }
.logos--sm img { height:42px; width:auto; opacity:1; filter:none; }
.logos-label { text-align:center; font-size:var(--fs-xsmall); font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--c-muted); margin-bottom:var(--s-5); }

/* -----------------------------------------------------------------------------
   9. COURSE GRID + CARDS
   -------------------------------------------------------------------------- */
.course-cat { margin-bottom:var(--s-7); }
.course-cat__head { display:flex; align-items:center; gap:var(--s-3); margin-bottom:var(--s-5); }
.course-cat__head .ico { width:40px; height:40px; border-radius:10px; background:var(--c-brand-soft); color:var(--c-brand); display:flex; align-items:center; justify-content:center; flex:none; }
.course-cat__head h3 { font-size:var(--fs-h3); }
.course-cat__head p { font-size:var(--fs-small); color:var(--c-ink-soft); }

.course-grid { display:grid; grid-template-columns:1fr; gap:var(--s-4); }
@media (min-width:600px){ .course-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:980px){ .course-grid { grid-template-columns:repeat(3,1fr); } }

.course-card { display:flex; flex-direction:column; background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); overflow:hidden; transition:box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.course-card:hover { box-shadow:var(--sh-md); transform:translateY(-4px); border-color:var(--c-brand-line); }
.course-card__thumb { position:relative; aspect-ratio:16/10; background:var(--c-bg-alt); overflow:hidden; }
.course-card__thumb img { width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ease); }
.course-card:hover .course-card__thumb img { transform:scale(1.04); }
.course-card__price { position:absolute; top:10px; right:10px; background:#fff; color:var(--c-brand-dark); font-family:var(--font-head); font-weight:700; font-size:.95rem; padding:5px 12px; border-radius:var(--r-pill); box-shadow:var(--sh-sm); }
.course-card__body { display:flex; flex-direction:column; flex:1; padding:var(--s-5); }
.course-card__chips { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:var(--s-3); }
.chip { display:inline-flex; align-items:center; gap:5px; background:var(--c-brand-soft); color:var(--c-brand-dark); font-size:var(--fs-xsmall); font-weight:600; padding:3px 10px; border-radius:var(--r-pill); }
.chip--accred { background:var(--c-action-soft); color:var(--c-action-hover); }
.course-card h3 { font-size:1.1rem; margin-bottom:var(--s-2); }
.course-card h3 a { color:var(--c-brand-dark); }
.course-card h3 a:hover { color:var(--c-brand); }
.course-card p { color:var(--c-ink-soft); font-size:var(--fs-small); margin-bottom:var(--s-4); flex:1; }
.course-card__foot { display:flex; gap:var(--s-2); margin-top:auto; }
.course-card__foot .btn { flex:1; }

/* -----------------------------------------------------------------------------
   10. COURSE DETAIL (content + sticky sidebar)
   -------------------------------------------------------------------------- */
.course-layout { display:grid; grid-template-columns:1fr; gap:var(--s-6); }
@media (min-width:960px){ .course-layout { grid-template-columns:minmax(0,1fr) 340px; gap:var(--s-7); align-items:start; } }
.course-body > h2 { font-size:var(--fs-h2); margin:var(--s-7) 0 var(--s-3); }
.course-body > h2:first-child { margin-top:0; }
.course-body > h3 { font-size:var(--fs-h3); margin:var(--s-5) 0 var(--s-2); }
.course-body p { color:var(--c-ink-soft); margin-bottom:var(--s-4); }
.course-body a { font-weight:600; }
.course-body a:hover { text-decoration:underline; }

.checklist { list-style:none; padding:0; margin:0 0 var(--s-5); display:grid; gap:var(--s-3); }
@media (min-width:560px){ .checklist--2col { grid-template-columns:repeat(2,1fr); } }
.checklist li { display:flex; align-items:flex-start; gap:12px; font-size:var(--fs-small); color:var(--c-ink); }
.checklist li::before { content:""; flex:none; width:22px; height:22px; margin-top:1px; border-radius:50%; background:var(--c-action-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2316A34A' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/14px no-repeat; }

.course-sidebar { position:relative; }
@media (min-width:960px){ .course-sidebar { position:sticky; top:calc(var(--nav-h) + 16px); } }
.booking-card { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); box-shadow:var(--sh-md); overflow:hidden; }
.booking-card__top { background:linear-gradient(150deg, var(--c-brand-dark), var(--c-brand-deep)); color:#fff; padding:var(--s-5); }
.booking-card__price { font-family:var(--font-head); font-size:2rem; font-weight:800; line-height:1; }
.booking-card__price span { font-size:.85rem; font-weight:500; opacity:.8; }
.booking-card__pernote { font-size:var(--fs-xsmall); opacity:.82; margin-top:4px; }
.booking-card__body { padding:var(--s-5); }
.booking-card dl { display:grid; grid-template-columns:auto 1fr; gap:var(--s-2) var(--s-4); margin:0 0 var(--s-5); font-size:var(--fs-small); }
.booking-card dt { color:var(--c-muted); font-weight:600; }
.booking-card dd { margin:0; text-align:right; color:var(--c-ink); font-weight:600; }
.booking-card .btn { margin-bottom:var(--s-3); }
.booking-card__guarantee { display:flex; align-items:flex-start; gap:8px; font-size:var(--fs-xsmall); color:var(--c-ink-soft); background:var(--c-brand-soft); padding:10px 12px; border-radius:var(--r-sm); margin-top:var(--s-2); }
.booking-card__guarantee svg { flex:none; width:16px; height:16px; color:var(--c-brand); margin-top:1px; }

/* Related courses */
.related-courses { margin-top:var(--s-8); }

/* -----------------------------------------------------------------------------
   11. VENUE
   -------------------------------------------------------------------------- */
.venue-grid { display:grid; grid-template-columns:1fr; gap:var(--s-5); }
@media (min-width:880px){ .venue-grid { grid-template-columns:1fr 1fr; gap:var(--s-7); align-items:start; } }
.venue-address { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-5); box-shadow:var(--sh-sm); }
.venue-address h3 { font-size:var(--fs-h3); margin-bottom:var(--s-2); }
.venue-cols { display:grid; grid-template-columns:1fr; gap:var(--s-5) var(--s-6); margin-top:var(--s-6); }
@media (min-width:640px){ .venue-cols { grid-template-columns:repeat(3,1fr); } }
.venue-col h4 { font-family:var(--font-head); font-size:var(--fs-small); margin-bottom:var(--s-2); display:flex; align-items:center; gap:8px; color:var(--c-brand-dark); }
.venue-col h4 svg { width:18px; height:18px; color:var(--c-brand); }
.venue-col ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:6px; font-size:var(--fs-small); color:var(--c-ink-soft); }
.venue-col li { display:flex; justify-content:space-between; gap:var(--s-3); padding-bottom:6px; border-bottom:1px dashed var(--c-line); }
.venue-col li span:last-child { color:var(--c-muted); white-space:nowrap; }
.venue-map { border:0; width:100%; height:100%; min-height:320px; border-radius:var(--r-lg); }

/* -----------------------------------------------------------------------------
   12. TESTIMONIALS
   -------------------------------------------------------------------------- */
.reviews-grid { display:grid; grid-template-columns:1fr; gap:var(--s-4); }
@media (min-width:640px){ .reviews-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:1000px){ .reviews-grid { grid-template-columns:repeat(3,1fr); } }
.review { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-5); box-shadow:var(--sh-sm); display:flex; flex-direction:column; gap:var(--s-3); }
.review__stars { color:var(--c-star); display:inline-flex; gap:2px; }
.review__quote { color:var(--c-ink); font-size:var(--fs-small); line-height:1.6; flex:1; }
.review__by { display:flex; align-items:center; gap:10px; }
.review__avatar { width:36px; height:36px; border-radius:50%; background:var(--c-brand-soft); color:var(--c-brand); font-family:var(--font-head); font-weight:700; display:flex; align-items:center; justify-content:center; font-size:.9rem; flex:none; }
.review__name { font-weight:700; font-size:var(--fs-small); color:var(--c-brand-dark); }
.review__src { font-size:var(--fs-xsmall); color:var(--c-muted); }

/* -----------------------------------------------------------------------------
   13. FAQ (native details, zero JS)
   -------------------------------------------------------------------------- */
.faq { max-width:820px; margin-inline:auto; display:flex; flex-direction:column; gap:var(--s-3); }
.faq details { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-md); overflow:hidden; transition:box-shadow var(--dur); }
.faq details[open] { box-shadow:var(--sh-sm); border-color:var(--c-brand-line); }
.faq summary { list-style:none; cursor:pointer; padding:var(--s-4) var(--s-5); font-family:var(--font-head); font-weight:600; font-size:1rem; color:var(--c-brand-dark); display:flex; align-items:center; justify-content:space-between; gap:var(--s-3); }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:""; flex:none; width:11px; height:11px; border-right:2px solid var(--c-brand); border-bottom:2px solid var(--c-brand); transform:rotate(45deg); transition:transform var(--dur) var(--ease); }
.faq details[open] summary::after { transform:rotate(225deg); }
.faq__body { padding:0 var(--s-5) var(--s-5); color:var(--c-ink-soft); font-size:var(--fs-small); }
.faq__body p { margin-bottom:var(--s-3); }

/* -----------------------------------------------------------------------------
   14. CTA BAND
   -------------------------------------------------------------------------- */
.cta-band { background:linear-gradient(135deg, var(--c-brand) 0%, var(--c-brand-dark) 100%); color:#fff; border-radius:var(--r-xl); padding:clamp(var(--s-6),4vw,var(--s-8)); text-align:center; position:relative; overflow:hidden; }
.cta-band::after { content:""; position:absolute; bottom:-40%; right:-5%; width:380px; height:380px; background:radial-gradient(circle, rgba(255,255,255,.14) 0%, transparent 65%); }
.cta-band h2 { color:#fff; font-size:var(--fs-h2); margin-bottom:var(--s-3); position:relative; }
.cta-band p { color:rgba(255,255,255,.88); max-width:560px; margin:0 auto var(--s-5); position:relative; }
.cta-band__btns { display:flex; flex-wrap:wrap; gap:var(--s-3); justify-content:center; position:relative; }

/* -----------------------------------------------------------------------------
   15. FEATURE / WHY CARDS
   -------------------------------------------------------------------------- */
.feature-grid { display:grid; grid-template-columns:1fr; gap:var(--s-4); }
@media (min-width:640px){ .feature-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:980px){ .feature-grid { grid-template-columns:repeat(3,1fr); } }
.feature { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); padding:var(--s-5); transition:transform var(--dur), box-shadow var(--dur), border-color var(--dur); }
.feature:hover { transform:translateY(-3px); box-shadow:var(--sh-md); border-color:var(--c-brand-line); }
.feature .ico { width:48px; height:48px; border-radius:12px; background:var(--c-brand-soft); color:var(--c-brand); display:flex; align-items:center; justify-content:center; margin-bottom:var(--s-4); }
.feature .ico svg { width:26px; height:26px; }
.feature h3 { font-size:1.1rem; margin-bottom:var(--s-2); }
.feature p { color:var(--c-ink-soft); font-size:var(--fs-small); }

/* -----------------------------------------------------------------------------
   16. PROSE (about / legal pages)
   -------------------------------------------------------------------------- */
.prose { max-width:760px; }
.prose h2 { font-size:var(--fs-h2); margin:var(--s-7) 0 var(--s-3); }
.prose h3 { font-size:var(--fs-h3); 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) var(--s-5); display:flex; flex-direction:column; gap:8px; }
.prose a { font-weight:600; }
.prose a:hover { text-decoration:underline; }
.prose strong { color:var(--c-ink); }

/* -----------------------------------------------------------------------------
   17. FORMS (contact)
   -------------------------------------------------------------------------- */
.form-card { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); box-shadow:var(--sh-md); padding:clamp(var(--s-5),3vw,var(--s-6)); }
.field { margin-bottom:var(--s-4); }
.field label { display:block; font-family:var(--font-head); font-weight:600; font-size:var(--fs-small); color:var(--c-brand-dark); margin-bottom:6px; }
.field input, .field textarea, .field select { width:100%; padding:12px 14px; border:1.5px solid var(--c-line); border-radius:var(--r-sm); font:inherit; color:var(--c-ink); background:#fff; transition:border-color var(--dur); }
.field input:focus, .field textarea:focus, .field select:focus { outline:none; border-color:var(--c-brand); box-shadow:0 0 0 3px var(--c-brand-soft); }
.field textarea { min-height:130px; resize:vertical; }
.field--hp { position:absolute; left:-9999px; opacity:0; height:0; overflow:hidden; }
.form-note { font-size:var(--fs-xsmall); color:var(--c-muted); margin-top:var(--s-3); }
.form-status { display:none; padding:12px 14px; border-radius:var(--r-sm); font-size:var(--fs-small); margin-bottom:var(--s-4); }
.form-status.is-error { display:block; background:#FDECEC; color:#B42318; }
.form-status.is-ok { display:block; background:var(--c-action-soft); color:var(--c-action-hover); }
.contact-grid { display:grid; grid-template-columns:1fr; gap:var(--s-6); }
@media (min-width:880px){ .contact-grid { grid-template-columns:1fr 1.1fr; gap:var(--s-7); align-items:start; } }
.contact-detail { display:flex; gap:var(--s-3); margin-bottom:var(--s-4); }
.contact-detail .ico { flex:none; width:44px; height:44px; border-radius:12px; background:var(--c-brand-soft); color:var(--c-brand); display:flex; align-items:center; justify-content:center; }
.contact-detail h3, .contact-detail__label { font-size:1rem; font-weight:600; font-family:var(--font-head); color:var(--c-brand-dark); margin-bottom:2px; }
.contact-detail p, .contact-detail a { color:var(--c-ink-soft); font-size:var(--fs-small); }
.contact-detail a:hover { color:var(--c-brand); }

/* -----------------------------------------------------------------------------
   18. FOOTER
   -------------------------------------------------------------------------- */
.site-footer { background:var(--c-brand-dark); color:rgba(255,255,255,.78); font-size:var(--fs-small); }
.site-footer a { color:rgba(255,255,255,.78); }
.site-footer a:hover { color:#fff; }
.site-footer__main { display:grid; grid-template-columns:1fr; gap:var(--s-6); padding-block:var(--s-8) var(--s-6); }
@media (min-width:720px){ .site-footer__main { grid-template-columns:1.5fr 1fr 1fr; } }
@media (min-width:1000px){ .site-footer__main { grid-template-columns:2fr 1fr 1fr 1.2fr; } }
.site-footer h2 { font-size:1.05rem; color:#fff; margin-bottom:var(--s-2); }
.site-footer h3, .site-footer__col-title { font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.55); margin-bottom:var(--s-3); }
.site-footer .brand__name { color:#fff; }
.site-footer .brand__sub { color:rgba(255,255,255,.55); }
.site-footer__about p { margin-top:var(--s-3); max-width:340px; line-height:1.6; }
.site-footer__contact { display:flex; flex-direction:column; gap:8px; margin-top:var(--s-3); }
.site-footer__contact a, .site-footer__contact span { display:inline-flex; align-items:flex-start; gap:8px; }
.site-footer__contact svg { width:16px; height:16px; opacity:.7; flex:none; margin-top:3px; }
.site-footer__venue .addr { display:flex; flex-direction:column; line-height:1.5; }
.site-footer__venue .addr strong { color:#fff; font-weight:600; }
.site-footer nav ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:9px; }
.site-footer__accred { display:flex; gap:10px; flex-wrap:wrap; margin-top:var(--s-3); }
.site-footer__accred img { height:42px; width:auto; background:#fff; border-radius:6px; padding:5px 8px; object-fit:contain; }
.site-footer__bottom { border-top:1px solid rgba(255,255,255,.12); padding-block:var(--s-4); display:flex; flex-wrap:wrap; gap:var(--s-3); align-items:center; justify-content:space-between; }
.site-footer__bottom p { font-size:var(--fs-xsmall); color:rgba(255,255,255,.55); }
.site-footer__legal { display:flex; flex-wrap:wrap; gap:var(--s-4); font-size:var(--fs-xsmall); }

/* -----------------------------------------------------------------------------
   19. MISC PAGES (404 / thank-you)
   -------------------------------------------------------------------------- */
.center-page { text-align:center; max-width:560px; margin-inline:auto; padding-block:var(--s-9); }
.center-page .big { font-family:var(--font-head); font-size:clamp(3rem,10vw,6rem); font-weight:800; color:var(--c-brand); line-height:1; margin-bottom:var(--s-3); }
.center-page h1 { margin-bottom:var(--s-3); }
.center-page p { color:var(--c-ink-soft); margin-bottom:var(--s-5); }
.center-page .btn { margin:0 6px; }

/* -----------------------------------------------------------------------------
   20. UTILITIES
   -------------------------------------------------------------------------- */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.text-center{text-align:center}
.grid-2{display:grid;grid-template-columns:1fr;gap:var(--s-6)}
@media(min-width:820px){.grid-2{grid-template-columns:1fr 1fr;align-items:center}}
.media-rounded{border-radius:var(--r-xl);box-shadow:var(--sh-lg);width:100%;object-fit:cover}

/* --- hero venue line + course page additions --- */
.hero__loc { display:flex; align-items:center; gap:8px; margin-bottom:var(--s-5); font-size:var(--fs-small); color:rgba(255,255,255,.85); }
.hero__loc svg { color:#7FB4F2; flex:none; }
.hero__loc a { color:#fff; text-decoration:underline; }
.course-hero-img { width:100%; aspect-ratio:16/9; object-fit:cover; border-radius:var(--r-lg); box-shadow:var(--sh-sm); margin-bottom:var(--s-6); }
.booking-card__cap { font-size:var(--fs-xsmall); color:var(--c-ink-soft); text-align:center; margin:2px 0 var(--s-3); line-height:1.4; }
/* ===== Enhanced dark-band backgrounds: richer gradient + subtle cross pattern ===== */
.hero { background:linear-gradient(115deg, #0F4178 0%, #1A60AC 52%, #2A7FD6 100%); }
.page-hero { position:relative; overflow:hidden; background:linear-gradient(115deg, #0F4178 0%, #1A60AC 55%, #2A7FD6 100%); }
.page-hero .container { position:relative; z-index:1; }
.cta-band { background:linear-gradient(120deg, #1A60AC 0%, #15539A 55%, #0F4178 100%); }
.hero::before, .page-hero::before, .cta-band::before {
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='1.4' stroke-linecap='round'%3E%3Cpath d='M24 17v14'/%3E%3Cpath d='M17 24h14'/%3E%3C/g%3E%3C/svg%3E");
  background-size:46px 46px; opacity:.07;
}
.cta-band > * { position:relative; z-index:1; }

/* ===== Course page hero (text + image, 2-col) ===== */
.page-hero__grid { display:grid; grid-template-columns:1fr; gap:var(--s-5); align-items:center; }
@media (min-width:900px){ .page-hero__grid { grid-template-columns:1.08fr .92fr; gap:var(--s-7); } }
.page-hero__media img { width:100%; border-radius:var(--r-lg); box-shadow:var(--sh-lg); aspect-ratio:4/3; object-fit:cover; }
.page-hero__facts { display:flex; flex-wrap:wrap; gap:var(--s-3) var(--s-5); margin-top:var(--s-5); list-style:none; padding:0; }
.page-hero__facts li { display:flex; align-items:center; gap:8px; font-size:var(--fs-small); color:rgba(255,255,255,.9); }
.page-hero__facts svg { color:#4ADE80; flex:none; }
@media (max-width:560px){ .page-hero__media { display:none; } }

/* ===== CTA band extras ===== */
.cta-band__eyebrow { display:inline-flex; align-items:center; gap:6px; font-family:var(--font-head); font-size:var(--fs-xsmall); font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:#cfe2fb; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16); padding:6px 14px; border-radius:var(--r-pill); margin-bottom:var(--s-4); }
.cta-band__eyebrow svg { color:#7FB4F2; }
.cta-band__trust { margin-top:var(--s-5); font-size:var(--fs-small); color:rgba(255,255,255,.82); display:flex; flex-wrap:wrap; gap:8px 20px; justify-content:center; }
.cta-band__trust .ck { display:inline-flex; align-items:center; gap:6px; }
.cta-band__trust svg { color:#4ADE80; flex:none; }

/* ===== Gallery ===== */
.gallery-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:var(--s-3); }
@media (min-width:680px){ .gallery-grid { grid-template-columns:repeat(3,1fr); } }
@media (min-width:1000px){ .gallery-grid { grid-template-columns:repeat(4,1fr); } }
.gallery-grid figure { margin:0; overflow:hidden; border-radius:var(--r-md); aspect-ratio:4/3; box-shadow:var(--sh-sm); background:var(--c-bg-alt); }
.gallery-grid img { width:100%; height:100%; object-fit:cover; transition:transform .45s var(--ease); }
.gallery-grid figure:hover img { transform:scale(1.06); }

/* =============================================================================
   LIGHT & AIRY — cleaner theme (overrides). White surfaces, dark text, calm
   accents, more whitespace, no decorative pattern, lighter headings.
   ============================================================================= */
:root { --fs-display: clamp(1.9rem, 1.2rem + 2.6vw, 2.9rem); }
h1,h2,h3,h4 { font-weight:700; letter-spacing:-.012em; }
.section { padding-block: clamp(3.5rem, 5.5vw, 6.5rem); }
.section-head h2 { font-weight:700; }

/* remove decorative pattern + glows */
.hero::before, .page-hero::before, .cta-band::before,
.hero::after, .cta-band::after { content:none !important; display:none !important; }

/* light utility bar */
.utilbar { background:var(--c-bg-alt); color:var(--c-ink-soft); border-bottom:1px solid var(--c-line); }
.utilbar a { color:var(--c-ink-soft); }
.utilbar a:hover { color:var(--c-brand); }

/* HERO — light blue */
.hero { background:var(--c-brand-soft); color:var(--c-ink); border-bottom:1px solid var(--c-brand-line); }
.hero h1 { color:var(--c-brand-dark); font-weight:700; }
.hero h1 .hl { color:var(--c-brand); }
.hero p.lede { color:var(--c-ink-soft); }
.hero__rating { background:#fff; border:1px solid var(--c-brand-line); color:var(--c-brand-dark); }

/* STG mark image — no tile, the mark itself is the logo */
.brand__mark { background:none; box-shadow:none; border-radius:0; height:40px; width:auto; display:block; flex:none; }
.brand__mark img { height:40px; width:auto; display:block; }
.brand__name { line-height:1.08; font-size:0.95rem; font-weight:600; }
.hero__accred { display:flex; align-items:center; gap:var(--s-3) var(--s-4); margin-top:var(--s-5); flex-wrap:wrap; }
.hero__accred > span { font-size:var(--fs-xsmall); color:var(--c-muted); text-transform:uppercase; letter-spacing:.06em; }
.hero__accred .logos { display:inline-flex; align-items:center; gap:var(--s-5); flex-wrap:wrap; background:#fff; border:1px solid var(--c-line); border-radius:var(--r-md); padding:10px 18px; box-shadow:var(--sh-sm); }
.hero__accred img { height:30px; width:auto; }
.hero__rating .stars { color:var(--c-star); }
.hero__points li { color:var(--c-ink); }
.hero__loc { display:block; color:var(--c-ink-soft); line-height:1.5; max-width:460px; margin-top:var(--s-5); }
.hero__loc svg { color:var(--c-brand); vertical-align:-3px; margin-right:4px; }

/* PAGE HERO — light */
.page-hero { background:var(--c-bg-alt); color:var(--c-ink); border-bottom:1px solid var(--c-line); }
.page-hero h1 { color:var(--c-brand-dark); }
.page-hero p { color:var(--c-ink-soft); }
.page-hero__facts li { color:var(--c-ink-soft); }
.breadcrumbs ol { color:var(--c-muted); }
.breadcrumbs a { color:var(--c-brand); }
.breadcrumbs a:hover { color:var(--c-brand-hover); }
.breadcrumbs [aria-current="page"] { color:var(--c-ink); }

/* CTA band — soft tint, not a dark slab */
.cta-band { background:var(--c-brand-soft); color:var(--c-ink); box-shadow:none; border:1px solid var(--c-brand-line); }
.cta-band h2 { color:var(--c-brand-dark); }
.cta-band p { color:var(--c-ink-soft); }
.cta-band__eyebrow { background:#fff; border:1px solid var(--c-brand-line); color:var(--c-brand); }
.cta-band__eyebrow svg { color:var(--c-brand); }
.cta-band__trust { color:var(--c-ink-soft); }
.cta-band__trust svg { color:var(--c-action); }

/* flatter, airier cards (subtle, not flat) */
.course-card { box-shadow:none; }
.course-card:hover { box-shadow:var(--sh-md); transform:translateY(-3px); }
.feature { box-shadow:none; }
.feature:hover { box-shadow:var(--sh-sm); }
.review { box-shadow:none; }
.gallery-grid figure { box-shadow:none; border:1px solid var(--c-line); }

/* Trustpilot trust strip */
.tp-strip { background:#fff; border-bottom:1px solid var(--c-line); padding-block:var(--s-5); }
.tp-strip .container { display:flex; justify-content:center; align-items:center; min-height:24px; }
.tp-strip .trustpilot-widget { width:100%; line-height:0; }
.tp-strip iframe { display:block; margin:0 auto; }
.tp-badge { display:inline-flex; align-items:center; gap:var(--s-4); flex-wrap:wrap; justify-content:center; text-align:center; }
.tp-badge img { height:44px; width:auto; }
.tp-badge__txt { font-size:var(--fs-small); color:var(--c-ink-soft); }
.tp-badge__txt strong { color:var(--c-ink); }
.tp-badge:hover .tp-badge__txt { color:var(--c-brand); }

/* Accreditation logos in the booking card */
.booking-card__accred { margin-bottom:var(--s-4); padding-bottom:var(--s-4); border-bottom:1px solid var(--c-line); }
.booking-card__accred > span { display:block; font-size:var(--fs-xsmall); color:var(--c-muted); text-transform:uppercase; letter-spacing:.06em; margin-bottom:8px; }
.ac-logos { display:flex; align-items:center; gap:var(--s-4); flex-wrap:wrap; }
.ac-logos img { height:30px; width:auto; }
.booking-card__accred--txt { font-size:var(--fs-small); color:var(--c-ink-soft); }

/* ===== Course category filter (pure CSS, no JS) ===== */
.cf-radio { position:absolute; width:1px; height:1px; opacity:0; pointer-events:none; }
.cf-tabs { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-bottom:var(--s-7); }
.cf-tab { cursor:pointer; padding:9px 18px; border:1px solid var(--c-line); border-radius:var(--r-pill); font-family:var(--font-head); font-weight:600; font-size:var(--fs-small); color:var(--c-ink-soft); background:#fff; transition:background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease); user-select:none; }
.cf-tab:hover { border-color:var(--c-brand); color:var(--c-brand); }
#cf-all:checked ~ .cf-tabs label[for="cf-all"],
#cf-workplace:checked ~ .cf-tabs label[for="cf-workplace"],
#cf-life-support:checked ~ .cf-tabs label[for="cf-life-support"],
#cf-paediatric:checked ~ .cf-tabs label[for="cf-paediatric"],
#cf-mh-fire:checked ~ .cf-tabs label[for="cf-mh-fire"] { background:var(--c-brand); color:#fff; border-color:var(--c-brand); }
.cf-radio:focus-visible ~ .cf-tabs { outline:3px solid var(--c-brand-soft); outline-offset:4px; border-radius:var(--r-md); }
/* when a specific category is chosen, show only it (and drop its now-redundant header) */
#cf-workplace:checked ~ .course-cats .course-cat,
#cf-life-support:checked ~ .course-cats .course-cat,
#cf-paediatric:checked ~ .course-cats .course-cat,
#cf-mh-fire:checked ~ .course-cats .course-cat { display:none; }
#cf-workplace:checked ~ .course-cats .course-cat[data-cat="workplace"],
#cf-life-support:checked ~ .course-cats .course-cat[data-cat="life-support"],
#cf-paediatric:checked ~ .course-cats .course-cat[data-cat="paediatric"],
#cf-mh-fire:checked ~ .course-cats .course-cat[data-cat="mh-fire"] { display:block; }
#cf-workplace:checked ~ .course-cats .course-cat__head,
#cf-life-support:checked ~ .course-cats .course-cat__head,
#cf-paediatric:checked ~ .course-cats .course-cat__head,
#cf-mh-fire:checked ~ .course-cats .course-cat__head { display:none; }

/* ===== Testimonials: masonry flow + Google G ===== */
.reviews-grid { display:block; column-count:1; column-gap:var(--s-4); }
@media (min-width:640px){ .reviews-grid { column-count:2; } }
@media (min-width:1000px){ .reviews-grid { column-count:3; } }
.reviews-grid .review { display:block; break-inside:avoid; margin:0 0 var(--s-4); }
.reviews-grid .review__stars { margin-bottom:var(--s-3); }
.reviews-grid .review__quote { margin-bottom:var(--s-4); display:block; }
.review__g { width:26px; height:26px; flex:none; display:inline-flex; align-items:center; justify-content:center; }
.review__g svg { width:24px; height:24px; }

/* ===== SEO content section (lead + cards) ===== */
.seo-lead__text h2 { margin:var(--s-2) 0 var(--s-4); }
.seo-lead__text p { color:var(--c-ink-soft); margin-bottom:var(--s-4); line-height:1.7; }
.seo-lead__text .btn { margin-top:var(--s-2); }
.seo-lead__media img { aspect-ratio:4/3; object-fit:cover; }
.seo-grid { display:grid; grid-template-columns:1fr; gap:var(--s-4); margin-top:var(--s-7); }
@media (min-width:760px){ .seo-grid { grid-template-columns:repeat(2,1fr); } }
.seo-grid .feature h3 { font-size:1.05rem; }
.seo-grid .feature p { line-height:1.6; }

/* ===== Hero info card (venue + accreditation) ===== */
.hero__card { background:#fff; border:1px solid var(--c-line); border-radius:var(--r-lg); box-shadow:var(--sh-md); padding:var(--s-5); margin-top:var(--s-6); max-width:540px; }
.hero__card-venue { display:flex; align-items:center; gap:14px; }
.hero__card-venue .ico { flex:none; width:46px; height:46px; border-radius:12px; background:var(--c-brand-soft); color:var(--c-brand); display:flex; align-items:center; justify-content:center; }
.hero__card-vtxt { display:flex; flex-direction:column; gap:2px; min-width:0; }
.hero__card .lbl { font-size:var(--fs-xsmall); font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--c-muted); }
.hero__card .nm { font-family:var(--font-head); font-weight:700; color:var(--c-brand-dark); font-size:1.02rem; line-height:1.25; }
.hero__card .ad { font-size:var(--fs-small); color:var(--c-ink-soft); }
.hero__card-line { height:1px; background:var(--c-line); margin:var(--s-4) 0; }
.hero__card-accred { display:flex; align-items:center; gap:var(--s-3) var(--s-4); flex-wrap:wrap; }
.hero__card-accred .logos { display:flex; align-items:center; gap:var(--s-5); flex-wrap:wrap; }
.hero__card-accred img { height:30px; width:auto; }
@media (max-width:560px){ .hero__card { max-width:none; } }

/* Online course chip */
.chip--online { background:#E1F4FD; color:#0C6E9E; }

/* On the dark footer, render the whole logo (mark + text) white */
.site-footer .brand__mark img { filter: brightness(0) invert(1); }

/* ============================================================
   QA MOBILE / A11Y FIXES (2026-06-24)
   ============================================================ */

/* Bulletproof accordion collapse across browsers (some hide <details>
   content via UA display:none, which author display rules can override). */
.mobile-nav details:not([open]) .m-sub { display: none; }
.faq details:not([open]) .faq__body { display: none; }

/* Mobile drawer category labels — replaces inline .72rem (was ~11.5px) */
.mobile-nav .m-cat { font-size:.8rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--c-muted); margin:12px 0 4px; }

/* Readable label floors (>=12px) */
.brand__sub { font-size:.72rem; }
.mega__col h3 { font-size:.78rem; }

/* Utility bar must wrap so the email never clips below 375px */
.utilbar__right { flex-wrap:wrap; justify-content:center; row-gap:2px; }

/* Touch tap targets: on phones/small screens (and any touch device) give every
   button a 44px minimum hit area, and the footer course-nav links real height. */
@media (max-width:680px), (hover:none) {
  .btn { min-height:44px; }
  .btn--sm { min-height:44px; }
}
.site-footer nav ul a { display:inline-block; padding-block:7px; }
.site-footer nav ul { gap:2px; }

/* Booking-card spec list: stack + left-align on small screens so long
   values (venue name, 'Flexible to suit your team') don't look ragged. */
@media (max-width:560px) {
  .booking-card dl { grid-template-columns:1fr; gap:2px 0; }
  .booking-card dt { margin-top:10px; }
  .booking-card dd { text-align:left; }
}

/* Contact form required-field markers */
.field .req { color:#C0392B; font-weight:700; }
.field .opt { color:var(--c-muted); font-weight:400; font-size:.85em; }
.form-req-note { font-size:var(--fs-small); color:var(--c-muted); margin:0 0 var(--s-3); }
.form-req-note .req { color:#C0392B; font-weight:700; }

/* Course pages: on mobile the booking card moves above the body content (so price +
   CTA are near the top), and a sticky bottom bar carries the CTA once you scroll past it. */
.sticky-cta { display:none; }
@media (max-width:959.98px) {
  .course-sidebar { order:-1; margin-bottom:var(--s-3); }
  .sticky-cta {
    position:fixed; left:0; right:0; bottom:0; z-index:50;
    display:flex; align-items:center; justify-content:space-between; gap:var(--s-4);
    padding:10px var(--s-4) calc(10px + env(safe-area-inset-bottom));
    background:#fff; border-top:1px solid var(--c-line); box-shadow:0 -6px 22px rgba(10,42,74,.14);
    transform:translateY(110%); transition:transform .28s var(--ease);
  }
  .sticky-cta.is-visible { transform:translateY(0); }
  .sticky-cta__price { font-family:var(--font-head); font-weight:800; font-size:1.15rem; color:var(--c-brand-dark); white-space:nowrap; line-height:1.1; }
  .sticky-cta__price span { color:var(--c-muted); font-weight:500; font-size:.78rem; }
  .sticky-cta .btn { flex:none; min-height:46px; padding-inline:18px; margin:0; }
}

/* In-page section nav — sticky jump-links to the course H2s (mobile only) */
.section-nav { display:none; }
@media (max-width:959.98px) {
  .section-nav { display:block; position:sticky; top:var(--nav-h); z-index:45;
    background:#fff; border-bottom:1px solid var(--c-line); box-shadow:0 3px 10px rgba(10,42,74,.05); }
  .section-nav__inner { display:flex; gap:8px; overflow-x:auto; -webkit-overflow-scrolling:touch;
    scrollbar-width:none; padding-block:9px; }
  .section-nav__inner::-webkit-scrollbar { display:none; }
  .section-nav a { flex:none; padding:7px 14px; border-radius:999px; background:var(--c-bg-alt);
    color:var(--c-ink-soft); font-family:var(--font-head); font-weight:600; font-size:.85rem;
    white-space:nowrap; transition:background var(--dur), color var(--dur); }
  .section-nav a:hover { color:var(--c-brand); }
  .section-nav a.is-active { background:var(--c-brand); color:#fff; }
  /* The global scroll-padding-top (var(--nav-h)+16 = 92px) already covers the header;
     add ~52px more so the target clears the ~55px sticky section-nav with a small gap. */
  .anchor-h2, .anchor-sec { scroll-margin-top: 52px; }
}
