/*
Theme Name: Capea 2
Theme URI: https://capea.org.au
Description: Built by Chris Harvey - Superuser Web Design superuser.com.au
Version: 1.5.16
Requires at least: 6.4
Tested up to: 6.9
Requires PHP: 8.0
Author: Chris
Text Domain: capea2
*/

/* ── Local Fonts ──────────────────────────────────────────────────────── */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('assets/fonts/roboto-300.woff2') format('woff2');
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('assets/fonts/roboto-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('assets/fonts/roboto-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('assets/fonts/roboto-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('assets/fonts/roboto-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  font-weight: 400;
  font-display: block;
  src: url('assets/fonts/material-symbols-outlined.woff2') format('woff2');
}

/* ── Design System Tokens ─────────────────────────────────────────────── */
:root {
  /* Brand colors — aliased from WP preset vars */
  --clr-primary:        var(--wp--preset--color--primary);          /* #43b790 brand green */
  --clr-primary-dark:   var(--wp--preset--color--primary-dark);     /* #006c50 dark green */
  --clr-secondary:      var(--wp--preset--color--secondary);        /* #774b98 purple */
  --clr-secondary-light:var(--wp--preset--color--secondary-container); /* #daa8fd */
  --clr-bg:             var(--wp--preset--color--background);       /* #ffffff */
  --clr-surface:        var(--wp--preset--color--surface);          /* #effcf6 */
  --clr-surface-teal:   var(--wp--preset--color--surface-teal-light); /* #f0f9f6 */
  --clr-surface-container: var(--wp--preset--color--surface-container); /* #e4f1eb */
  --clr-text:           var(--wp--preset--color--on-background);    /* #121e1a */
  --clr-text-secondary: var(--wp--preset--color--on-surface-variant); /* #3d4943 */
  --clr-muted:          #5c6b66; /* intentionally hardcoded — WCAG AA on light */
  --clr-outline:        var(--wp--preset--color--outline);          /* #6d7a73 */
  --clr-error:          var(--wp--preset--color--error);            /* #ba1a1a */

  /* Typography */
  --font-body:    var(--wp--preset--font-family--body);
  --font-hed:     var(--wp--preset--font-family--headline);

  /* Spacing — 8px base unit */
  --space-1:  8px;
  --space-2:  16px;
  --space-3:  24px;
  --space-4:  32px;
  --space-5:  40px;
  --space-6:  48px;
  --space-8:  64px;
  --space-10: 80px;
  --space-12: 96px;
  --container-max: 1280px;

  /* Radii — 5px for most things, pill for chips/badges */
  --radius-sm:   4px;
  --radius:      5px;
  --radius-md:   5px;
  --radius-lg:   5px;
  --radius-xl:   5px;
  --radius-full: 9999px;

  /* Shadows — atmospheric, low-opacity */
  --shadow-sm:  0 2px 12px 0 rgba(0, 108, 80, 0.06);
  --shadow-md:  0 4px 24px 0 rgba(0, 108, 80, 0.09);
  --shadow-lg:  0 8px 40px 0 rgba(0, 108, 80, 0.12);
}

/* ── Header ───────────────────────────────────────────────────────────── */
.wp-block-template-part:has(.site-header) {
  position: sticky;
  top: 0;
  z-index: 50;
}
.admin-bar .wp-block-template-part:has(.site-header) { top: 32px; }
@media screen and (max-width: 782px) { .admin-bar .wp-block-template-part:has(.site-header) { top: 46px; } }
.site-header {
  background: #ffffff; /* surface-container-lowest */
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
  transition: box-shadow 0.2s ease;
}
.site-header.scrolled {
  box-shadow: 0 2px 16px rgba(0, 0, 0, 0.12);
}

.site-header__inner {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  height: 80px;
  padding-inline: var(--space-2); /* 16px mobile */
}
@media (min-width: 1024px) {
  .site-header__inner { padding-inline: var(--space-5); } /* 40px desktop */
}

/* Logo — site title as text */
.site-header .wp-block-site-title {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}
.site-header .wp-block-site-title a {
  color: var(--clr-primary-dark) !important;
  text-decoration: none;
  font-family: var(--font-hed);
}
.site-header .wp-block-site-title a:hover {
  color: var(--clr-primary) !important;
}

/* Nav links */
.site-header__nav .wp-block-navigation-item__content {
  font-size: 1rem;
  font-weight: 400;
  color: #3d4943; /* on-surface-variant */
  text-decoration: none;
  padding-block: 4px;
  transition: color 0.15s ease;
}
.site-header__nav .wp-block-navigation-item__content:hover {
  color: var(--clr-primary);
}
.site-header__nav .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content,
.site-header__nav .wp-block-navigation-item.current-menu-parent .wp-block-navigation-item__content,
.site-header__nav .wp-block-navigation-item.current-menu-ancestor .wp-block-navigation-item__content {
  color: var(--clr-primary);
  border-bottom: 2px solid var(--clr-primary);
  padding-bottom: 4px;
  font-weight: 700;
}
/* Submenu dropdown */
.site-header__nav .wp-block-navigation__submenu-container {
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.10);
  padding: 8px 0;
  min-width: 220px;
  top: calc(100% + 8px);
}
.site-header__nav .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  padding: 10px 20px;
  display: block;
  font-size: 0.9375rem;
  color: #3d4943;
  border-bottom: none !important;
  font-weight: 400 !important;
}
.site-header__nav .wp-block-navigation__submenu-container .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content {
  color: var(--clr-primary-dark) !important;
  font-weight: 600 !important;
}
.site-header__nav .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover {
  color: var(--clr-primary-dark);
  background: var(--clr-surface);
}
.site-header__nav .wp-block-navigation-submenu__toggle,
.site-header__nav .wp-block-navigation__submenu-icon {
  color: #3d4943;
}

/* Hide nav on mobile/tablet; show desktop nav at 1024px+ */
.site-header .wp-block-navigation {
  display: none;
}
@media (min-width: 1024px) {
  .site-header .wp-block-navigation {
    display: flex;
  }
}

/* Actions group (right side) */
.wp-block-buttons.site-header__actions {
  gap: 4px !important;
  flex-shrink: 0;
}

/* Icon buttons — search and cart */
.wp-block-button.header-search-btn .wp-block-button__link,
.wp-block-button.header-cart-btn .wp-block-button__link {
  width: 40px !important;
  height: 40px !important;
  padding: 0 !important;
  border-radius: 50% !important;
  background: transparent !important;
  border: none !important;
  color: transparent !important;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s ease;
}
.wp-block-button.header-search-btn .wp-block-button__link:hover,
.wp-block-button.header-cart-btn .wp-block-button__link:hover {
  background: #e9f7f1 !important;
  transform: none;
  box-shadow: none;
}
.wp-block-button.header-search-btn .wp-block-button__link::before,
.wp-block-button.header-cart-btn .wp-block-button__link::before {
  font-family: 'Material Symbols Outlined';
  font-size: 22px;
  font-weight: 400;
  line-height: 1;
  color: var(--clr-primary-dark);
}
.wp-block-button.header-search-btn .wp-block-button__link::before { content: 'search'; }
.wp-block-button.header-cart-btn .wp-block-button__link::before  { content: 'shopping_cart'; }
@media (max-width: 1023px) {
  .wp-block-button.header-search-btn { display: none; }
}

/* Cart badge */
.wp-block-button.header-cart-btn {
  position: relative;
}
.wp-block-button.header-cart-btn::after {
  content: '2';
  position: absolute;
  top: 0;
  right: 0;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--clr-secondary);
  color: #ffffff;
  font-size: 10px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

/* Login button — ghost text with hover bg */
.wp-block-button.header-btn-login {
  margin-left: 4px;
}
.site-header .wp-block-button.header-btn-login .wp-block-button__link {
  background: var(--clr-surface-teal) !important;
  color: var(--clr-primary-dark) !important;
  border: none !important;
  padding: 8px 16px !important;
  font-size: 0.875rem;
  font-weight: 700;
  border-radius: 5px !important;
}
.site-header .wp-block-button.header-btn-login .wp-block-button__link:hover {
  background: var(--clr-surface-container) !important;
  transform: none;
  box-shadow: none;
}
.wp-block-button.header-btn-login .wp-block-button__link:active { transform: scale(0.95) !important; }
@media (max-width: 1023px) {
  .wp-block-button.header-btn-login { display: none; }
}

/* Join Now button — .site-header parent gives (0,4,0) to beat global primary (0,3,0) */
.site-header .wp-block-button.header-btn-join .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #ffffff !important;
  border: none !important;
  padding: 10px 24px !important;
  font-size: 0.875rem;
  font-weight: 700;
  transform: scale(0.95);
  transition: transform 0.15s ease, box-shadow 0.15s ease !important;
}
.site-header .wp-block-button.header-btn-join .wp-block-button__link:hover {
  transform: scale(0.95);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18) !important;
}
.site-header .wp-block-button.header-btn-join .wp-block-button__link:active { transform: scale(0.9) !important; box-shadow: none !important; }

/* Shop nav pill — purple outline button inside the navigation */
.site-header__nav .nav-shop-btn .wp-block-navigation-item__content {
    border: 2px solid #774b98 !important;
    border-radius: 6px !important;
    padding: 5px 14px !important;
    color: #774b98 !important;
    font-weight: 700;
    transition: background .15s, color .15s;
    line-height: 1.4;
}
.site-header__nav .nav-shop-btn .wp-block-navigation-item__content:hover {
    background: #774b98 !important;
    color: #fff !important;
    text-decoration: none !important;
}

/* ── Reset ────────────────────────────────────────────────────────────── */
html, body { margin-top: 0 !important; }
body.admin-bar { margin-top: 32px !important; }
@media screen and (max-width: 782px) { body.admin-bar { margin-top: 46px !important; } }
body { overflow-x: clip; }
.wp-site-blocks { padding-top: 0 !important; }
:where(.wp-site-blocks) > * { margin-block-start: 0 !important; }

/* Responsive gutters — 16px mobile, 40px desktop (matches nav padding) */
@media (max-width: 767px) {
  :root {
    --wp--style--root--padding-left:  16px !important;
    --wp--style--root--padding-right: 16px !important;
  }
}

*, *::before, *::after { box-sizing: border-box; }

/* ── Base ─────────────────────────────────────────────────────────────── */
body {
  font-family: var(--font-body);
  color: var(--clr-text);
  background-color: var(--clr-bg);
  line-height: 1.5;
}

/* Fluid h2: scales from 28px (mobile) up to 48px (desktop ≥1200px) */
h2.wp-block-heading {
  font-size: clamp(1.75rem, 3.5vw, 3rem) !important;
}

/* ── Buttons ──────────────────────────────────────────────────────────── */
.wp-block-button__link {
  border-radius: 5px !important;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 16px;
  padding: 12px 28px;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

/* Primary (filled) */
.wp-block-button:not(.is-style-outline) .wp-block-button__link {
  background-color: var(--clr-primary-dark) !important;
  color: #ffffff !important;
  border: none;
}
.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
  transform: scale(1.03);
  box-shadow: var(--shadow-md);
}

/* Secondary (outline) */
.wp-block-button.is-style-outline .wp-block-button__link {
  background-color: transparent !important;
  color: var(--clr-secondary) !important;
  border: 2px solid var(--clr-secondary) !important;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background-color: var(--clr-secondary) !important;
  color: #ffffff !important;
}
.editor-styles-wrapper .wp-block-button:not(.is-style-outline) .wp-block-button__link:hover { transform: scale(1.03); box-shadow: var(--shadow-md); }
.editor-styles-wrapper .wp-block-button.is-style-outline .wp-block-button__link:hover { background-color: var(--clr-secondary) !important; color: #ffffff !important; }

/* Ghost button (Login) */
.wp-block-button.is-style-ghost .wp-block-button__link {
  background: transparent !important;
  color: var(--clr-primary-dark) !important;
  border: none !important;
  font-weight: 700;
  padding: 8px 16px;
}
.wp-block-button.is-style-ghost .wp-block-button__link:hover {
  background: var(--clr-surface-teal) !important;
  transform: none;
  box-shadow: none;
}
.editor-styles-wrapper .wp-block-button.is-style-ghost .wp-block-button__link:hover {
  background: var(--clr-surface-teal) !important;
}

/* ── Sponsor Banner ──────────────────────────────────────────────────── */
.sponsor-banner {
  background: #fff;
  padding-block: var(--wp--preset--spacing--6);
  text-align: center;
}
.sponsor-banner .wp-block-paragraph { margin-block-end: 0; }
.sponsor-banner .sponsor-label { color: #4a4a4a; }
.sponsor-banner .sponsor-logo img {
  max-width: 300px;
  width: 100%;
  height: auto;
  margin-top: 8px;
}

/* ── Footer ───────────────────────────────────────────────────────────── */
.site-footer {
  border-top: 1px solid #bccac2; /* outline-variant */
}
.site-footer .wp-block-site-title {
  margin-bottom: var(--space-2);
}
.site-footer .wp-block-site-title a {
  color: var(--clr-primary-dark) !important;
  text-decoration: none;
  font-size: 1.5rem;
}
.site-footer h3.wp-block-heading {
  font-size: 1.125rem;
  font-weight: 700;
  color: #121e1a;
  margin-bottom: var(--space-2);
}
.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer-links li { margin-bottom: var(--space-1); }
.footer-links a {
  color: #3d4943;
  text-decoration: none;
  font-size: 1rem;
  transition: color 0.15s ease;
}
.footer-links a:hover {
  color: var(--clr-secondary);
  text-decoration: underline;
}
.footer-nfp-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--clr-secondary);
  font-weight: 700;
  font-size: 0.875rem;
}
.footer-nfp-badge::before {
  content: 'award_star';
  font-family: 'Material Symbols Outlined';
  font-size: 18px;
  font-weight: 400;
  line-height: 1;
  vertical-align: middle;
}
.footer-divider { opacity: 0.25; }

/* ── Feature Cards ────────────────────────────────────────────────────── */
.feature-card {
  background: #ffffff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-4);
  transition: box-shadow 0.2s ease, transform 0.2s ease;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.feature-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

/* ── Chips / Tags ─────────────────────────────────────────────────────── */
.tag-chip {
  display: inline-block;
  background: rgba(119, 75, 152, 0.12);
  color: var(--clr-secondary);
  border-radius: var(--radius-full);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  padding: 4px 12px;
  text-transform: uppercase;
}

/* ── Section label ────────────────────────────────────────────────────── */
.section-label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--clr-secondary);
}

/* ── Hero Section ─────────────────────────────────────────────────────────── */

/* Background image replaces the cover block's default colour overlay */
.hero-section.wp-block-cover {
  background-image: url('/wp-content/uploads/2026/05/CAPEA2022-09460-1024x683.jpg') !important;
  background-size: cover !important;
  background-position: center !important;
}
/* Directional gradient overlay */
.hero-section .wp-block-cover__background {
  background: linear-gradient(to right, rgba(0,67,49,0.92) 0%, rgba(0,67,49,0.72) 40%, rgba(0,67,49,0.15) 68%, transparent 85%) !important;
  opacity: 1 !important;
}
/* Mirror constrained-layout math: 1280px content + 2×40px root padding = 1360px */
.hero-section .wp-block-cover__inner-container {
  max-width: 1360px !important;
  width: 100% !important;
  margin-inline: auto !important;
  padding-inline: var(--space-2) !important;
}
@media (min-width: 1024px) {
  .hero-section .wp-block-cover__inner-container {
    padding-inline: 40px !important;
  }
}
/* Text column */
.hero-text-col { max-width: 672px; }

/* Block spacing */
.hero-text-col .tag-chip {
  background: var(--clr-secondary);
  color: #ffffff;
  display: inline-block;
  width: fit-content;
  border-radius: 4px;
  font-size: 12px;
  padding: 4px 12px;
  margin-top: 0 !important;
  margin-bottom: 24px !important;
}
.hero-text-col h1.wp-block-heading {
  font-family: var(--font-hed);
  line-height: 1.15 !important;
  letter-spacing: -0.02em !important;
  margin-top: 0 !important;
  margin-bottom: 24px !important;
}
.hero-text-col .hero-body {
  font-size: 1.125rem;
  line-height: 1.6;
  opacity: 0.9;
  margin-top: 0 !important;
  margin-bottom: 40px !important;
}
.hero-text-col .wp-block-buttons {
  margin-top: 0 !important;
  gap: 16px !important;
}
/* Hero button size matches Stitch px-8 py-4 */
.hero-btn-primary .wp-block-button__link,
.wp-block-button.is-style-outline.hero-btn-outline .wp-block-button__link {
  padding: 16px 32px !important;
}
.hero-btn-primary .wp-block-button__link {
  background: var(--clr-primary) !important;
  color: #004331 !important;
  border: none !important;
  font-weight: 700 !important;
}
.hero-btn-primary .wp-block-button__link:hover { opacity: 0.9; }
.wp-block-button.is-style-outline.hero-btn-outline .wp-block-button__link {
  background: var(--clr-secondary) !important;
  color: #ffffff !important;
  border: none !important;
  font-weight: 700 !important;
}
.wp-block-button.is-style-outline.hero-btn-outline .wp-block-button__link:hover {
  background: #ffffff !important;
  color: var(--clr-secondary) !important;
}

/* ── Card Icons (Material Symbols as text) ────────────────────────────────── */
/* font-family !important needed: editor-styles-wrapper resets font-family on p at higher cascade priority */
.card-icon,
.editor-styles-wrapper .card-icon {
  font-family: 'Material Symbols Outlined' !important;
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  font-size: 36px;
  font-weight: 400;
  line-height: 1;
  text-transform: none;
  white-space: nowrap;
  color: var(--clr-primary);
  margin-bottom: var(--space-2) !important;
}
.card-icon--secondary,
.editor-styles-wrapper .card-icon--secondary { color: var(--clr-secondary); }

/* ── Card Links ──────────────────────────────────────────────────────────── */
.card-link { margin-top: auto !important; padding-top: var(--space-2); font-weight: 700; font-size: 0.9rem; }
.card-link a { color: var(--clr-primary-dark); text-decoration: none; }
.card-link a:hover { color: var(--clr-primary-dark); }
.card-link--secondary a { color: var(--clr-secondary); }
.card-link--secondary a:hover { color: #5e337e; }
.feature-card--secondary { border-top: 3px solid var(--clr-secondary); }

/* ── Section Photos ──────────────────────────────────────────────────────── */
.section-photo { width: 100%; border-radius: var(--radius); overflow: hidden; box-shadow: 0 20px 40px -15px rgba(0,108,80,0.1); }
.section-photo img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; }

/* Standards book column — image fills exactly the left column's height.
   The wrap is absolutely positioned so the right column has no intrinsic
   height and the flex row height is set by the left column alone. */
.wp-block-column:has(.standards-img-wrap) {
  position: relative;
}
/* On mobile (columns stacked), give the image column a floor so it shows */
@media (max-width: 599px) {
  .wp-block-column:has(.standards-img-wrap) {
    min-height: 380px;
  }
}
.standards-img-wrap {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
}
.standards-edition-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: var(--clr-secondary);
  color: #ffffff;
  padding: 0.35rem 1rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 20px;
  z-index: 2;
  margin: 0 !important;
  box-shadow: 0 4px 14px rgba(119,75,152,0.45);
}
.standards-book-img {
  flex: 1;
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(0,0,0,0.18);
  border: 1px solid var(--clr-outline);
  border-radius: 4px;
  transition: box-shadow 0.2s ease;
}
.standards-book-img:hover { box-shadow: 0 16px 40px rgba(0,0,0,0.28); }
.standards-book-img a { display: block; height: 100%; }
.standards-book-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.35s ease;
}
.standards-book-img:hover img { transform: scale(1.03); }

/* Assessment tool image */
.assessment-tool-img { width: 75%; margin: 0 auto; border-radius: var(--radius); overflow: hidden; transform: rotate(3deg); transition: transform 0.7s ease; }
.assessment-tool-img:hover { transform: rotate(0deg); }
.assessment-tool-img img { width: 100%; display: block; }

/* Legacy placeholder (kept for any remaining SVGs) */
.placeholder-img-block { width: 100%; border-radius: var(--radius-xl); overflow: hidden; }
.placeholder-img-block img { width: 100%; display: block; }

/* ── National Standards — Milestone Boxes ────────────────────────────────── */
.milestone-row.wp-block-columns { gap: 8px !important; }

.milestone-box {
  border: 1.5px solid rgba(67, 183, 144, 0.45);
  border-radius: 10px;
  padding: 16px 10px;
  text-align: center;
  background: rgba(67, 183, 144, 0.09);
}
.milestone-year {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--clr-primary-dark);
  margin-bottom: 4px !important;
  line-height: 1.2 !important;
}
.milestone-label {
  font-size: 10px !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--clr-text-secondary);
  font-weight: 700;
  margin: 0 !important;
}
.milestone-box-featured { background: rgba(119, 75, 152, 0.09); border-color: rgba(119, 75, 152, 0.45); }
.milestone-box-featured .milestone-year,
.milestone-box-featured .milestone-label { color: var(--clr-secondary); }

/* Trophy icon beside section label */
.section-trophy-icon,
.editor-styles-wrapper .section-trophy-icon {
  font-family: 'Material Symbols Outlined' !important;
  font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 20;
  font-size: 18px;
  line-height: 1;
  text-transform: none;
  white-space: nowrap;
  color: var(--clr-secondary);
  margin: 0 !important;
}

/* ── Benefit Cards ───────────────────────────────────────────────────────── */
.benefit-card {
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius);
  padding: var(--space-4) !important;
  background: rgba(255,255,255,0.06);
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
  text-align: center;
}
.benefit-card:hover { background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.22); transform: translateY(-2px); }
.benefit-card .wp-block-heading { font-size: 1rem; font-weight: 700; color: #ffffff; margin-bottom: var(--space-1) !important; }
.benefit-card p:not(.card-icon) { font-size: 0.9rem; line-height: 1.5; margin: 0 !important; color: rgba(255,255,255,0.95) !important; }
.benefit-card .card-icon,
.editor-styles-wrapper .benefit-card .card-icon { color: #ffffff !important; }

/* ── Assessment Tool Dark Section ────────────────────────────────────────── */
.section-assessment {
  position: relative;
  overflow: hidden;
  background-color: #2d1b36;
  color: #ffffff;
}
.section-assessment::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 33%;
  height: 100%;
  background: #7e57c2;
  opacity: 0.15;
  filter: blur(80px);
  pointer-events: none;
}
.section-assessment .assessment-heading { color: #ffffff; font-size: 1.75rem; line-height: 1.3; }
.section-assessment .assessment-body { color: rgba(255,255,255,0.95); font-size: 1.05rem; line-height: 1.6; }
.pdf-badge {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 16px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 5px;
  padding: 24px !important;
  margin-top: var(--space-4) !important;
}
.pdf-badge__icon {
  font-family: 'Material Symbols Outlined' !important;
  font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 48;
  font-size: 48px;
  line-height: 1;
  color: var(--clr-secondary);
  margin: 0 !important;
  text-transform: none;
  white-space: nowrap;
  flex-shrink: 0;
}
.pdf-badge__text { display: flex; flex-direction: column; gap: 4px; margin: 0 !important; }
.pdf-badge__name { font-weight: 700; font-size: 0.95rem; color: #ffffff; margin: 0 !important; }
.pdf-badge__meta { font-size: 0.875rem; color: rgba(255,255,255,0.95); margin: 0 !important; }
.btn-icon {
  font-family: 'Material Symbols Outlined' !important;
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 20;
  font-size: 1.1em;
  line-height: 1;
  vertical-align: middle;
  margin-right: 4px;
  text-transform: none;
  white-space: nowrap;
}

.wp-block-button.btn-download-purple .wp-block-button__link {
  background: var(--clr-secondary) !important;
  color: #ffffff !important;
  border: none !important;
}
.wp-block-button.btn-download-purple .wp-block-button__link:hover { opacity: 0.9; transform: scale(1.02); }

/* ── Pricing Cards ───────────────────────────────────────────────────────── */
/* equal-height columns */
.wp-block-columns:has(.pricing-card) { align-items: stretch !important; max-width: 64rem !important; margin-left: auto !important; margin-right: auto !important; }
.wp-block-column:has(.pricing-card) { display: flex !important; flex-direction: column; overflow: visible !important; }

.pricing-card {
  background: #ffffff;
  border-radius: var(--radius-xl) !important;
  padding: var(--space-8) !important;
  box-shadow: var(--shadow-md);
  border: 1px solid #e4f1eb;
  display: flex !important;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex: 1 !important;
}
.pricing-card-featured { background: var(--clr-secondary) !important; border-color: transparent !important; box-shadow: 0 8px 40px rgba(119,75,152,0.4) !important; position: relative !important; overflow: visible !important; }
.pricing-plan-name { font-size: 1.35rem !important; font-weight: 700 !important; color: var(--clr-primary-dark); margin-bottom: 0 !important; }
.pricing-card-featured .pricing-plan-name { color: #ffffff !important; }
.pricing-price { font-size: 3rem; font-weight: 700; color: var(--clr-primary-dark); margin-top: 0 !important; margin-bottom: 0.25rem !important; line-height: 1; }
.pricing-currency { font-size: inherit; font-weight: inherit; vertical-align: baseline; }
.pricing-period { font-size: 1rem; font-weight: 400; color: var(--clr-text-secondary); margin-left: 4px; }
.pricing-save { font-size: 0.8rem; font-weight: 700; color: var(--clr-secondary); margin-bottom: 0 !important; margin-top: 0 !important; letter-spacing: 0.05em; }
.pricing-card-featured .pricing-price { color: #ffffff !important; }
.pricing-card-featured .pricing-period { color: rgba(255,255,255,0.95) !important; }
.pricing-card-featured .pricing-save { color: #ffffff !important; }
.pricing-badge {
  position: absolute;
  top: -16px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--clr-secondary);
  border: none;
  color: #ffffff;
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: 700;
  padding: 5px 20px;
  white-space: nowrap;
  margin: 0 !important;
}
.pricing-features { text-align: left; width: 100%; margin-top: var(--space-5) !important; margin-bottom: var(--space-5) !important; list-style: none !important; padding: 0 !important; flex-grow: 1; }
.pricing-features li { display: flex !important; align-items: center; gap: 12px; padding: 12px 0 !important; border-bottom: 1px solid #e4f1eb; font-size: 0.95rem; color: var(--clr-text-secondary); }
.pricing-features li::before { content: 'check'; font-family: 'Material Symbols Outlined'; font-size: 20px; color: var(--clr-primary); flex-shrink: 0; line-height: 1; }
.pricing-card-featured .pricing-features li { color: rgba(255,255,255,0.95); border-bottom-color: rgba(255,255,255,0.15); }
.pricing-card-featured .pricing-features li::before { color: #ffffff; }
.pricing-card .wp-block-buttons { width: 100% !important; margin-top: 0 !important; }
.pricing-card .wp-block-button { width: 100% !important; }
.wp-block-button.pricing-btn .wp-block-button__link { background: var(--clr-primary-dark) !important; color: #ffffff !important; border: none !important; width: 100% !important; text-align: center; }
.wp-block-button.pricing-btn-featured .wp-block-button__link,
.wp-block-button.pricing-btn-featured .wp-block-button__link:visited { background: #ffffff !important; color: var(--clr-secondary) !important; border: none !important; width: 100% !important; text-align: center; }
.wp-block-button.pricing-btn-featured .wp-block-button__link:hover { background: #ffffff !important; opacity: 0.92; }

/* ── Testimonial Cards ───────────────────────────────────────────────────── */
.wp-block-column:has(.testimonial-card) {
  display: flex !important;
  flex-direction: column !important;
}
.testimonial-card {
  background: rgba(255,255,255,0.1) !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
  border-radius: 16px !important;
  padding: var(--space-5) var(--space-4) var(--space-4) !important;
  display: flex !important;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex: 1 !important;
}
.testimonial-avatar-img {
  width: 5rem;
  height: 5rem;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto var(--space-2) !important;
  border: 3px solid rgba(255,255,255,0.75);
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
  flex-shrink: 0;
}
.testimonial-avatar-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
.testimonial-card__quote { border-left: none !important; padding: 0 !important; margin-bottom: 4px !important; }
.testimonial-card__quote p { font-style: italic; color: rgba(255,255,255,0.95) !important; font-size: 0.975rem !important; line-height: 1.7 !important; }
.testimonial-card__quote cite { font-weight: 700; font-style: normal; color: #ffffff; font-size: 1.05rem; display: block; margin-top: var(--space-4); }
.testimonial-role { font-size: 0.72rem !important; font-weight: 600 !important; letter-spacing: 0.08em !important; text-transform: uppercase !important; color: rgba(255,255,255,0.95) !important; margin: 4px 0 0 !important; }

/* ── Benefits Join Button (white on green) ───────────────────────────────── */
.wp-block-button.benefits-join-btn .wp-block-button__link {
  background: #ffffff !important;
  color: var(--clr-primary-dark) !important;
  border: none !important;
  font-weight: 700;
}
.wp-block-button.benefits-join-btn .wp-block-button__link:hover {
  background: var(--wp--preset--color--surface) !important;
  transform: scale(1.03);
}

/* ── Newsletter CTA ──────────────────────────────────────────────────────── */
.cta-inner { position: relative; overflow: hidden; }
.cta-inner::after {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 40%; height: 100%;
  background: radial-gradient(circle at center, rgba(255,255,255,0.08), transparent 70%);
  pointer-events: none;
}
.cta-inner h2 { line-height: 1.2; }
.cta-subscribe-btn .wp-block-button__link { background: #ffffff !important; color: var(--clr-primary-dark) !important; border: none !important; font-weight: 700; }
.cta-subscribe-btn .wp-block-button__link:hover { background: var(--clr-surface) !important; transform: scale(1.03); }

/* Newsletter subscription form on dark CTA background */
.cta-inner .tnp { margin-top: var(--wp--preset--spacing--5); }
.cta-inner .tnp form { text-align: left !important; }
.cta-inner .tnp-email {
    width: 100%;
    box-sizing: border-box;
    padding: 12px 16px;
    border: 2px solid rgba(255,255,255,0.4) !important;
    border-radius: 4px;
    background: rgba(255,255,255,0.1) !important;
    color: #fff !important;
    font-size: 1rem;
    font-family: var(--font-body);
    margin-bottom: 12px;
}
.cta-inner .tnp-email::placeholder { color: rgba(255,255,255,0.75) !important; }
.cta-inner .tnp-email:focus { outline: none; border-color: #fff; background: rgba(255,255,255,0.2); }
.cta-inner .tnp-field-button { text-align: left !important; }
.cta-inner input.tnp-submit {
    -webkit-appearance: none;
    appearance: none;
    display: inline-block;
    width: auto !important;
    padding: 12px 28px !important;
    background: #fff !important;
    color: var(--clr-primary-dark) !important;
    border: none !important;
    border-radius: 5px !important;
    font-family: var(--font-body) !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.cta-inner input.tnp-submit:hover { background: var(--clr-surface) !important; transform: scale(1.03); box-shadow: var(--shadow-md); }
.cta-inner .cf-turnstile { margin-top: 12px; }
.cta-inner .tnp-privacy-field { margin-top: 10px; color: rgba(255,255,255,0.95); font-size: 0.875rem; }
.cta-inner .tnp-privacy-field a { color: #fff; }

/* ── FAQ Section ─────────────────────────────────────────────────────────── */
.faq-list { max-width: 720px !important; margin-inline: auto !important; }
.faq-col { max-width: none !important; margin-inline: 0 !important; }
.faq-item {
  background: #ffffff;
  border-radius: var(--radius-lg) !important;
  border: 1px solid #e4f1eb;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  margin-bottom: var(--space-2);
}
.faq-item summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-3) var(--space-4);
  cursor: pointer;
  font-weight: 700;
  font-size: 1rem;
  color: var(--clr-text);
  list-style: none;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: 'expand_more';
  font-family: 'Material Symbols Outlined';
  font-size: 20px;
  color: var(--clr-secondary);
  transition: transform 0.25s ease;
  flex-shrink: 0;
  margin-left: var(--space-2);
}
.faq-item[open] summary::after { transform: rotate(180deg); }
.faq-item[open] { border-color: var(--clr-secondary); }

/* ── Off-canvas Mobile Nav ────────────────────────────────────────────── */

.mobile-menu-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: none;
  background: transparent;
  cursor: pointer;
  border-radius: 50%;
  color: var(--clr-primary-dark);
  transition: background 0.15s ease;
  padding: 0;
  flex-shrink: 0;
}
.mobile-menu-toggle:hover { background: #e9f7f1; }
.mobile-menu-toggle__icon {
  font-family: 'Material Symbols Outlined';
  font-size: 24px;
  font-weight: 400;
  line-height: 1;
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  text-transform: none;
  white-space: nowrap;
}
@media (max-width: 1023px) {
  .mobile-menu-toggle { display: flex; }
}

.mobile-nav-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 200;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.mobile-nav-overlay.is-open {
  opacity: 1;
  pointer-events: all;
}

.mobile-nav-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: min(320px, 88vw);
  height: 100%;
  background: #ffffff;
  z-index: 300;
  transform: translateX(100%);
  transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  flex-direction: column;
  box-shadow: -4px 0 32px rgba(0, 0, 0, 0.16);
  list-style: none;
  padding: 0;
  margin: 0;
}
.mobile-nav-drawer.is-open { transform: translateX(0); }

.mobile-nav-drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 20px 20px 24px;
  border-bottom: 1px solid #e4f1eb;
  flex-shrink: 0;
}
.mobile-nav-drawer__site-name {
  font-family: var(--font-hed);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--clr-primary-dark);
}
.mobile-nav-drawer__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: none;
  background: transparent;
  cursor: pointer;
  border-radius: 50%;
  color: var(--clr-primary-dark);
  transition: background 0.15s ease;
  padding: 0;
}
.mobile-nav-drawer__close:hover { background: #e9f7f1; }
.mobile-nav-drawer__close span {
  font-family: 'Material Symbols Outlined';
  font-size: 22px;
  font-weight: 400;
  line-height: 1;
  text-transform: none;
  white-space: nowrap;
}

.mobile-nav-drawer__links {
  list-style: none;
  margin: 0;
  padding: 8px 0;
  flex: 1;
  overflow-y: auto;
}
.mobile-nav-drawer__links li { border-bottom: 1px solid #f0f7f4; }
.mobile-nav-drawer__links li a {
  display: block;
  padding: 16px 24px;
  font-size: 1.05rem;
  font-weight: 500;
  color: #3d4943;
  text-decoration: none;
  transition: color 0.15s ease, background 0.15s ease;
}
.mobile-nav-drawer__links li a:hover {
  color: var(--clr-primary);
  background: #f0faf6;
}

.mobile-nav-drawer__footer {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 20px 24px 32px;
  border-top: 1px solid #e4f1eb;
  flex-shrink: 0;
}
.mobile-nav-drawer__login {
  display: block;
  text-align: center;
  padding: 12px 20px;
  border-radius: 5px;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--clr-primary-dark);
  text-decoration: none;
  border: 2px solid var(--clr-primary);
  transition: background 0.15s ease;
}
.mobile-nav-drawer__login:hover { background: #e9f7f1; }
.mobile-nav-drawer__join {
  display: block;
  text-align: center;
  padding: 12px 20px;
  border-radius: 5px;
  font-size: 0.95rem;
  font-weight: 700;
  color: #ffffff;
  text-decoration: none;
  background: var(--clr-primary);
  transition: opacity 0.15s ease;
}
.mobile-nav-drawer__join:hover { opacity: 0.9; }

body.menu-open { overflow: hidden; }

/* ── Mobile Responsiveness ────────────────────────────────────────────── */

/* Benefits grid: 4-col → 2-col → 1-col */
@media (max-width: 767px) {
  .benefits-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 479px) {
  .benefits-grid { grid-template-columns: minmax(0, 1fr) !important; }
}

/* Hero: reduce height on small screens */
@media (max-width: 767px) {
  .hero-section.wp-block-cover { min-height: 580px !important; }
}
@media (max-width: 479px) {
  .hero-section.wp-block-cover { min-height: 480px !important; }
  .hero-text-col .wp-block-buttons { flex-direction: column !important; align-items: flex-start !important; }
  .hero-btn-primary .wp-block-button__link,
  .wp-block-button.is-style-outline.hero-btn-outline .wp-block-button__link { padding: 14px 24px !important; }
}

/* Pricing cards: tighten padding on small screens */
@media (max-width: 599px) {
  .pricing-card { padding: var(--space-6) var(--space-4) !important; }
}

/* Testimonial cards: tighten padding on small screens */
@media (max-width: 599px) {
  .testimonial-card { padding: var(--space-3) var(--space-3) var(--space-3) !important; }
}

/* CTA inner: reduce padding on mobile */
@media (max-width: 767px) {
  .cta-inner {
    padding-top: var(--space-8) !important;
    padding-right: var(--space-4) !important;
    padding-bottom: var(--space-8) !important;
    padding-left: var(--space-4) !important;
  }
}

/* Footer: reduce block padding when columns stack */
@media (max-width: 767px) {
  .site-footer .wp-block-columns {
    padding-top: var(--wp--preset--spacing--8) !important;    /* 64px → was 96px */
    padding-bottom: var(--wp--preset--spacing--5) !important; /* 40px → was 80px */
  }
}

/* Bento cards (philosophy/goals pages): remove fixed min-height when columns stack */
@media (max-width: 781px) {
  .capea-bento-card-teal,
  .capea-bento-card-green {
    min-height: auto !important;
  }
}
.faq-item p { padding: 0 var(--space-4) var(--space-4); color: var(--clr-text-secondary); line-height: 1.65; margin: 0 !important; }

/* ── Full-width section layout (page-no-title template) ──────────────── */
/* Remove inter-block gaps so full-width coloured sections sit flush */
.wp-block-post-content > .alignfull,
.wp-block-post-content > .wp-block-cover.alignfull {
  margin-block: 0 !important;
}

/* ════════════════════════════════════════════════════════════════════
   About CAPEA page styles — adapted to capea2 palette
   ════════════════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Accordion — wp:details block
   ═══════════════════════════════════ */
.wp-block-details.capea-details {
  border: 1px solid var(--clr-surface-container);
  border-radius: 8px;
  margin-bottom: 8px;
  padding: 0;
  overflow: hidden;
  background: #fff;
}

.wp-block-details.capea-details > summary {
  background: #fff;
  color: var(--clr-primary-dark);
  font-weight: 600;
  font-size: 1rem;
  padding: 16px 20px;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  list-style: none;
  border: none;
}

.wp-block-details.capea-details > summary::-webkit-details-marker { display: none; }

.wp-block-details.capea-details > summary::after {
  content: "+";
  font-size: 1.5rem;
  font-weight: 300;
  flex-shrink: 0;
  margin-left: 12px;
  transition: transform .2s;
}

.wp-block-details.capea-details[open] > summary {
  background: var(--clr-surface);
  border-bottom: 1px solid var(--clr-surface-container);
}

.wp-block-details.capea-details[open] > summary::after { transform: rotate(45deg); }

.wp-block-details.capea-details > *:not(summary) { padding: 16px 20px 20px; }

/* ═══════════════════════════════════
   Certification Page — Sections
   ═══════════════════════════════════ */
.capea-section-white {
  background: #ffffff;
  padding: 64px 24px !important;
}

.capea-section-teal {
  background: var(--clr-primary-dark) !important;
  padding: 64px 24px !important;
}

.capea-section-light {
  background: var(--clr-surface-teal);
  padding: 64px 24px !important;
}

.capea-section-purple {
  background: var(--clr-secondary);
  padding: 64px 24px !important;
}

/* ═══════════════════════════════════
   Certification Page — Hero
   ═══════════════════════════════════ */
.capea-hero-h1 {
  color: #ffffff !important;
  font-size: clamp(2.2rem, 4vw + 0.5rem, 3.375rem) !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  text-shadow: 0 2px 8px rgba(0,0,0,0.4);
  margin-bottom: 16px !important;
}

.capea-hero-sub {
  color: rgba(255,255,255,0.95) !important;
  font-size: 1.15rem !important;
  text-shadow: 0 1px 4px rgba(0,0,0,0.3);
  max-width: 65ch;
  /* Replicate the H1's constrained-layout centering offset so both share the same left edge */
  margin-left: max(0px, calc((100% - 1280px) / 2)) !important;
  margin-right: auto !important;
}
/* When the hero-sub is explicitly centered, use standard auto-centering */
.has-text-align-center.capea-hero-sub {
  margin-left: auto !important;
  margin-right: auto !important;
}

/* ═══════════════════════════════════
   Certification Page — Headings
   ═══════════════════════════════════ */
.capea-h2-teal   { color: var(--clr-primary-dark) !important; }

.capea-h2-white  { color: #ffffff !important; }

.capea-h3-teal   { color: var(--clr-primary-dark) !important; margin-top: 8px !important; }

.capea-h3-white  { color: #ffffff !important; margin: 8px 0 6px !important; }

.capea-subheading { color: var(--clr-muted) !important; font-size: 1.1rem !important; margin-bottom: 40px !important; }

/* ═══════════════════════════════════
   Certification Page — Intro image
   ═══════════════════════════════════ */
.capea-intro-img img {
  border-radius: 12px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.12);
}

/* ═══════════════════════════════════
   Certification Page — Benefit cards
   ═══════════════════════════════════ */
.capea-benefit-row { margin-bottom: 0 !important; }

.capea-benefit-col {
  background: rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 28px 20px !important;
  text-align: center;
}

.capea-benefit-icon {
  font-size: 2.4rem !important;
  margin-bottom: 10px !important;
  line-height: 1 !important;
}

.capea-benefit-text { color: rgba(255,255,255,0.95) !important; font-size: 0.95rem !important; }

.capea-cta-sub {
  color: rgba(255,255,255,0.95) !important;
  font-size: 1.05rem !important;
  max-width: 600px;
  margin: 0 auto 32px !important;
}

/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.wp-block-button.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.wp-block-button.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

.wp-block-button.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* ═══════════════════════════════════
   Responsive
   ═══════════════════════════════════ */
@media (max-width: 768px) {
  .capea-section-white,
  .capea-section-teal,
  .capea-section-light,
  .capea-section-purple { padding: 48px 16px !important; }
  .capea-benefit-col { margin-bottom: 12px; }
}

/* ═══════════════════════════════════
   Membership Page — Testimonials
   ═══════════════════════════════════ */
.capea-testimonial-col {
  background: rgba(255,255,255,0.1);
  border-radius: 16px;
  padding: 32px 28px !important;
}

.capea-testimonial-quote {
  color: rgba(255,255,255,0.95) !important;
  font-size: 1rem !important;
  line-height: 1.7 !important;
  font-style: italic;
  margin-bottom: 16px !important;
}

.capea-testimonial-author {
  color: rgba(255,255,255,0.95) !important;
  font-size: 0.9rem !important;
  margin: 0 !important;
}

.capea-testimonial-author strong {
  color: #ffffff !important;
  display: block;
  margin-bottom: 2px;
}

/* ═══════════════════════════════════
   Membership Page — Sponsor & CTA
   ═══════════════════════════════════ */
.capea-cta-sub--dark { color: var(--clr-muted) !important; }

/* ═══════════════════════════════════
   Responsive additions
   ═══════════════════════════════════ */
@media (max-width: 768px) {
  .capea-price-card { padding: 28px 20px !important; }
  .capea-price-tag { font-size: 2.2rem !important; }
  .capea-testimonial-col { padding: 24px 20px !important; }
}

.capea-testimonial-quote {
  color: rgba(255,255,255,0.95) !important;
  font-size: 0.95rem !important;
  font-style: italic;
  line-height: 1.75 !important;
  margin-bottom: 20px !important;
}

/* ============================================
   ABOUT CAPEA PAGE STYLES
   ============================================ */

/* Light section background */
.capea-section-light {
    background-color: var(--clr-surface-teal) !important;
    padding: 60px 20px !important;
}

/* Mission strip / stat bar */
.capea-mission-strip,
.capea-section-teal:has(.capea-stat-row) {
    padding: 28px 20px !important;
}

.capea-stat-row {
    align-items: center !important;
    gap: 0 !important;
    margin-bottom: 0 !important;
}

.capea-stat-item {
    text-align: center;
    padding: 20px;
    border-right: 1px solid rgba(255,255,255,0.2);
}

.capea-stat-item:last-child {
    border-right: none;
}

.capea-stat-item--center {
    border-left: 1px solid rgba(255,255,255,0.2);
    border-right: 1px solid rgba(255,255,255,0.2);
}

.capea-stat-number {
    font-size: 2.2rem !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    margin: 0 0 4px !important;
    margin-block-start: 0 !important;
    line-height: 1.1 !important;
}

.capea-stat-label {
    font-size: 0.82rem !important;
    color: rgba(255,255,255,0.95) !important;
    margin: 0 !important;
    margin-block-start: 0 !important;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.capea-stat-icon {
    font-size: 2rem !important;
    margin: 0 0 8px !important;
    line-height: 1 !important;
    display: block;
}

.capea-stat-vision {
    font-size: 1.2rem !important;
    color: #ffffff !important;
    margin: 0 0 6px !important;
    margin-block-start: 0 !important;
    font-weight: 600 !important;
}

.capea-stat-purpose {
    font-size: 0.9rem !important;
    color: rgba(255,255,255,0.95) !important;
    margin: 0 !important;
    margin-block-start: 0 !important;
    font-style: italic;
}

/* Navigation cards */
.capea-nav-card-row {
    gap: 20px !important;
    margin-bottom: 20px !important;
}

.capea-nav-card {
    background: #ffffff !important;
    border: 1px solid var(--clr-surface-container) !important;
    border-radius: 12px !important;
    padding: 28px 20px !important;
    transition: box-shadow 0.2s, transform 0.2s !important;
    display: flex !important;
    flex-direction: column !important;
}

.capea-nav-card:hover {
    box-shadow: 0 6px 24px rgba(0,128,128,0.12) !important;
    transform: translateY(-3px) !important;
}

.capea-nav-card p.capea-nav-card-icon {
    font-size: 2.2rem !important;
    margin: 0 0 12px !important;
    line-height: 1 !important;
}

.capea-nav-card h3 {
    font-size: 1rem !important;
    margin-bottom: 8px !important;
    line-height: 1.3 !important;
}

.capea-nav-card p {
    font-size: 0.88rem !important;
    color: var(--clr-muted) !important;
    flex-grow: 1;
    margin-bottom: 16px !important;
}

.capea-nav-card .wp-block-buttons {
    margin-top: auto !important;
}

/* Small teal button variant */
.wp-block-button.capea-btn-teal-sm .wp-block-button__link {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    transition: background-color 0.2s !important;
}

.wp-block-button.capea-btn-teal-sm .wp-block-button__link:hover {
    background-color: var(--clr-primary-dark) !important;
}

/* Strategic plan columns */
.capea-strat-col {
    background: rgba(255,255,255,0.12) !important;
    border-radius: 10px !important;
    padding: 24px 16px !important;
}

/* Key events section */
.capea-key-events {
    margin-top: 40px !important;
    background: rgba(255,255,255,0.1) !important;
    border-radius: 12px !important;
    padding: 28px !important;
}

.capea-event-item {
    text-align: center;
    padding: 12px;
    border-right: 1px solid rgba(255,255,255,0.2);
}

.capea-event-item:last-child {
    border-right: none;
}

.capea-event-date {
    font-size: 0.8rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    color: rgba(255,255,255,0.95) !important;
    margin: 0 0 4px !important;
}

.capea-event-title {
    color: #ffffff !important;
    font-size: 1rem !important;
    margin: 0 0 6px !important;
}

.capea-event-theme {
    font-size: 0.82rem !important;
    color: rgba(255,255,255,0.95) !important;
    font-style: italic !important;
    margin: 0 !important;
}

/* Hall of Fame table */
.capea-hof-table,
.capea-hof-table--purple {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.capea-hof-table table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 0.9rem !important;
}

.capea-hof-table th {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    padding: 10px 14px !important;
    text-align: left !important;
    font-weight: 600 !important;
}

.capea-hof-table td {
    padding: 9px 14px !important;
    border-bottom: 1px solid var(--clr-surface-container) !important;
    color: var(--clr-text) !important;
}

.capea-hof-table tr:nth-child(even) td {
    background-color: var(--clr-surface-teal) !important;
}

.capea-hof-table tr:hover td {
    background-color: var(--clr-surface) !important;
}

/* Executive board cards */
.capea-board-row {
    gap: 16px !important;
}

.capea-board-card {
    background: var(--clr-surface-teal) !important;
    border: 1px solid var(--clr-surface-container) !important;
    border-radius: 10px !important;
    padding: 24px 16px !important;
    text-align: center;
}

.capea-board-card h3 {
    font-size: 0.95rem !important;
    margin-bottom: 4px !important;
}

.capea-board-role {
    font-size: 0.82rem !important;
    color: var(--clr-primary-dark) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    margin: 0 !important;
}

/* Goal list */
.capea-goal-list {
    list-style: none !important;
    padding: 0 !important;
}

.capea-goal-list li {
    padding: 10px 0 10px 28px !important;
    border-bottom: 1px solid rgba(255,255,255,0.15) !important;
    position: relative !important;
    color: rgba(255,255,255,0.95) !important;
    font-size: 0.95rem !important;
    line-height: 1.5 !important;
}

.capea-goal-list li::before {
    content: "\2713" !important;
    position: absolute !important;
    left: 0 !important;
    top: 10px !important;
    color: #ffffff !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
}

/* Testimonials */
.capea-testimonial-col {
    background: rgba(255,255,255,0.12) !important;
    border-radius: 12px !important;
    padding: 28px 24px !important;
    border-left: 4px solid rgba(255,255,255,0.4) !important;
}

.capea-testimonial-quote {
    font-size: 1rem !important;
    color: #ffffff !important;
    font-style: italic !important;
    line-height: 1.7 !important;
    margin-bottom: 16px !important;
}

.capea-testimonial-author {
    font-size: 0.85rem !important;
    color: rgba(255,255,255,0.95) !important;
    font-weight: 600 !important;
    margin: 0 !important;
}

/* Responsive: stack nav cards on mobile */
@media (max-width: 768px) {
    .capea-nav-card-row {
        flex-wrap: wrap !important;
    }
    .capea-nav-card {
        min-width: calc(50% - 12px) !important;
    }
    .capea-stat-item {
        border-right: none !important;
        border-bottom: 1px solid rgba(255,255,255,0.2) !important;
    }
    .capea-event-item {
        border-right: none !important;
        border-bottom: 1px solid rgba(255,255,255,0.2) !important;
    }
}

@media (max-width: 480px) {
    .capea-nav-card {
        min-width: 100% !important;
    }
}

/* Fix: benefit text colour in white sections */
.capea-section-white .capea-benefit-text,
.capea-section-light .capea-benefit-text {
    color: #555555 !important;
}

/* Ensure nav card rows wrap nicely */
.capea-nav-card-row {
    gap: 20px;
    margin-bottom: 20px !important;
}

@media (max-width: 768px) {
    .capea-nav-card-row {
        flex-direction: column !important;
    }
    .capea-info-box {
        margin-top: 24px;
    }
}

/* Hall of Fame table on purple background */
.capea-hof-table--purple table {
    background: rgba(255,255,255,0.12) !important;
    border-radius: 10px;
    overflow: hidden;
    width: 100%;
    margin-top: 32px;
    color: #ffffff !important;
}

.capea-hof-table--purple thead {
    background: rgba(0,0,0,0.15) !important;
}

.capea-hof-table--purple th {
    color: #ffffff !important;
    font-weight: 700;
    padding: 12px 16px !important;
    text-align: left;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 0.82rem;
}

.capea-hof-table--purple td {
    color: rgba(255,255,255,0.95) !important;
    padding: 10px 16px !important;
    border-bottom: 1px solid rgba(255,255,255,0.15) !important;
}

.capea-hof-table--purple tr:last-child td {
    border-bottom: none !important;
}

.capea-hof-table--purple tr:hover td {
    background: rgba(255,255,255,0.08);
}

/* Fix: Hall of Fame table row contrast — override WordPress default alternating colours */
.capea-hof-table--purple table tr,
.capea-hof-table--purple table tr td,
.capea-hof-table--purple table tr:nth-child(odd),
.capea-hof-table--purple table tr:nth-child(even),
.capea-hof-table--purple table tbody tr,
.capea-hof-table--purple table tbody tr:nth-child(odd),
.capea-hof-table--purple table tbody tr:nth-child(even) {
    background: transparent !important;
    background-color: transparent !important;
    color: #ffffff !important;
}

.capea-hof-table--purple table tr:nth-child(even) td {
    background: rgba(0,0,0,0.05) !important;
}

.capea-hof-table--purple table tr:nth-child(odd) td {
    background: rgba(0,0,0,0.10) !important;
}

.capea-hof-table--purple table td,
.capea-hof-table--purple table th {
    color: #ffffff !important;
    border-color: rgba(255,255,255,0.15) !important;
}

.capea-hof-table--purple table tr:hover td {
    background: rgba(255,255,255,0.18) !important;
}

.capea-section-white .capea-note {
    color: var(--clr-muted) !important;
}

.capea-section-teal .capea-note {
    color: rgba(255,255,255,0.95) !important;
    background: rgba(255,255,255,0.15);
    border-left-color: rgba(255,255,255,0.5);
}

/* Intro cols vertical alignment on standards page */
.capea-intro-cols .wp-block-column {
    align-self: center;
}
.capea-intro-cols .wp-block-column.is-vertically-aligned-top {
    align-self: flex-start;
}

/* Benefit text on light sections - ensure readability */
.capea-section-light .capea-benefit-text,
.capea-section-white .capea-benefit-text {
    color: #555555 !important;
}

/* Responsive: stack columns on mobile */
@media (max-width: 768px) {
    .capea-standards-cover {
        margin-bottom: 24px;
    }
    .capea-intro-cols {
        flex-direction: column !important;
    }
}

.capea-event-date {
    font-size: 0.9rem !important;
    font-weight: 700 !important;
    color: var(--clr-primary-dark) !important;
    margin-bottom: 4px !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.capea-event-card--featured .capea-event-date {
    color: var(--clr-secondary) !important;
}

.capea-event-title {
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    color: var(--clr-text) !important;
    margin-bottom: 10px !important;
    line-height: 1.3 !important;
}

.capea-event-theme {
    font-size: 0.88rem !important;
    color: var(--clr-muted) !important;
    line-height: 1.5 !important;
    margin-bottom: 8px !important;
}

/* ============================================
   FIX: Restore white text for event classes
   inside dark-background capea-key-events
   (overrides the Strategic Plan card colors)
   ============================================ */
.capea-key-events .capea-event-date {
    color: rgba(255,255,255,0.95) !important;
}

.capea-key-events .capea-event-title,
.capea-key-events .capea-event-title strong {
    color: #ffffff !important;
}

.capea-key-events .capea-event-theme {
    color: rgba(255,255,255,0.95) !important;
}

/* Board member row */
.capea-board-row {
    gap: 16px !important;
    margin-top: 32px !important;
    margin-bottom: 24px !important;
}

/* Board member card */
.capea-board-card {
    background: #ffffff;
    border-radius: 12px;
    padding: 20px 12px !important;
    text-align: center;
    box-shadow: 0 4px 16px rgba(0,0,0,0.12);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.capea-board-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 28px rgba(0,0,0,0.18);
}

.capea-board-role {
    font-size: 0.85rem !important;
    color: var(--clr-primary-dark) !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 0 !important;
}

.capea-org-card .capea-h3-teal {
    color: var(--clr-primary-dark) !important;
    font-size: 1.1rem !important;
    margin-bottom: 12px !important;
}

/* Responsive */
@media (max-width: 900px) {
    .capea-board-row {
        flex-wrap: wrap !important;
    }
    .capea-board-card {
        flex-basis: calc(50% - 16px) !important;
        min-width: 140px;
    }
}

@media (max-width: 600px) {
    .capea-board-card {
        flex-basis: 100% !important;
    }
    .capea-fec-cols {
        flex-direction: column !important;
    }
}

/* Small teal buttons for providers */
.wp-block-button.capea-btn-teal-sm .wp-block-button__link {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.wp-block-button.capea-btn-teal-sm .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
}

.capea-event-title {
    font-size: 1.6rem !important;
    color: var(--clr-primary-dark) !important;
    margin-bottom: 12px !important;
    line-height: 1.3 !important;
}

.capea-event-title-white {
    color: #ffffff !important;
}

.capea-event-theme-label {
    font-size: 1rem !important;
    color: var(--clr-secondary) !important;
    font-weight: 600 !important;
    margin-bottom: 12px !important;
}

/* ============================================
   CAPEA CALENDAR PAGE - MISSING UTILITY CLASSES
   ============================================ */

.capea-subheading-white {
    color: #ffffff !important;
    font-size: 1.1rem !important;
    opacity: 0.95;
}

.capea-event-theme-label {
    font-size: 1rem !important;
    color: var(--clr-secondary) !important;
    font-weight: 600 !important;
    margin-bottom: 12px !important;
}

.capea-event-title {
    font-size: 1.6rem !important;
    color: var(--clr-primary-dark) !important;
    margin-bottom: 12px !important;
    line-height: 1.3 !important;
}

.capea-event-title-white {
    color: #ffffff !important;
}

/* ============================================
   CAPEA BUTTON - TEAL OUTLINE VARIANT
   ============================================ */
.wp-block-button.capea-btn-teal-outline .wp-block-button__link {
    background: transparent !important;
    color: var(--clr-primary-dark) !important;
    border: 2px solid var(--clr-primary-dark) !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
}

.wp-block-button.capea-btn-teal-outline .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

.capea-section-purple .capea-tip-credit { color: rgba(255,255,255,0.95) !important; }

/* Interaction Archive */
.capea-section-purple .rp-int-layout { gap:32px !important; }

.res-social-section .capea-h2-teal { margin: 0 0 14px; }

/* White text benefit cards (on teal bg) */
.capea-benefit-text.mem-white-text,
.mem-white-text { color: rgba(255,255,255,0.95) !important; }

/* White heading variants */
.capea-h2-white { color: #ffffff !important; }

.capea-h3-white { color: #ffffff !important; font-size: 1.2rem !important; font-weight: 700 !important; margin-bottom: 12px !important; }

.capea-subheading-white {
    color: rgba(255,255,255,0.95) !important;
    font-size: 1.05rem !important;
}


/* White btn outline (already in mem- but adding capea- prefix alias) */
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}

/* White button with green text — for use on teal/dark sections */
.wp-block-button.capea-btn-white-green .wp-block-button__link {
    background: #ffffff !important;
    color: var(--clr-primary-dark) !important;
    border: none !important;
    border-radius: 6px !important;
    font-weight: 700 !important;
    padding: 12px 32px !important;
    transition: background 0.2s, color 0.2s !important;
}
.wp-block-button.capea-btn-white-green .wp-block-button__link:hover {
    background: var(--clr-surface) !important;
    color: var(--clr-primary-dark) !important;
}

/* White button, purple text — no border-radius override (inherits global) */
.wp-block-button.capea-btn-white-purple .wp-block-button__link {
    background: #ffffff !important;
    color: var(--clr-secondary) !important;
    border: none !important;
    font-weight: 700 !important;
    padding: 12px 32px !important;
    transition: background 0.2s, color 0.2s !important;
}
.wp-block-button.capea-btn-white-purple .wp-block-button__link:hover {
    background: var(--wp--preset--color--secondary-container) !important;
    color: var(--clr-secondary) !important;
}

/* Purple button with white text and white border
   Specificity (0,3,0) to beat the global green button rule */
.wp-block-button.capea-btn-purple .wp-block-button__link {
    background: var(--clr-secondary) !important;
    color: #ffffff !important;
    border: 2px solid #ffffff !important;
    border-radius: 6px !important;
    font-weight: 700 !important;
    padding: 12px 28px !important;
    transition: background 0.2s, color 0.2s !important;
}
.wp-block-button.capea-btn-purple .wp-block-button__link:hover {
    background: #ffffff !important;
    color: var(--clr-secondary) !important;
    border-color: #ffffff !important;
}

/* ══════════════════════════════════════════════════════════
   history-of-capea — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Certification Page — Intro image
   ═══════════════════════════════════ */
.capea-intro-img img {
  border-radius: 12px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.12);
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* Hall of Fame table */
.capea-hof-table table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 0.9rem !important;
}

.capea-hof-table th {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    padding: 10px 14px !important;
    text-align: left !important;
    font-weight: 600 !important;
}

.capea-hof-table td {
    padding: 9px 14px !important;
    border-bottom: 1px solid var(--clr-surface-container) !important;
    color: var(--clr-text) !important;
}

.capea-hof-table tr:nth-child(even) td {
    background-color: var(--clr-surface-teal) !important;
}

.capea-hof-table tr:hover td {
    background-color: var(--clr-surface) !important;
}

/* ================================================
   History of CAPEA Page
   ================================================ */

/* Timeline infographic image — constrain tall portrait image */
.capea-history-timeline-img img {
    max-height: 600px;
    width: auto !important;
    margin: 0 auto;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.12);
}

/* Pioneer portrait image with caption on teal bg */
.capea-history-portrait {
    text-align: center;
}

.capea-history-portrait img {
    border-radius: 12px;
    box-shadow: 0 6px 24px rgba(0,0,0,0.25);
    max-width: 280px;
    width: 100%;
    margin: 0 auto;
}

.capea-history-portrait figcaption {
    color: rgba(255,255,255,0.95) !important;
    font-size: 0.88rem;
    font-style: italic;
    margin-top: 12px;
    line-height: 1.5;
}

/* Pioneer card on teal background */
.capea-history-pioneer-card {
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.25);
    border-radius: 10px;
    padding: 20px !important;
}

/* Timeline accordion items — numbered style */
.capea-timeline-item {
    border-left: 4px solid var(--clr-primary-dark) !important;
    padding-left: 16px !important;
    margin-bottom: 12px !important;
    border-radius: 0 8px 8px 0 !important;
}

.capea-timeline-item > summary {
    font-weight: 700 !important;
    font-size: 1.05rem !important;
    color: var(--clr-primary-dark) !important;
    padding: 14px 16px !important;
}

.capea-timeline-item[open] > summary {
    color: #005f66 !important;
    border-bottom: 1px solid #e0f0f1;
    margin-bottom: 8px;
}

/* Hall of Fame award image */
.capea-hof-award-img img {
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.3);
    max-width: 340px;
    width: 100%;
    margin: 0 auto;
}

/* Hall of Fame table on purple background */
.capea-hof-table--purple table {
    background: rgba(255,255,255,0.12) !important;
    border-radius: 10px;
    overflow: hidden;
    width: 100%;
    margin-top: 32px;
    color: #ffffff !important;
}

.capea-hof-table--purple thead {
    background: rgba(0,0,0,0.15) !important;
}

.capea-hof-table--purple th {
    color: #ffffff !important;
    font-weight: 700;
    padding: 12px 16px !important;
    text-align: left;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 0.82rem;
}

.capea-hof-table--purple td {
    color: rgba(255,255,255,0.95) !important;
    padding: 10px 16px !important;
    border-bottom: 1px solid rgba(255,255,255,0.15) !important;
}

.capea-hof-table--purple tr:last-child td {
    border-bottom: none !important;
}

.capea-hof-table--purple tr:hover td {
    background: rgba(255,255,255,0.08);
}

@media (max-width: 768px) {
    .capea-history-portrait img,
    .capea-history-logo-img img,
    .capea-hof-award-img img {
        max-width: 100%;
    }
    .capea-history-timeline-img img {
        max-height: 400px;
    }
}

/* Fix: Hall of Fame table row contrast — override WordPress default alternating colours */
.capea-hof-table--purple table tr,
.capea-hof-table--purple table tr td,
.capea-hof-table--purple table tr:nth-child(odd),
.capea-hof-table--purple table tr:nth-child(even),
.capea-hof-table--purple table tbody tr,
.capea-hof-table--purple table tbody tr:nth-child(odd),
.capea-hof-table--purple table tbody tr:nth-child(even) {
    background: transparent !important;
    background-color: transparent !important;
    color: #ffffff !important;
}

.capea-hof-table--purple table tr:nth-child(even) td {
    background: rgba(0,0,0,0.05) !important;
}

.capea-hof-table--purple table tr:nth-child(odd) td {
    background: rgba(0,0,0,0.10) !important;
}

.capea-hof-table--purple table td,
.capea-hof-table--purple table th {
    color: #ffffff !important;
    border-color: rgba(255,255,255,0.15) !important;
}

.capea-hof-table--purple table tr:hover td {
    background: rgba(255,255,255,0.18) !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* White btn outline (already in mem- but adding capea- prefix alias) */
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}


/* ══════════════════════════════════════════════════════════
   capea-strategic-plan — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* ============================================
   STRATEGIC PLAN PAGE
   ============================================ */

/* Vision Strip */
.capea-vision-strip {
    padding: 48px 24px !important;
}

.capea-vision-cols {
    align-items: center !important;
    gap: 0 !important;
}

.capea-vision-item {
    padding: 24px 32px !important;
}

.capea-vision-item--bordered {
    border-right: 2px solid rgba(255,255,255,0.3);
}

.capea-vision-label {
    font-size: 0.85rem !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    color: rgba(255,255,255,0.95) !important;
    margin-bottom: 8px !important;
    font-weight: 600 !important;
}

.capea-vision-headline {
    font-size: 2.4rem !important;
    font-weight: 800 !important;
    color: #ffffff !important;
    margin: 0 !important;
    line-height: 1.2 !important;
}

.capea-vision-purpose {
    font-size: 1.2rem !important;
    font-weight: 400 !important;
    color: rgba(255,255,255,0.95) !important;
    margin: 0 !important;
    font-style: italic;
    line-height: 1.5 !important;
}

/* Strategic Priority Cards */
.capea-strat-priorities-row {
    gap: 20px !important;
    margin-top: 32px !important;
}

.capea-priority-card {
    background: #ffffff;
    border-radius: 12px;
    padding: 28px 24px !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.08);
    border-top: 4px solid var(--clr-primary-dark);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
}

.capea-priority-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0,0,0,0.14);
}

.capea-priority-card--educators { border-top-color: var(--clr-secondary); }

.capea-priority-card--excellence { border-top-color: var(--clr-primary-dark); }

.capea-priority-card--sustainable { border-top-color: #2d8a4e; }

.capea-priority-icon {
    font-size: 2.4rem !important;
    margin-bottom: 8px !important;
    line-height: 1 !important;
}

.capea-priority-title {
    font-size: 1.15rem !important;
    font-weight: 700 !important;
    color: var(--clr-text) !important;
    margin-bottom: 6px !important;
}

.capea-priority-tagline {
    font-size: 0.88rem !important;
    color: var(--clr-primary-dark) !important;
    font-style: italic;
    margin-bottom: 12px !important;
    font-weight: 600;
}

.capea-priority-list {
    margin: 0 !important;
    padding-left: 18px !important;
}

.capea-priority-list li {
    font-size: 0.9rem !important;
    color: #444 !important;
    margin-bottom: 6px !important;
    line-height: 1.5 !important;
}

/* Event Cards */
.capea-events-row {
    gap: 20px !important;
    margin-top: 32px !important;
}

.capea-event-card {
    background: #ffffff;
    border-radius: 12px;
    padding: 24px !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.08);
    border-left: 4px solid var(--clr-primary-dark);
    transition: transform 0.3s ease;
}

.capea-event-card:hover {
    transform: translateY(-3px);
}

.capea-event-card--featured {
    border-left-color: var(--clr-secondary);
    background: linear-gradient(135deg, #fdf9ff 0%, #f5eeff 100%);
}

.capea-event-card--featured .capea-event-date {
    color: var(--clr-secondary) !important;
}

.capea-event-location {
    font-size: 0.82rem !important;
    color: #6d6d6d !important;
    margin-bottom: 10px !important;
}

.capea-event-save {
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    color: var(--clr-secondary) !important;
    margin-top: 8px !important;
}

/* Project Framework */
.capea-framework-row {
    margin-top: 32px !important;
    gap: 24px !important;
}

.capea-framework-item {
    background: rgba(255,255,255,0.12);
    border-radius: 10px;
    padding: 24px !important;
    border: 1px solid rgba(255,255,255,0.2);
    text-align: center;
    transition: background 0.3s ease;
}

.capea-framework-item:hover {
    background: rgba(255,255,255,0.2);
}

.capea-framework-icon {
    font-size: 2rem !important;
    margin-bottom: 12px !important;
    line-height: 1 !important;
}

.capea-framework-title {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    margin-bottom: 8px !important;
}

.capea-framework-text {
    font-size: 0.88rem !important;
    color: rgba(255,255,255,0.95) !important;
    line-height: 1.6 !important;
    margin: 0 !important;
}

/* Responsive */
@media (max-width: 768px) {
    .capea-vision-item--bordered { border-right: none; border-bottom: 2px solid rgba(255,255,255,0.3); }
    .capea-vision-headline { font-size: 1.8rem !important; }
    .capea-strat-priorities-row,
    .capea-events-row,
    .capea-framework-row { flex-direction: column !important; }
    .capea-priority-card,
    .capea-event-card,
    .capea-framework-item { margin-bottom: 16px; }
}

.capea-event-card {
    gap: 40px;
    align-items: center;
    margin-bottom: 0;
}

@media (max-width: 768px) {
    .capea-event-card .wp-block-columns {
        flex-direction: column !important;
    }
    .capea-event-card-reverse .wp-block-columns {
        flex-direction: column-reverse !important;
    }
    .capea-event-image-col,
    .capea-event-details-col {
        width: 100% !important;
        flex-basis: 100% !important;
    }
    .capea-event-badges {
        flex-direction: column !important;
    }
    .capea-conference-card {
        margin-bottom: 16px !important;
    }
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* White btn outline (already in mem- but adding capea- prefix alias) */
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}


/* ══════════════════════════════════════════════════════════
   organisational-structure — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* Checklist with teal ticks */
.capea-check-list {
    list-style: none !important;
    padding-left: 0 !important;
}

.capea-check-list li {
    padding: 6px 0 6px 32px !important;
    position: relative;
}

.capea-check-list li::before {
    content: '\2713';
    position: absolute;
    left: 0;
    top: 6px;
    color: var(--clr-primary-dark);
    font-weight: 700;
    font-size: 1.1rem;
}

/* Board photo */
.capea-board-photo img {
    width: 110px !important;
    height: 110px !important;
    object-fit: cover;
    border-radius: 50% !important;
    border: 3px solid var(--clr-secondary);
    margin: 0 auto 12px !important;
    display: block;
}

.capea-board-photo {
    margin-bottom: 0 !important;
}

/* Board name & role */
.capea-board-name {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--clr-secondary) !important;
    margin: 8px 0 4px !important;
    line-height: 1.3 !important;
}

/* White card inside teal section */
.capea-org-card {
    background: #ffffff;
    border-radius: 12px;
    padding: 24px !important;
    margin-bottom: 20px !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.1);
}

.capea-org-card:last-child {
    margin-bottom: 0 !important;
}

.capea-org-card .capea-h3-teal {
    color: var(--clr-primary-dark) !important;
    font-size: 1.1rem !important;
    margin-bottom: 12px !important;
}

/* Org list inside white card */
.capea-org-list {
    margin: 0 !important;
    padding-left: 20px !important;
}

.capea-org-list li {
    font-size: 0.92rem !important;
    color: var(--clr-text) !important;
    margin-bottom: 6px !important;
    line-height: 1.5 !important;
}

/* Officers table inside white card */
.capea-officers-table {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.capea-officers-table table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 0.9rem;
}

.capea-officers-table td {
    padding: 8px 10px !important;
    border-bottom: 1px solid #e8f4f4 !important;
    vertical-align: top;
    color: var(--clr-text) !important;
}

.capea-officers-table tr:last-child td {
    border-bottom: none !important;
}

.capea-officers-table tr:hover td {
    background: var(--clr-surface-teal);
}

/* Divider inside white card */
.capea-divider-teal {
    border-color: #e0f0f0 !important;
    margin: 16px 0 !important;
}

.capea-divider-teal {
    border-color: var(--clr-primary-dark) !important;
    opacity: 0.3;
    margin: 16px 0 !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* White btn outline (already in mem- but adding capea- prefix alias) */
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}

/* ══════════════════════════════════════════════════════════════════════════
   Philosophy & Values page — Stitch bento design
   ══════════════════════════════════════════════════════════════════════════ */

/* White icon (Material Symbol on dark/coloured backgrounds) */
.card-icon--white,
.editor-styles-wrapper .card-icon--white {
    color: #ffffff !important;
    margin-bottom: 8px !important;
}

/* Bento grid: info cards fill column height */
.capea-bento-card-teal,
.capea-bento-card-green {
    min-height: 400px;
    background: var(--clr-surface-teal);
    display: flex;
    flex-direction: column;
}
.capea-bento-card-green {
    background: var(--clr-primary-dark);
}
.capea-bento-card-green p,
.capea-bento-card-green .capea-bento-text {
    color: rgba(255,255,255,0.95) !important;
}

/* Bento cover: overflow hidden clips image to border-radius */
.wp-block-cover.is-position-bottom-left {
    overflow: hidden;
}

/* Text inside bento cover cards */
.capea-bento-text {
    color: rgba(255,255,255,0.95) !important;
    font-size: 0.95rem;
    line-height: 1.6;
    margin: 0 !important;
}

/* Accredited Programs badge inside green card */
.capea-bento-badge {
    display: flex !important;
    align-items: center;
    gap: 10px;
    border-top: 1px solid rgba(255,255,255,0.2);
    padding-top: 20px;
    margin-top: auto !important;
}
.capea-bento-badge .card-icon--white {
    font-size: 24px !important;
    margin-bottom: 0 !important;
}
.capea-bento-badge-label {
    color: rgba(255,255,255,0.95) !important;
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    margin: 0 !important;
}

/* Values section image */
.capea-values-image img {
    border-radius: 20px;
    box-shadow: 0 20px 48px -12px rgba(0,108,80,0.18);
    width: 100%;
    height: auto;
}

/* Value item rows */
.capea-value-item {
    display: flex !important;
    gap: 20px;
    margin-bottom: 28px !important;
    align-items: flex-start;
}
.capea-value-item:last-child { margin-bottom: 0 !important; }

/* Circular icon badge */
.capea-value-icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    flex-shrink: 0;
    display: flex !important;
    align-items: center;
    justify-content: center;
}
.capea-value-icon .card-icon,
.capea-value-icon .card-icon--secondary {
    font-size: 24px !important;
    margin: 0 !important;
}
.capea-value-icon--primary { background: rgba(0,108,80,0.1); }
.capea-value-icon--secondary { background: rgba(119,75,152,0.1); }

/* Value text */
.capea-value-title {
    color: var(--clr-primary-dark) !important;
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    margin: 0 0 6px !important;
}
.capea-value-desc {
    color: var(--clr-muted) !important;
    font-size: 0.95rem !important;
    line-height: 1.6 !important;
    margin: 0 !important;
}

/* CTA card */
.capea-cta-card {
    overflow: hidden;
    position: relative;
    text-align: center;
}

/* ═══════════════════════════════════
   Philosophy Page — Beliefs List
   ═══════════════════════════════════ */
.capea-beliefs-list {
    list-style: none !important;
    padding-left: 0 !important;
    counter-reset: beliefs-counter;
    margin-top: 48px !important;
}

.capea-beliefs-list > li {
    counter-increment: beliefs-counter;
    position: relative;
    padding: 1.75rem 0 1.75rem 5rem;
    border-top: 1px solid rgba(67, 183, 144, 0.18);
    font-size: 1.05rem;
    line-height: 1.8;
    color: var(--clr-text);
}

.capea-beliefs-list > li:last-child {
    border-bottom: 1px solid rgba(67, 183, 144, 0.18);
}

.capea-beliefs-list > li::before {
    content: counter(beliefs-counter, decimal-leading-zero);
    position: absolute;
    left: 0;
    top: 1.6rem;
    font-family: var(--font-hed);
    font-size: 2rem;
    font-weight: 800;
    color: var(--wp--preset--color--primary);
    line-height: 1;
    width: 4rem;
}

.capea-beliefs-list ul.wp-block-list {
    list-style: none !important;
    padding: 0.875rem 0 0 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column;
    gap: 0.625rem;
}

.capea-beliefs-list ul.wp-block-list li {
    position: relative;
    padding-left: 1.5rem;
    color: var(--clr-muted);
    font-size: 0.975rem;
    line-height: 1.65;
}

.capea-beliefs-list ul.wp-block-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.75rem;
    width: 0.75rem;
    height: 2px;
    background: var(--wp--preset--color--primary);
    border-radius: 1px;
}

/* ══════════════════════════════════════════════════════════════════════════
   Goals of CAPEA page — Stitch bento design
   ══════════════════════════════════════════════════════════════════════════ */

.capea-goals-grid {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
}

/* Bento rows: equal-height columns with gap */
.capea-bento-row {
    gap: 24px !important;
    align-items: stretch !important;
    margin-bottom: 24px !important;
}
.capea-bento-row:last-child { margin-bottom: 0 !important; }
.capea-bento-row > .wp-block-column {
    display: flex !important;
    flex-direction: column;
}

/* Goals card: base white card */
.capea-goals-card {
    background: #ffffff;
    border-radius: 12px !important;
    padding: 40px !important;
    box-shadow: 0 20px 40px -15px rgba(0, 108, 80, 0.08);
    border: 1px solid rgba(188, 202, 194, 0.3) !important;
    flex: 1;
    display: flex !important;
    flex-direction: column !important;
    transition: transform 0.2s ease;
}
.capea-goals-card:hover { transform: translateY(-4px); }
.editor-styles-wrapper .capea-goals-card:hover { transform: none; }

/* Green card */
.capea-goals-card--primary {
    background: var(--clr-primary-dark) !important;
    border-color: transparent !important;
}
/* Purple/lavender card */
.capea-goals-card--purple {
    background: var(--wp--preset--color--secondary-container) !important;
    border-color: transparent !important;
}
/* Teal card: horizontal layout */
.capea-goals-card--teal {
    background: var(--clr-surface-teal) !important;
    border-color: rgba(0, 108, 80, 0.1) !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 32px !important;
}
.capea-bento-card-text {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
}

/* Icon circle */
.capea-goals-icon-circle {
    width: 64px !important;
    height: 64px !important;
    border-radius: 50% !important;
    background: rgba(0, 108, 80, 0.08) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-bottom: 24px !important;
    flex-shrink: 0 !important;
}
.capea-goals-icon-circle .card-icon {
    font-size: 28px !important;
    margin: 0 !important;
    color: var(--clr-primary-dark) !important;
    line-height: 1 !important;
}
.capea-goals-card--primary .capea-goals-icon-circle {
    background: rgba(255, 255, 255, 0.2) !important;
}
.capea-goals-card--primary .capea-goals-icon-circle .card-icon {
    color: #ffffff !important;
}
.capea-goals-card--purple .capea-goals-icon-circle {
    background: rgba(255, 255, 255, 0.4) !important;
}
.capea-goals-card--purple .capea-goals-icon-circle .card-icon {
    color: var(--clr-secondary) !important;
}
.capea-goals-card--teal .capea-bento-card-text .capea-goals-icon-circle {
    margin-bottom: 20px !important;
}

/* Card description text */
.capea-card-desc {
    color: var(--clr-muted) !important;
    font-size: 1rem !important;
    line-height: 1.65 !important;
    margin-bottom: 20px !important;
}
.capea-goals-card--purple .capea-card-desc {
    color: rgb(98, 55, 131) !important;
}

/* Push list/buttons/tags to bottom of card */
.capea-goals-card .capea-checklist,
.capea-goals-card--primary .wp-block-buttons,
.capea-goals-card--purple .capea-tag-row {
    margin-top: auto !important;
}

/* Dark purple heading for lavender card */
.capea-h2-purple-dark { color: #623783 !important; }

/* Checklist with Material Symbols check icons */
.capea-checklist {
    list-style: none !important;
    padding-left: 0 !important;
}
.capea-checklist li {
    position: relative;
    padding-left: 32px !important;
    margin-bottom: 14px !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    color: var(--clr-text) !important;
    line-height: 1.5 !important;
}
.capea-checklist li:last-child { margin-bottom: 0 !important; }
.capea-checklist li::before {
    content: 'check_circle';
    font-family: 'Material Symbols Outlined' !important;
    font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 20;
    font-size: 20px !important;
    color: var(--clr-primary-dark);
    position: absolute;
    left: 0;
    top: 0;
    line-height: 1.4;
}

/* Tag pills */
.capea-tag-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
}
.capea-tag {
    display: inline-block !important;
    background: rgba(255, 255, 255, 0.4) !important;
    color: #623783 !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    padding: 4px 12px !important;
    border-radius: 999px !important;
    margin: 0 !important;
}

/* Stat badges */
.capea-stat-badges {
    display: flex !important;
    flex-wrap: wrap;
    gap: 12px !important;
    flex-shrink: 0 !important;
    align-items: center;
    justify-content: center;
}
.capea-stat-badge {
    background: #ffffff !important;
    border-radius: 12px !important;
    padding: 16px 20px !important;
    text-align: center !important;
    min-width: 88px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
.capea-stat-badge-number {
    color: var(--clr-primary-dark) !important;
    font-size: 1.4rem !important;
    font-weight: 700 !important;
    margin: 0 !important;
    line-height: 1 !important;
}
.capea-stat-badge-label {
    color: var(--clr-muted) !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    margin: 4px 0 0 !important;
    letter-spacing: 0.02em !important;
    text-transform: uppercase;
}

/* "View Programs" white button on green card */
.wp-block-button.capea-goals-primary-btn .wp-block-button__link,
.editor-styles-wrapper .wp-block-button.capea-goals-primary-btn .wp-block-button__link {
    background: #ffffff !important;
    color: var(--clr-primary-dark) !important;
    border-radius: 5px !important;
    font-weight: 700 !important;
    padding: 14px 28px !important;
    border: none !important;
}
.wp-block-button.capea-goals-primary-btn .wp-block-button__link:hover {
    background: var(--clr-surface-teal) !important;
}

/* Strategic section image */
.capea-strategic-img img {
    border-radius: 12px !important;
    box-shadow: 0 20px 48px -12px rgba(0, 108, 80, 0.18);
    width: 100%;
    height: auto;
}

/* Goals bullet list */
.capea-goals-bullet-list {
    list-style: none !important;
    padding-left: 0 !important;
}
.capea-goals-bullet-list li {
    position: relative;
    padding-left: 20px !important;
    margin-bottom: 20px !important;
    font-size: 1rem !important;
    line-height: 1.6 !important;
    color: var(--clr-muted) !important;
}
.capea-goals-bullet-list li:last-child { margin-bottom: 0 !important; }
.capea-goals-bullet-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.65em;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--clr-primary-dark);
    flex-shrink: 0;
}

/* CTA box */
.capea-goals-cta {
    background: var(--clr-primary-dark) !important;
    border-radius: 24px !important;
    padding: 64px 48px !important;
    text-align: center;
}
.editor-styles-wrapper .capea-goals-cta { text-align: center; }

/* CTA "Become a Member" button: white fill with dark teal text (on primary-dark CTA box) */
.wp-block-button.capea-goals-cta-btn .wp-block-button__link,
.editor-styles-wrapper .wp-block-button.capea-goals-cta-btn .wp-block-button__link {
    background: #ffffff !important;
    color: var(--clr-primary-dark) !important;
    border-radius: 5px !important;
    font-weight: 700 !important;
    padding: 14px 32px !important;
    border: none !important;
}
.wp-block-button.capea-goals-cta-btn .wp-block-button__link:hover {
    background: #004331 !important;
}
.capea-goals-cta .capea-btn-white-outline .wp-block-button__link {
    border-radius: 5px !important;
}

/* Responsive */
@media (max-width: 768px) {
    .capea-goals-card--teal {
        flex-direction: column !important;
        align-items: flex-start !important;
    }
    .capea-stat-badges { justify-content: flex-start; }
    .capea-bento-row { margin-bottom: 16px !important; }
    .capea-goals-cta { padding: 40px 24px !important; }
}


/* ══════════════════════════════════════════════════════════
   professional-education — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Certification Page — Intro image
   ═══════════════════════════════════ */
.capea-intro-img img {
  border-radius: 12px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.12);
}

/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.wp-block-button.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.wp-block-button.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

/* ═══════════════════════════════════
   Membership Page — White Solid Button
   ═══════════════════════════════════ */
.wp-block-button.capea-btn-white-solid .wp-block-button__link {
  background: #ffffff !important;
  color: var(--clr-primary-dark) !important;
  border: 2px solid #ffffff !important;
  font-weight: 700 !important;
  padding: 12px 28px !important;
}

.wp-block-button.capea-btn-white-solid .wp-block-button__link:hover {
  background: rgba(255,255,255,0.9) !important;
}

/* ===========================================
   PROFESSIONAL EDUCATION PAGE STYLES
   =========================================== */

/* White subheading on dark sections */
.mem-sub-white { color: rgba(255,255,255,0.95) !important; }

/* Outline button variants */
.wp-block-button.capea-btn-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.wp-block-button.capea-btn-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}

.wp-block-button.capea-btn-outline-white .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.wp-block-button.capea-btn-outline-white .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}


/* ══════════════════════════════════════════════════════════
   educator-pathways — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.wp-block-button.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.wp-block-button.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

.wp-block-button.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* ── Testimonials section ── */
.capea-testimonial-row {
  margin-top: 40px !important;
  gap: 24px;
}

.capea-testimonial-card {
  background: rgba(255,255,255,0.12) !important;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 16px;
  padding: 32px 24px !important;
  text-align: center;
  transition: background 0.2s;
}

.capea-testimonial-card:hover {
  background: rgba(255,255,255,0.18) !important;
}

.capea-testimonial-photo {
  margin-bottom: 20px !important;
}

.capea-testimonial-photo img {
  width: 90px !important;
  height: 90px !important;
  object-fit: cover;
  border-radius: 50%;
  border: 3px solid rgba(255,255,255,0.5);
  display: block;
  margin: 0 auto;
}

.capea-testimonial-name {
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  margin-bottom: 4px !important;
}

.capea-testimonial-role {
  color: rgba(255,255,255,0.95) !important;
  font-size: 0.85rem !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0 !important;
}

@media (max-width: 768px) {
  .capea-testimonial-card {
    margin-bottom: 16px;
  }
}

/* Small teal button variant */
.wp-block-button.capea-btn-teal-sm .wp-block-button__link {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    transition: background-color 0.2s !important;
}

.wp-block-button.capea-btn-teal-sm .wp-block-button__link:hover {
    background-color: var(--clr-primary-dark) !important;
}

/* Trainer badge column */
.capea-trainer-badge-col {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.capea-trainer-logo {
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(255,255,255,0.2);
    max-width: 220px;
    margin: 0 auto 16px !important;
}

.capea-trainer-logo img {
    border-radius: 12px;
    max-width: 220px;
}

.capea-trainer-badge-label {
    color: rgba(255,255,255,0.95) !important;
    font-size: 0.95rem !important;
    text-align: center;
    line-height: 1.6;
    font-style: italic;
}

/* ============================================================
   EDUCATOR PATHWAYS PAGE
   ============================================================ */

/* Provider cards grid */
.capea-provider-row {
    margin-bottom: 24px !important;
    align-items: stretch;
}

.capea-provider-card {
    background: #ffffff;
    border-radius: 12px;
    padding: 32px 24px !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.07);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.capea-provider-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}

.capea-provider-card-light {
    background: #ffffff;
    border: 1px solid #e8f5f6;
}

/* Provider logos */
.capea-provider-logo {
    margin-bottom: 16px !important;
    margin-top: 0 !important;
}

.capea-provider-logo img {
    max-height: 80px;
    width: auto;
    max-width: 200px;
    object-fit: contain;
    border-radius: 6px;
}

/* Provider card text */
.capea-provider-title {
    font-size: 1.05rem !important;
    color: var(--clr-primary-dark) !important;
    margin-bottom: 8px !important;
    margin-top: 0 !important;
}

.capea-provider-badge {
    display: inline-block;
    background: #e6f7f7;
    color: var(--clr-primary-dark);
    font-size: 0.8rem;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 20px;
    margin-bottom: 12px !important;
    margin-top: 0 !important;
}

.capea-provider-desc {
    font-size: 0.9rem !important;
    color: var(--clr-muted) !important;
    line-height: 1.6 !important;
    flex-grow: 1;
    margin-bottom: 16px !important;
}

/* Small teal buttons for providers */
.wp-block-button.capea-btn-teal-sm .wp-block-button__link {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.wp-block-button.capea-btn-teal-sm .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
}

/* Other qualifications cards */
.capea-other-qual-card {
    background: #f8f8f8;
    border-radius: 12px;
    padding: 32px 28px !important;
    border-left: 4px solid var(--clr-primary-dark);
}

.capea-other-qual-note {
    font-size: 0.87rem !important;
    color: #595959 !important;
    background: #fff8e1;
    border-left: 3px solid #f59e0b;
    padding: 10px 14px;
    border-radius: 4px;
    margin-top: 12px !important;
}

.capea-other-qual-note a {
    color: var(--clr-primary-dark);
}

/* Responsive provider grid */
@media (max-width: 768px) {
    .capea-provider-card {
        margin-bottom: 20px;
        padding: 24px 16px !important;
    }
    .capea-provider-logo img {
        max-height: 60px;
    }
    .capea-other-qual-card {
        margin-bottom: 20px;
    }
}

.capea-text-white,
.capea-text-white p,
.capea-text-white li {
    color: #ffffff !important;
}

.capea-text-white,
.capea-text-white p,
.capea-text-white li {
    color: #ffffff !important;
}

/* ============================================
   CAPEA BUTTON - TEAL OUTLINE VARIANT
   ============================================ */
.wp-block-button.capea-btn-teal-outline .wp-block-button__link {
    background: transparent !important;
    color: var(--clr-primary-dark) !important;
    border: 2px solid var(--clr-primary-dark) !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
}

.wp-block-button.capea-btn-teal-outline .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* Text white utility */
.capea-text-white, .capea-text-white p, .capea-text-white h2, .capea-text-white h3 {
    color: #ffffff !important;
}

/* White btn outline (already in mem- but adding capea- prefix alias) */
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}


/* ══════════════════════════════════════════════════════════
   journal-and-research-publications — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ============================================================
   RESEARCH PUBLICATIONS PAGE (capea-research-pub-gutenberg)
   ============================================================ */

/* Hero */
.rp-hero .wp-block-cover__inner-container { padding: 60px 20px; }

.rp-eyebrow { font-size:.85rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:rgba(255,255,255,.95); margin-bottom:12px !important; }

.rp-hero-h1 { font-size:2.4rem !important; font-weight:300 !important; color:#fff !important; margin-bottom:14px !important; line-height:1.25 !important; }

.rp-hero-sub { font-size:1.05rem; color:rgba(255,255,255,.95); max-width:640px; margin:0 auto 28px !important; line-height:1.7; }

.wp-block-button.rp-btn-white .wp-block-button__link { background:#fff !important; color:var(--clr-primary-dark) !important; border-radius:5px !important; font-weight:700 !important; padding:12px 28px !important; }

.wp-block-button.rp-btn-white .wp-block-button__link:hover { background:var(--clr-surface-teal) !important; color:var(--clr-primary-dark) !important; transform:translateY(-2px); }

.wp-block-button.rp-btn-ghost .wp-block-button__link { background:transparent !important; color:#fff !important; border:2px solid rgba(255,255,255,.6) !important; border-radius:5px !important; font-weight:600 !important; padding:12px 28px !important; }

.wp-block-button.rp-btn-ghost .wp-block-button__link:hover { border-color:#fff !important; background:rgba(255,255,255,.1) !important; }

/* Stats Bar */
.rp-stats-bar { padding:28px 20px !important; }

.rp-stats-row { gap:0 !important; }

.rp-stat-item { text-align:center; padding:8px 16px; border-right:1px solid rgba(255,255,255,.2); }

.rp-stat-item:last-child { border-right:none; }

.rp-stat-num { font-size:2rem !important; font-weight:800 !important; color:#fff !important; margin:0 !important; line-height:1.1 !important; }

.rp-stat-lbl { font-size:.78rem !important; color:rgba(255,255,255,.90) !important; text-transform:uppercase; letter-spacing:1px; margin:0 !important; }

/* Section common */
.rp-section { padding:56px 20px !important; }

.rp-section-title { font-size:1.7rem !important; font-weight:700 !important; color:var(--clr-primary-dark) !important; margin-bottom:8px !important; padding-bottom:10px !important; border-bottom:3px solid var(--clr-primary-dark) !important; }

.rp-section-desc { color:var(--clr-muted); font-size:1rem; margin-bottom:28px !important; max-width:760px; }

/* Featured IJBPE card */
.rp-featured-card { background:linear-gradient(135deg,var(--clr-surface-teal) 0%,#e6f7f8 100%); border-radius:16px; padding:36px; box-shadow:0 4px 20px rgba(0,123,130,.1); }

.rp-featured-img-col { max-width:220px !important; flex:0 0 220px !important; }

.rp-cover-img img { border-radius:10px !important; box-shadow:0 8px 30px rgba(0,0,0,.2) !important; }

.rp-cover-caption { font-size:.82rem !important; color:var(--clr-primary-dark) !important; font-weight:600 !important; margin-top:10px !important; }

.rp-badge { display:inline-block; padding:5px 14px; border-radius:20px; font-size:.8rem; font-weight:700; margin-bottom:14px !important; }

.rp-badge-teal { background:var(--clr-primary-dark); color:#fff !important; }

.rp-badge-purple { background:var(--clr-secondary); color:#fff !important; }

.rp-badge-orange { background:#b85800; color:#fff !important; }

.rp-badge-light { background:rgba(255,255,255,.15); color:#fff !important; border:1px solid rgba(255,255,255,.5); }

.rp-pub-name { font-size:1.5rem !important; color:#004f55 !important; margin-bottom:6px !important; line-height:1.3 !important; }

.rp-pub-abbr { font-size:.9rem; color:var(--clr-muted); margin-bottom:14px !important; }

.rp-feature-tags { gap:8px !important; margin-bottom:20px !important; }

.rp-tag { background:#fff; border:1px solid #b2dfe2; color:var(--clr-primary-dark) !important; border-radius:20px; padding:4px 12px; font-size:.8rem !important; font-weight:600; margin:0 !important; }

.wp-block-button.rp-btn-primary .wp-block-button__link { background:var(--clr-primary-dark) !important; color:#fff !important; border-radius:5px !important; font-weight:700 !important; padding:12px 26px !important; }

.wp-block-button.rp-btn-primary .wp-block-button__link:hover { background:var(--clr-primary-dark) !important; transform:translateY(-2px) !important; box-shadow:var(--shadow-md) !important; }

.wp-block-button.rp-btn-outline .wp-block-button__link { background:transparent !important; color:var(--clr-primary-dark) !important; border:2px solid var(--clr-primary-dark) !important; border-radius:5px !important; font-weight:700 !important; padding:12px 26px !important; }

.wp-block-button.rp-btn-outline .wp-block-button__link:hover { background:var(--clr-primary-dark) !important; color:#fff !important; }

/* Partner journals cards — editorial left-border design */
.rp-cards-row { gap:24px !important; align-items:stretch !important; }

.rp-pub-card {
  background:#fff;
  border-radius:8px;
  padding:28px;
  box-shadow:0 1px 10px rgba(0,0,0,.08), 0 0 0 1px rgba(0,0,0,.04);
  display:flex !important;
  flex-direction:column !important;
  border-left:4px solid var(--clr-primary-dark);
}

/* Hide the low-res thumbnail images — editorial style is type-forward */
.rp-pub-logo { display:none !important; }

/* Category label — small caps, light teal, left-aligned */
.rp-pub-card .rp-badge {
  align-self:flex-start;
  width:fit-content;
  margin:0 0 16px 0 !important;
  border-radius:4px !important;
  font-size:.7rem !important;
  letter-spacing:.8px;
  text-transform:uppercase;
  padding:4px 10px !important;
  background:var(--clr-surface-teal) !important;
  color:var(--clr-primary-dark) !important;
}

/* Override WP's has-text-align-center inside editorial cards */
.rp-pub-card .has-text-align-center { text-align:left !important; }

/* Title */
.rp-card-title { font-size:1.12rem !important; font-weight:700 !important; color:var(--clr-text) !important; margin:0 0 6px 0 !important; line-height:1.35 !important; }

/* Publisher / source line */
.rp-pub-abbr { font-size:.85rem !important; color:var(--clr-muted); padding:0 !important; margin:0 0 12px 0 !important; }

/* Description — left-aligned, fills remaining height */
.rp-pub-card > p:not([class]) { padding:0 !important; font-size:.93rem !important; color:var(--clr-muted); line-height:1.65; flex:1; }

/* CTA — left-aligned, solid teal */
.rp-pub-card .wp-block-buttons { padding:0 !important; margin-top:20px !important; justify-content:flex-start !important; }
.rp-pub-card .wp-block-button .wp-block-button__link { background:var(--clr-primary-dark) !important; color:#fff !important; border:none !important; border-radius:5px !important; font-size:.88rem !important; font-weight:700 !important; padding:10px 20px !important; }
.rp-pub-card .wp-block-button .wp-block-button__link:hover { background:#004d38 !important; transform:translateY(-1px) !important; }

/* Keep rp-btn-outline-purple in case used elsewhere */
.wp-block-button.rp-btn-outline-purple .wp-block-button__link { background:var(--clr-secondary) !important; color:#fff !important; border:none !important; border-radius:5px !important; font-weight:700 !important; padding:10px 22px !important; font-size:.88rem !important; }
.wp-block-button.rp-btn-outline-purple .wp-block-button__link:hover { background:#5f3a7a !important; transform:translateY(-2px) !important; }

.rp-int-cover img { border-radius:10px !important; box-shadow:0 8px 24px rgba(0,0,0,.3) !important; max-height:360px !important; width:auto !important; max-width:100% !important; height:auto !important; display:block !important; margin:0 auto !important; }

.rp-int-title { font-size:1.8rem !important; color:#fff !important; margin-bottom:10px !important; }

.rp-int-sub { color:rgba(255,255,255,.85) !important; font-size:.97rem; margin-bottom:20px !important; line-height:1.7; }

.rp-int-years { gap:16px !important; margin-bottom:24px !important; }

.rp-int-year-heading { font-size:1rem !important; font-weight:700 !important; color:#fff !important; margin-bottom:8px !important; border-bottom:1px solid rgba(255,255,255,.3) !important; padding-bottom:4px !important; }

.rp-int-list { padding-left:16px !important; margin:0 !important; }

.rp-int-list li { color:rgba(255,255,255,.85) !important; font-size:.88rem; margin-bottom:4px !important; }

.rp-int-list li a { color:#c9f0f2 !important; text-decoration:underline; }

.rp-int-list li a:hover { color:#fff !important; }

/* Stay current cards — coloured-tile redesign */
.rp-stay-cols { gap:28px !important; align-items:stretch !important; }

.rp-stay-card { border-top:none !important; border-radius:16px; padding:44px 36px; text-align:center; box-shadow:0 6px 28px rgba(0,0,0,.15); display:flex !important; flex-direction:column !important; }

.rp-stay-card--fb { background:#1877F2; }

.rp-stay-card--res { background:var(--clr-secondary); }

.rp-stay-icon { font-size:3rem !important; margin-bottom:20px !important; color:rgba(255,255,255,.9) !important; line-height:1 !important; }

.rp-fb-icon { text-align:center; margin-bottom:20px; line-height:1; }

.rp-stay-title { font-size:1.3rem !important; font-weight:700 !important; color:#fff !important; margin-bottom:14px !important; }

.rp-stay-card p:not(.rp-stay-icon):not(.rp-stay-title) { color:rgba(255,255,255,.88) !important; line-height:1.65; margin-bottom:28px !important; font-size:.97rem !important; }

/* White buttons inside stay cards — (0,3,0) specificity to beat global rule */
.rp-stay-card .wp-block-button .wp-block-button__link { background:#fff !important; color:var(--clr-primary-dark) !important; border:none !important; border-radius:5px !important; font-weight:700 !important; padding:12px 28px !important; }

.rp-stay-card--fb .wp-block-button .wp-block-button__link { color:#1877F2 !important; }

.rp-stay-card--res .wp-block-button .wp-block-button__link { color:var(--clr-secondary) !important; }

.rp-stay-card .wp-block-button .wp-block-button__link:hover { background:rgba(255,255,255,.92) !important; transform:translateY(-2px) !important; box-shadow:0 4px 14px rgba(0,0,0,.2) !important; }

.rp-stay-card--res .wp-block-button .wp-block-button__link:hover { background:rgba(255,255,255,.92) !important; color:var(--clr-secondary) !important; }

/* Final CTA */
.rp-cta-section { padding:60px 20px !important; }

.rp-cta-title { font-size:2rem !important; color:#fff !important; margin-bottom:14px !important; }

.rp-cta-sub { color:rgba(255,255,255,.88); font-size:1rem; max-width:600px; margin:0 auto 28px !important; line-height:1.7; }

/* Responsive */
@media (max-width:768px) {
    .rp-hero-h1 { font-size:1.7rem !important; }
    .rp-stats-row { flex-wrap:wrap !important; }
    .rp-stat-item { border-right:none !important; border-bottom:1px solid rgba(255,255,255,.2); width:50% !important; }
    .rp-featured-cols { flex-direction:column !important; }
    .rp-featured-img-col { max-width:100% !important; flex:none !important; text-align:center; }
    .rp-cards-row { flex-direction:column !important; }
    .rp-int-layout { flex-direction:column !important; }
    .rp-int-years { flex-wrap:wrap !important; }
    .rp-stay-cols { flex-direction:column !important; }
    .rp-cta-title { font-size:1.5rem !important; }
}


/* ══════════════════════════════════════════════════════════
   webinars — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
.capea-h3-purple { color: var(--clr-secondary) !important; margin-top: 8px !important; }

/* ═══════════════════════════════════
   Certification Page — Badges
   ═══════════════════════════════════ */
.capea-badge {
  display: inline-block !important;
  background: #e4f5f5;
  color: var(--clr-primary-dark) !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  padding: 3px 12px !important;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: .6px;
  margin-bottom: 4px !important;
  line-height: 2 !important;
}

.capea-badge--purple {
  background: #f0e8f8 !important;
  color: var(--clr-secondary) !important;
}

/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.wp-block-button.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.wp-block-button.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

.wp-block-button.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* ═══════════════════════════════════
   Membership Page — White Solid Button
   ═══════════════════════════════════ */
.wp-block-button.capea-btn-white-solid .wp-block-button__link {
  background: #ffffff !important;
  color: var(--clr-primary-dark) !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 700 !important;
  padding: 12px 28px !important;
}

.wp-block-button.capea-btn-white-solid .wp-block-button__link:hover {
  background: rgba(255,255,255,0.9) !important;
}

/* Small teal button variant */
.wp-block-button.capea-btn-teal-sm .wp-block-button__link {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    transition: background-color 0.2s !important;
}

.wp-block-button.capea-btn-teal-sm .wp-block-button__link:hover {
    background-color: var(--clr-primary-dark) !important;
}

/* Educator / Trainer badges */
.capea-badge-educator {
    display: inline-block;
    background: var(--clr-primary-dark);
    color: #fff;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 3px 10px;
    border-radius: 20px;
    margin-right: 4px;
}

.capea-badge-trainer {
    display: inline-block;
    background: var(--clr-secondary);
    color: #fff;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 3px 10px;
    border-radius: 20px;
}

/* Small teal buttons for providers */
.wp-block-button.capea-btn-teal-sm .wp-block-button__link {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.wp-block-button.capea-btn-teal-sm .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
}

/* ============================================
   CAPEA BUTTON - TEAL OUTLINE VARIANT
   ============================================ */
.wp-block-button.capea-btn-teal-outline .wp-block-button__link {
    background: transparent !important;
    color: var(--clr-primary-dark) !important;
    border: 2px solid var(--clr-primary-dark) !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
}

.wp-block-button.capea-btn-teal-outline .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* ADULT EDUCATION THEORY */
.capea-h3-purple { color: var(--clr-secondary) !important; font-size: 1.3rem !important; margin-bottom: 16px !important; }

/* White btn outline (already in mem- but adding capea- prefix alias) */
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.wp-block-button.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}


/* ══════════════════════════════════════════════════════════
   resources — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Certification Page — Intro image
   ═══════════════════════════════════ */
.capea-intro-img img {
  border-radius: 12px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.12);
}

/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

/* ═══════════════════════════════════
   Membership Page — White Solid Button
   ═══════════════════════════════════ */
.capea-btn-white-solid .wp-block-button__link {
  background: #ffffff !important;
  color: var(--clr-primary-dark) !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 700 !important;
  padding: 12px 28px !important;
}

.capea-btn-white-solid .wp-block-button__link:hover {
  background: rgba(255,255,255,0.9) !important;
}

/* Small teal button variant */
.capea-btn-teal-sm .wp-block-button__link {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    transition: background-color 0.2s !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background-color: var(--clr-primary-dark) !important;
}

/* Small teal buttons for providers */
.capea-btn-teal-sm .wp-block-button__link {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
}

/* ============================================
   CAPEA BUTTON - TEAL OUTLINE VARIANT
   ============================================ */
.capea-btn-teal-outline .wp-block-button__link {
    background: transparent !important;
    color: var(--clr-primary-dark) !important;
    border: 2px solid var(--clr-primary-dark) !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
}

.capea-btn-teal-outline .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* =============================================
   RESOURCES HUB PAGE - Hub Card modifier
   ============================================= */
.res-hub-card {
  transition: transform .2s, box-shadow .2s;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  box-shadow: 0 4px 18px rgba(0,108,80,.12);
}

.res-hub-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 14px 36px rgba(0,108,80,.22);
}

.res-hub-card .wp-block-buttons {
  margin-top: auto;
  padding-top: 16px;
  display: flex;
  justify-content: center;
}


/* ══════════════════════════════════════════════════════════
   competency-standards-for-childbirth-and-parenting-educators — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* Small teal button variant */
.capea-btn-teal-sm .wp-block-button__link {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    transition: background-color 0.2s !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background-color: var(--clr-primary-dark) !important;
}

/* Small teal buttons for providers */
.capea-btn-teal-sm .wp-block-button__link {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
}

/* ============================================
   CAPEA BUTTON - TEAL OUTLINE VARIANT
   ============================================ */
.capea-btn-teal-outline .wp-block-button__link {
    background: transparent !important;
    color: var(--clr-primary-dark) !important;
    border: 2px solid var(--clr-primary-dark) !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
}

.capea-btn-teal-outline .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* White btn outline (already in mem- but adding capea- prefix alias) */
.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    border-radius: 30px !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}


/* ══════════════════════════════════════════════════════════
   resources-for-childbirth-and-parenting-educators — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* ═══════════════════════════════════
   Membership Page — White Solid Button
   ═══════════════════════════════════ */
.capea-btn-white-solid .wp-block-button__link {
  background: #ffffff !important;
  color: var(--clr-primary-dark) !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 700 !important;
  padding: 12px 28px !important;
}

.capea-btn-white-solid .wp-block-button__link:hover {
  background: rgba(255,255,255,0.9) !important;
}

/* Small teal button variant */
.capea-btn-teal-sm .wp-block-button__link {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    transition: background-color 0.2s !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background-color: var(--clr-primary-dark) !important;
}

/* Small teal buttons for providers */
.capea-btn-teal-sm .wp-block-button__link {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
}

/* ============================================
   CAPEA BUTTON - TEAL OUTLINE VARIANT
   ============================================ */
.capea-btn-teal-outline .wp-block-button__link {
    background: transparent !important;
    color: var(--clr-primary-dark) !important;
    border: 2px solid var(--clr-primary-dark) !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
}

.capea-btn-teal-outline .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* ===========================================
   RESOURCES FOR EDUCATORS PAGE
   =========================================== */

/* Supplier / resource cards */
.capea-resource-card-row { gap: 24px !important; }

.capea-resource-supplier-card {
    background: #ffffff;
    border-radius: 14px;
    padding: 28px 22px;
    box-shadow: 0 3px 16px rgba(0,0,0,0.08);
    text-align: center;
    border-top: 4px solid var(--clr-primary-dark);
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform .2s, box-shadow .2s;
}

.capea-resource-supplier-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 28px rgba(0,123,130,0.18);
}

.capea-card-teal-top { border-top-color: var(--clr-primary-dark) !important; }

.capea-card-purple-top { border-top-color: var(--clr-secondary) !important; }

.capea-supplier-flag {
    width: 100%;
    max-width: 160px;
    height: 80px;
    object-fit: contain;
    margin-bottom: 12px;
}

.capea-supplier-name {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--clr-text) !important;
    margin: 0 0 8px !important;
}

.capea-supplier-desc {
    font-size: .85rem !important;
    color: var(--clr-muted) !important;
    line-height: 1.6 !important;
    flex: 1;
    margin: 0 0 14px !important;
}

.capea-resource-link {
    display: inline-block;
    font-size: .85rem;
    font-weight: 700;
    color: var(--clr-primary-dark);
    text-decoration: none;
    border-bottom: 2px solid var(--clr-primary-dark);
    padding-bottom: 1px;
    transition: color .2s;
}

.capea-resource-link:hover { color: var(--clr-primary-dark); border-color: var(--clr-primary-dark); }

/* Download cards */
.capea-download-row { gap: 20px !important; flex-wrap: wrap !important; }

.capea-download-card {
    background: #ffffff;
    border-radius: 14px;
    padding: 24px 20px;
    box-shadow: 0 3px 16px rgba(0,0,0,0.08);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    border-left: 5px solid var(--clr-primary-dark);
    transition: transform .2s;
}

.capea-download-card:hover { transform: translateY(-3px); }

.capea-download-teal { border-left-color: var(--clr-primary-dark) !important; }

.capea-download-purple { border-left-color: var(--clr-secondary) !important; }

.capea-download-icon {
    font-size: 2.2rem !important;
    margin: 0 0 10px !important;
    line-height: 1 !important;
}

.capea-download-title {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--clr-text) !important;
    margin: 0 0 8px !important;
}

.capea-download-desc {
    font-size: .88rem !important;
    color: var(--clr-muted) !important;
    line-height: 1.6 !important;
    flex: 1;
    margin: 0 0 16px !important;
}

.capea-disclaimer-note {
    font-size: .82rem !important;
    color: #767676 !important;
    font-style: italic !important;
    margin-top: 8px !important;
}

/* Journal cards */
.capea-journal-row { gap: 20px !important; }

.capea-journal-card {
    background: #ffffff;
    border-radius: 14px;
    padding: 24px 20px;
    box-shadow: 0 3px 16px rgba(0,0,0,0.07);
    display: flex;
    flex-direction: column;
    border-top: 4px solid var(--clr-primary-dark);
}

.capea-journal-featured {
    border-top-color: var(--clr-secondary) !important;
    background: linear-gradient(135deg, #faf7ff 0%, #f5f0fb 100%) !important;
}

.capea-journal-badge {
    display: inline-block;
    background: var(--clr-primary-dark);
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: 12px;
    margin-bottom: 10px;
    letter-spacing: .5px;
    text-transform: uppercase;
}

.capea-journal-badge-grey {
    background: #888 !important;
    color: #1a1a1a !important;
}

.capea-journal-abbr {
    font-size: .78rem;
    color: #6d6d6d;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    margin: 0 0 6px !important;
}

.capea-journal-title {
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    color: var(--clr-text) !important;
    margin: 0 0 10px !important;
    line-height: 1.4 !important;
}

.capea-journal-desc {
    font-size: .88rem !important;
    color: var(--clr-muted) !important;
    line-height: 1.65 !important;
    flex: 1;
    margin: 0 0 16px !important;
}

/* Video thumbnails (legacy — kept for reference) */

/* Unique needs cards */
.capea-unique-needs-card {
    background: #ffffff;
    border-radius: 14px;
    padding: 24px 20px;
    box-shadow: 0 3px 16px rgba(0,0,0,0.07);
    text-align: center;
    border-top: 4px solid var(--clr-secondary);
    display: flex;
    flex-direction: column;
    align-items: center;
}

.capea-unique-needs-icon {
    font-size: 2.4rem !important;
    margin: 0 0 10px !important;
    line-height: 1 !important;
}

/* Facebook connect card */
.capea-fb-connect-card {
    background: #8861a5 ;
    border-radius: 16px;
    padding: 36px 28px;
    color: #fff;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.capea-fb-icon {
    font-size: 3rem !important;
    margin: 0 0 12px !important;
    line-height: 1 !important;
}

/* White btn outline (already in mem- but adding capea- prefix alias) */
.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    border-radius: 30px !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}

@media (max-width: 768px) {
    .capea-resource-supplier-card { padding: 20px 16px; }
    .capea-download-card { padding: 20px 16px; }
    .capea-journal-card { padding: 20px 16px; }
    .capea-unique-needs-card { padding: 20px 16px; }
}

/* Journal card button overrides — purple and teal-outline work on white/light card bg */
.capea-journal-card .wp-block-button.capea-btn-purple .wp-block-button__link {
    border-color: var(--clr-secondary) !important;
}
.capea-journal-card .wp-block-button.capea-btn-purple .wp-block-button__link:hover {
    background: #5c3878 !important;
    border-color: #5c3878 !important;
    color: #ffffff !important;
}
.capea-journal-card .wp-block-buttons {
    margin-top: auto;
    padding-top: 16px;
}


/* ══════════════════════════════════════════════════════════
   resources-for-expectant-parents — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Certification Page — Criteria cards
   ═══════════════════════════════════ */
.capea-criteria-box {
  border: 2px solid var(--clr-surface-container) !important;
  border-radius: 12px !important;
  padding: 28px !important;
  box-shadow: 0 2px 16px rgba(0,123,130,.06);
}

.capea-criteria-box--purple {
  border-color: #d9c5f0 !important;
  box-shadow: 0 2px 16px rgba(119,75,152,.06);
}

/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* Small teal button variant */
.capea-btn-teal-sm .wp-block-button__link {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    transition: background-color 0.2s !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background-color: var(--clr-primary-dark) !important;
}

/* Disclaimer / notice box on teal background */
.capea-disclaimer-box {
    background: rgba(255,255,255,0.15);
    border: 1px solid rgba(255,255,255,0.4);
    border-radius: 8px;
    padding: 16px 24px !important;
    margin-top: 32px !important;
    color: #ffffff;
}

.capea-disclaimer-box p {
    color: #ffffff !important;
    margin: 0 !important;
    font-size: 0.92rem;
    opacity: 1;
}

/* Small teal buttons for providers */
.capea-btn-teal-sm .wp-block-button__link {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
}

/* ============================================
   CAPEA BUTTON - TEAL OUTLINE VARIANT
   ============================================ */
.capea-btn-teal-outline .wp-block-button__link {
    background: transparent !important;
    color: var(--clr-primary-dark) !important;
    border: 2px solid var(--clr-primary-dark) !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
}

.capea-btn-teal-outline .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* White btn outline (already in mem- but adding capea- prefix alias) */
.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    border-radius: 30px !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}


/* ══════════════════════════════════════════════════════════
   teaching-tips — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* ═══════════════════════════════════
   Membership Page — White Solid Button
   ═══════════════════════════════════ */
.capea-btn-white-solid .wp-block-button__link {
  background: #ffffff !important;
  color: var(--clr-primary-dark) !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 700 !important;
  padding: 12px 28px !important;
}

.capea-btn-white-solid .wp-block-button__link:hover {
  background: rgba(255,255,255,0.9) !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* ============================================================
   TEACHING TIPS PAGE
   ============================================================ */

.capea-video-row { gap: 24px; align-items: stretch; }

.capea-video-card {
    background: var(--clr-surface-teal);
    border-radius: 12px;
    padding: 0;
    text-align: center;
    border-top: 4px solid var(--clr-primary-dark);
    overflow: hidden;
    transition: box-shadow 0.25s, transform 0.25s;
    cursor: pointer;
}

.capea-video-card:hover {
    box-shadow: 0 10px 36px rgba(0,108,80,0.2);
    transform: translateY(-3px);
}

/* Thumbnail wrap */
.capea-video-thumb-wrap {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: #1a1a1a;
    display: block;
}

.capea-video-thumb-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.35s ease, opacity 0.25s ease;
}

.capea-video-card:hover .capea-video-thumb-wrap img {
    transform: scale(1.05);
    opacity: 0.8;
}

/* Play button circle */
.capea-play-btn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 60px;
    height: 60px;
    background: rgba(255,255,255,0.95);
    border-radius: 50%;
    border: none;
    cursor: pointer;
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 20px rgba(0,0,0,0.35);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.capea-play-btn::after {
    content: '';
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 9px 0 9px 18px;
    border-color: transparent transparent transparent #cc0000;
    margin-left: 4px;
}

.capea-video-thumb-wrap:hover .capea-play-btn,
.capea-video-card:hover .capea-play-btn {
    transform: translate(-50%, -50%) scale(1.14);
    box-shadow: 0 6px 28px rgba(0,0,0,0.4);
}

/* Card text body */
.capea-video-card .capea-video-title {
    color: #2d2d2d !important;
    font-size: 1.05rem !important;
    margin: 18px 20px 8px !important;
}

.capea-video-card .capea-video-desc {
    color: var(--clr-muted) !important;
    font-size: 0.92rem !important;
    line-height: 1.5;
    margin: 0 20px 20px !important;
}

/* ---- Video modal ---- */
.capea-video-modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: rgba(0,0,0,0.82);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    align-items: center;
    justify-content: center;
}

.capea-video-modal-overlay.is-open { display: flex; }

.capea-video-modal-inner {
    position: relative;
    width: 90vw;
    max-width: 900px;
    background: #000;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 32px 96px rgba(0,0,0,0.65);
    animation: capea-modal-in 0.3s cubic-bezier(0.34,1.4,0.64,1) both;
}

@keyframes capea-modal-in {
    from { opacity: 0; transform: scale(0.86); }
    to   { opacity: 1; transform: scale(1); }
}

.capea-video-modal-inner iframe {
    display: block;
    width: 100%;
    aspect-ratio: 16/9;
    border: none;
}

.capea-video-modal-close {
    position: absolute;
    top: -46px;
    right: 0;
    background: none;
    border: none;
    color: #fff;
    font-size: 2rem;
    line-height: 1;
    padding: 4px 10px;
    cursor: pointer;
    opacity: 0.85;
    transition: opacity 0.15s;
}

.capea-video-modal-close:hover { opacity: 1; }

.capea-reflect-q {
    background: var(--clr-surface-teal);
    border-left: 4px solid var(--clr-primary-dark);
    padding: 12px 16px;
    margin-bottom: 10px !important;
    border-radius: 0 8px 8px 0;
    color: #2d2d2d !important;
    font-size: 0.95rem !important;
}

.capea-philosophy-col {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.capea-philosophy-point {
    background: #fff;
    border-radius: 10px;
    padding: 16px 20px;
    margin-bottom: 14px !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.07);
}

.capea-philosophy-icon { font-weight: 700 !important; color: var(--clr-secondary) !important; margin-bottom: 4px !important; }

.capea-philosophy-text { color: #444 !important; font-size: 0.93rem !important; margin: 0 !important; }

/* RAMP2FAME */
.capea-quote-block {
    font-size: 1.2rem !important;
    font-style: italic;
    color: rgba(255,255,255,0.9) !important;
    border-left: 4px solid rgba(255,255,255,0.5);
    padding: 12px 24px;
    margin: 0 auto 32px !important;
    max-width: 700px;
}

.capea-ramp-row { gap: 20px; margin-bottom: 20px !important; align-items: stretch; }

.capea-ramp-card {
    background: rgba(255,255,255,0.12);
    border-radius: 12px;
    padding: 24px 20px;
    border: 1px solid rgba(255,255,255,0.25);
    transition: background 0.2s;
}

.capea-ramp-card:hover { background: rgba(255,255,255,0.2); }

.capea-ramp-letter {
    font-size: 2.4rem !important;
    font-weight: 900 !important;
    color: #fff !important;
    line-height: 1 !important;
    margin-bottom: 8px !important;
    opacity: 0.9;
}

.capea-ramp-title { color: #fff !important; font-size: 1rem !important; margin-bottom: 8px !important; }

.capea-ramp-desc { color: rgba(255,255,255,0.95) !important; font-size: 0.88rem !important; line-height: 1.5; margin: 0 !important; }

/* ACTIVITIES */
.capea-activity-row { gap: 20px; margin-bottom: 20px !important; align-items: stretch; }

.capea-activity-card {
    border-radius: 12px;
    padding: 28px 22px;
    text-align: center;
    transition: transform 0.2s, box-shadow 0.2s;
}

.capea-activity-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.12); }

.capea-activity-teal { background: var(--clr-primary-dark); }

.capea-activity-purple { background: var(--clr-secondary); }

.capea-activity-icon { font-size: 2.2rem !important; margin-bottom: 12px !important; }

.capea-activity-title { color: #fff !important; font-size: 1.05rem !important; margin-bottom: 10px !important; }

.capea-activity-desc { color: rgba(255,255,255,0.9) !important; font-size: 0.9rem !important; line-height: 1.55; margin: 0 !important; }

.capea-iceberg-tip {
    background: #fff;
    border: 1px solid var(--clr-primary-dark);
    border-radius: 8px;
    padding: 14px 18px;
    color: #2d2d2d !important;
    font-size: 0.93rem !important;
    margin-top: 16px !important;
}

.capea-knowles-item {
    display: flex !important;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 14px !important;
    background: #fff;
    border-radius: 8px;
    padding: 12px 16px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.06);
}

.capea-knowles-num {
    background: var(--clr-secondary);
    color: #fff !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex !important;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    line-height: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
    min-width: 28px;
}

.capea-knowles-text { color: var(--clr-text) !important; font-size: 0.92rem !important; line-height: 1.5; margin: 0 !important; }

/* RETENTION STATS */
.capea-retention-row { gap: 12px; flex-wrap: wrap; justify-content: center; margin-bottom: 24px !important; }

.capea-retention-card {
    background: rgba(255,255,255,0.15);
    border-radius: 10px;
    padding: 20px 12px;
    text-align: center;
    border: 1px solid rgba(255,255,255,0.25);
    flex: 1;
    min-width: 100px;
}

.capea-retention-highlight {
    background: rgba(255,255,255,0.10) !important;
    border: 2px solid #fff !important;
    transform: scale(1.05);
}

.capea-retention-pct { color: #fff !important; font-size: 1.8rem !important; font-weight: 800 !important; margin: 0 0 6px !important; line-height: 1; }

.capea-retention-label { color: #ffffff !important; font-size: 0.8rem !important; margin: 0 !important; }

/* STORYTELLING */
.capea-story-tip {
    background: var(--clr-surface-teal);
    border-radius: 8px;
    padding: 14px 16px;
    margin-bottom: 12px !important;
    border-left: 3px solid var(--clr-secondary);
}

.capea-story-tip p { color: #2d2d2d !important; font-size: 0.93rem !important; margin: 0 !important; }

/* REFERENCES */
.capea-ref-link {
    padding: 10px 0;
    border-bottom: 1px solid #e0e0e0;
}

.capea-ref-link:last-child { border-bottom: none; }

.capea-ref-link p { color: var(--clr-text) !important; font-size: 0.95rem !important; margin: 0 !important; }

.capea-ref-link a { color: var(--clr-primary-dark) !important; text-decoration: underline; }

/* ---- Responsive ---- */
@media (max-width: 768px) {
    .capea-ramp-row, .capea-activity-row, .capea-video-row { flex-direction: column; }
    .capea-retention-row { gap: 8px; }
    .capea-retention-card { min-width: 80px; padding: 14px 8px; }
    .capea-retention-pct { font-size: 1.3rem !important; }
    .capea-knowles-item { flex-direction: row; }
}

/* White btn outline (already in mem- but adding capea- prefix alias) */
.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    border-radius: 30px !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}


/* ══════════════════════════════════════════════════════════
   membership — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Certification Page — Intro image
   ═══════════════════════════════════ */
.capea-intro-img img {
  border-radius: 12px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.12);
}

/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

/* ═══════════════════════════════════
   Membership Page — White Solid Button
   ═══════════════════════════════════ */
.capea-btn-white-solid .wp-block-button__link {
  background: #ffffff !important;
  color: var(--clr-primary-dark) !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 700 !important;
  padding: 12px 28px !important;
}

.capea-btn-white-solid .wp-block-button__link:hover {
  background: rgba(255,255,255,0.9) !important;
}

/* Small teal button variant */
.capea-btn-teal-sm .wp-block-button__link {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    transition: background-color 0.2s !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background-color: var(--clr-primary-dark) !important;
}

/* Small teal buttons for providers */
.capea-btn-teal-sm .wp-block-button__link {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
}

/* ============================================
   CAPEA BUTTON - TEAL OUTLINE VARIANT
   ============================================ */
.capea-btn-teal-outline .wp-block-button__link {
    background: transparent !important;
    color: var(--clr-primary-dark) !important;
    border: 2px solid var(--clr-primary-dark) !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
}

.capea-btn-teal-outline .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* Outline button variants */
.capea-btn-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    border-radius: 5px !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.capea-btn-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}

.capea-btn-outline-white .wp-block-button__link {
    background: transparent !important;
    border: 2px solid rgba(255,255,255,0.7) !important;
    color: #ffffff !important;
    border-radius: 5px !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.capea-btn-outline-white .wp-block-button__link:hover {
    border-color: #ffffff !important;
    background: rgba(255,255,255,0.12) !important;
}

/* PRICING CARDS */
.mem-pricing-row { align-items: stretch !important; max-width: 760px !important; margin: 0 auto 20px !important; }

.mem-price-card {
    background: #ffffff !important;
    border-radius: 16px !important;
    padding: 36px 28px !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.08) !important;
    text-align: center !important;
    border: 2px solid #e8e8e8 !important;
    display: flex !important;
    flex-direction: column !important;
}

.mem-price-card .wp-block-list { flex: 1 !important; text-align: left !important; }

.mem-price-card--featured {
    background: linear-gradient(135deg,var(--clr-secondary) 0%,#5b3fa0 100%) !important;
    border-color: transparent !important;
    box-shadow: 0 8px 32px rgba(119,75,152,0.35) !important;
    transform: scale(1.03) !important;
}

/* Featured card list - white ticks */
.mem-check-white.wp-block-list li { color: rgba(255,255,255,0.92) !important; border-color: rgba(255,255,255,0.2) !important; }

.mem-check-white.wp-block-list li::before { color: rgba(255,255,255,0.95) !important; }

/* Best value badge */
.mem-best-value {
    display: inline-block !important;
    background: rgba(255,255,255,0.15) !important;
    border: 2px solid rgba(255,255,255,0.5) !important;
    color: #ffffff !important;
    font-size: .8rem !important;
    font-weight: 700 !important;
    padding: 5px 16px !important;
    border-radius: 20px !important;
    margin-bottom: 12px !important;
}

/* Price tag display */
.mem-price-tag {
    font-size: 3.2rem !important;
    font-weight: 800 !important;
    color: var(--clr-primary-dark) !important;
    line-height: 1 !important;
    margin: 0 0 20px !important;
}

.mem-price-tag--white { color: #ffffff !important; }

.mem-curr { font-size: 1.4rem !important; font-weight: 700 !important; vertical-align: super !important; }

.mem-period { font-size: 1rem !important; font-weight: 400 !important; opacity: 0.90 !important; }

/* Payment note */
.mem-payment-note { font-size: .85rem !important; color: #6d6d6d !important; margin-top: 16px !important; }

/* TESTIMONIAL CARDS */
.mem-testimonials { gap: 24px !important; }

.mem-testimonial-card {
    background: #f9f9fb !important;
    border-radius: 16px !important;
    padding: 32px 28px !important;
    border-left: 4px solid var(--clr-primary-dark) !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06) !important;
    display: flex !important;
    flex-direction: column !important;
}

.mem-quote-mark {
    font-size: 4rem !important;
    color: var(--clr-primary-dark) !important;
    line-height: 1 !important;
    margin: 0 0 8px !important;
    font-family: Georgia, serif !important;
    opacity: 0.4 !important;
}

.mem-quote-text {
    font-size: .95rem !important;
    color: #444 !important;
    line-height: 1.75 !important;
    font-style: italic !important;
    flex: 1 !important;
    margin-bottom: 16px !important;
}

.mem-quote-name {
    font-size: .88rem !important;
    color: var(--clr-muted) !important;
    margin: 0 !important;
    border-top: 1px solid #e8e8e8 !important;
    padding-top: 12px !important;
}

.mem-quote-name strong { color: var(--clr-primary-dark) !important; }

@media (max-width: 768px) {
    .mem-price-card--featured { transform: scale(1) !important; }
    .mem-pricing-row { max-width: 100% !important; }
    .mem-testimonials .wp-block-column { margin-bottom: 20px !important; }
}


/* ══════════════════════════════════════════════════════════
   join-or-renew-membership — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Certification Page — Intro image
   ═══════════════════════════════════ */
.capea-intro-img img {
  border-radius: 12px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.12);
}

/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

/* ═══════════════════════════════════
   Membership Page — Pricing Cards
   ═══════════════════════════════════ */
.capea-pricing-row {
  gap: 32px !important;
  align-items: stretch !important;
}

.capea-price-card--featured {
  background: var(--clr-primary-dark);
  border-color: var(--clr-primary-dark);
}

.capea-price-save-badge {
  background: rgba(255,255,255,0.15);
  color: #ffffff !important;
  font-size: .8rem !important;
  font-weight: 700 !important;
  padding: 4px 0 !important;
  border-radius: 6px;
  margin-bottom: 8px !important;
  letter-spacing: .3px;
}

.capea-price-tag--white { color: #ffffff !important; }

.capea-price-currency {
  font-size: 1.6rem;
  font-weight: 700;
  vertical-align: super;
  line-height: 0;
}

.capea-price-period {
  font-size: 1rem;
  font-weight: 400;
  opacity: 0.90;
}

.capea-list-white li { color: rgba(255,255,255,0.92) !important; }

.capea-list-white li::marker { color: rgba(255,255,255,0.95) !important; }

.capea-payment-note {
  color: #6d6d6d !important;
  font-size: 0.88rem !important;
  margin-top: 16px !important;
}

.capea-payment-note a { color: var(--clr-primary-dark) !important; }

/* ═══════════════════════════════════
   Membership Page — White Solid Button
   ═══════════════════════════════════ */
.capea-btn-white-solid .wp-block-button__link {
  background: #ffffff !important;
  color: var(--clr-primary-dark) !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 700 !important;
  padding: 12px 28px !important;
}

.capea-btn-white-solid .wp-block-button__link:hover {
  background: rgba(255,255,255,0.9) !important;
}

/* Small teal button variant */
.capea-btn-teal-sm .wp-block-button__link {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    transition: background-color 0.2s !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background-color: var(--clr-primary-dark) !important;
}

/* Small teal buttons for providers */
.capea-btn-teal-sm .wp-block-button__link {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
}

/* ============================================
   CAPEA BUTTON - TEAL OUTLINE VARIANT
   ============================================ */
.capea-btn-teal-outline .wp-block-button__link {
    background: transparent !important;
    color: var(--clr-primary-dark) !important;
    border: 2px solid var(--clr-primary-dark) !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
}

.capea-btn-teal-outline .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}


/* ══════════════════════════════════════════════════════════
   find-a-capea-certified-educator-or-trainer — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* Small teal button variant */
.capea-btn-teal-sm .wp-block-button__link {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    transition: background-color 0.2s !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background-color: var(--clr-primary-dark) !important;
}

/* ============================================================
   FIND-A-EDUCATOR / DIRECTORY PAGE
   ============================================================ */

/* Directory section anchor fix */
.capea-directory-section {
    scroll-margin-top: 100px;
}

/* Legend */
.capea-directory-legend {
    background: var(--clr-surface-teal);
    border-left: 4px solid var(--clr-primary-dark);
    border-radius: 6px;
    padding: 12px 20px;
    margin-bottom: 32px;
}

.capea-legend-label {
    margin: 0 !important;
    font-size: 0.95rem;
    color: #444;
}

/* State headings */
.capea-directory-state-heading {
    font-size: 1.2rem !important;
    color: var(--clr-primary-dark) !important;
    border-bottom: 2px solid var(--clr-primary-dark);
    padding-bottom: 8px;
    margin-top: 40px !important;
    margin-bottom: 12px !important;
}

/* Directory table */
.capea-directory-table table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.93rem;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0,0,0,0.07);
}

.capea-directory-table thead tr {
    background: var(--clr-primary-dark);
    color: #ffffff;
}

.capea-directory-table thead th {
    padding: 12px 16px;
    text-align: left;
    font-weight: 700;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #ffffff;
}

.capea-directory-table tbody tr:nth-child(even) {
    background: #f8f8f8;
}

.capea-directory-table tbody tr:nth-child(odd) {
    background: #ffffff;
}

.capea-directory-table tbody tr:hover {
    background: var(--clr-surface-teal);
}

.capea-directory-table tbody td {
    padding: 11px 16px;
    border-bottom: 1px solid #eee;
    color: var(--clr-text);
    vertical-align: middle;
}

/* Directory note */
.capea-directory-note {
    background: #fff8e1;
    border-left: 4px solid #f59e0b;
    border-radius: 6px;
    padding: 14px 20px;
    margin-top: 32px;
}

.capea-directory-note p {
    margin: 0 !important;
    font-size: 0.93rem;
    color: var(--clr-muted);
}

.capea-directory-note a {
    color: var(--clr-primary-dark);
    font-weight: 600;
}

/* Why Become cards */
.capea-become-card {
    background: #ffffff;
    border-radius: 12px;
    padding: 32px 24px !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.07);
    text-align: center;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.capea-become-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}

/* Responsive: stack directory tables on mobile */
@media (max-width: 768px) {
    .capea-directory-table table,
    .capea-directory-table thead,
    .capea-directory-table tbody,
    .capea-directory-table th,
    .capea-directory-table td,
    .capea-directory-table tr {
        display: block;
    }
    .capea-directory-table thead tr {
        display: none;
    }
    .capea-directory-table tbody td {
        padding: 8px 12px;
        border-bottom: none;
    }
    .capea-directory-table tbody td:first-child {
        background: var(--clr-primary-dark);
        color: #fff;
        font-weight: 700;
        border-radius: 6px 6px 0 0;
        padding-top: 12px;
    }
    .capea-directory-table tbody tr {
        margin-bottom: 16px;
        border: 1px solid #e0e0e0;
        border-radius: 8px;
        overflow: hidden;
    }
    .capea-become-card {
        margin-bottom: 16px;
    }
}

/* Small teal buttons for providers */
.capea-btn-teal-sm .wp-block-button__link {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
}

/* ============================================
   CAPEA BUTTON - TEAL OUTLINE VARIANT
   ============================================ */
.capea-btn-teal-outline .wp-block-button__link {
    background: transparent !important;
    color: var(--clr-primary-dark) !important;
    border: 2px solid var(--clr-primary-dark) !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
}

.capea-btn-teal-outline .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* White btn outline (already in mem- but adding capea- prefix alias) */
.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    border-radius: 30px !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}


/* ══════════════════════════════════════════════════════════
   why-become-a-capea-certified-educator-or-trainer — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Certification Page — Intro image
   ═══════════════════════════════════ */
.capea-intro-img img {
  border-radius: 12px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.12);
}

.capea-cta-email {
  color: rgba(255,255,255,0.95) !important;
  font-size: 0.95rem !important;
  margin-top: 20px !important;
}

.capea-cta-email a {
  color: #ffffff !important;
  text-decoration: underline;
}

/* ═══════════════════════════════════
   Certification Page — Buttons
   ═══════════════════════════════════ */
.capea-btn-teal .wp-block-button__link {
  background: var(--clr-primary-dark) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 12px 28px !important;
}

.capea-btn-teal .wp-block-button__link:hover { background: var(--clr-primary-dark) !important; }

.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* Small teal button variant */
.capea-btn-teal-sm .wp-block-button__link {
    background-color: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    transition: background-color 0.2s !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background-color: var(--clr-primary-dark) !important;
}

/* Small teal buttons for providers */
.capea-btn-teal-sm .wp-block-button__link {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.capea-btn-teal-sm .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
}

/* ============================================
   CAPEA BUTTON - TEAL OUTLINE VARIANT
   ============================================ */
.capea-btn-teal-outline .wp-block-button__link {
    background: transparent !important;
    color: var(--clr-primary-dark) !important;
    border: 2px solid var(--clr-primary-dark) !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
}

.capea-btn-teal-outline .wp-block-button__link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* White btn outline (already in mem- but adding capea- prefix alias) */
.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    border-radius: 30px !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}


/* ══════════════════════════════════════════════════════════
   contact-us — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
.capea-btn-white-outline .wp-block-button__link {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
  background: rgba(255,255,255,0.15) !important;
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */

/* --- Contact Info Strip --- */
.capea-contact-strip {
    gap: 20px !important;
    margin-top: 20px;
}

.capea-contact-item {
    background: rgba(255,255,255,0.12);
    border-radius: 12px;
    padding: 28px 20px;
    text-align: center;
    transition: background 0.3s ease, transform 0.2s ease;
}

.capea-contact-item:hover {
    background: rgba(255,255,255,0.2);
    transform: translateY(-3px);
}

.capea-contact-icon {
    font-size: 2.2rem;
    margin: 0 0 10px !important;
    line-height: 1;
}

.capea-contact-label {
    color: #ffffff !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    margin: 0 0 8px !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.capea-contact-detail {
    margin: 0 0 6px !important;
    font-size: 0.95rem;
}

.capea-contact-detail a {
    color: #ffffff !important;
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.capea-contact-note {
    color: rgba(255,255,255,0.95) !important;
    font-size: 0.82rem !important;
    margin: 0 !important;
    font-style: italic;
}

/* --- Contact Form Section --- */
.capea-contact-form-cols {
    gap: 60px !important;
    align-items: flex-start !important;
}

.capea-contact-info-box {
    background: var(--clr-surface-teal);
    border-left: 4px solid var(--clr-primary-dark);
    border-radius: 10px;
    padding: 28px 24px;
    margin-top: 24px;
}

.capea-contact-info-box h3 {
    font-size: 1rem !important;
    font-weight: 700 !important;
    margin: 0 0 10px !important;
    color: var(--clr-primary-dark) !important;
}

.capea-contact-info-box p {
    font-size: 0.9rem;
    margin: 0 0 6px !important;
    color: #444;
}

.capea-contact-email-list {
    margin: 0 !important;
    padding-left: 18px !important;
}

.capea-contact-email-list li {
    font-size: 0.88rem;
    color: #444;
    margin-bottom: 6px !important;
    line-height: 1.5;
}

.capea-contact-email-list a {
    color: var(--clr-primary-dark) !important;
    text-decoration: none;
}

.capea-contact-email-list a:hover {
    text-decoration: underline;
}

.capea-form-wrapper {
    background: #f8f9fa;
    border-radius: 14px;
    padding: 36px 32px !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.07);
}

/* --- Facebook Section --- */
.capea-facebook-section {
    padding: 70px 24px !important;
}

.capea-fb-eyebrow {
    color: rgba(255,255,255,0.95) !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin: 0 0 10px !important;
}

.capea-fb-lead {
    color: rgba(255,255,255,0.9) !important;
    font-size: 1.1rem !important;
    line-height: 1.7 !important;
    margin: 0 0 24px !important;
}

.capea-fb-list {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.capea-fb-list li {
    color: rgba(255,255,255,0.9) !important;
    font-size: 0.95rem !important;
    margin-bottom: 10px !important;
    padding-left: 4px;
}

.capea-btn-facebook .wp-block-button__link {
    background: #1877f2 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 50px !important;
    padding: 14px 32px !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    transition: background 0.3s ease, transform 0.2s ease;
    margin-top: 16px;
}

.capea-btn-facebook .wp-block-button__link:hover {
    background: #1464d8 !important;
    transform: translateY(-2px);
}

/* Facebook card (right column) */
.capea-fb-card {
    background: rgba(255,255,255,0.1) !important;
    border: 1px solid rgba(255,255,255,0.25);
    border-radius: 20px;
    padding: 40px 32px !important;
    text-align: center;
    backdrop-filter: blur(8px);
    max-width: 380px;
    margin: 0 auto;
}

.capea-fb-logo {
    font-size: 3.5rem !important;
    font-weight: 900 !important;
    color: #1877f2 !important;
    background: #ffffff;
    width: 72px;
    height: 72px;
    line-height: 72px !important;
    border-radius: 50%;
    margin: 0 auto 16px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Helvetica Neue', Arial, sans-serif;
}

.capea-fb-card-title {
    color: #ffffff !important;
    font-size: 1.3rem !important;
    font-weight: 700 !important;
    margin: 0 0 6px !important;
}

.capea-fb-card-sub {
    color: rgba(255,255,255,0.95) !important;
    font-size: 0.88rem !important;
    margin: 0 !important;
}

.capea-fb-divider {
    border-color: rgba(255,255,255,0.25) !important;
    margin: 20px 0 !important;
}

.capea-fb-card-tags {
    color: rgba(255,255,255,0.95) !important;
    font-size: 0.82rem !important;
    letter-spacing: 0.04em;
    margin: 0 0 10px !important;
}

.capea-fb-tagline {
    color: rgba(255,255,255,0.95) !important;
    font-size: 0.85rem !important;
    font-style: italic;
    margin: 0 0 20px !important;
}

.capea-btn-fb-card .wp-block-button__link {
    background: #1877f2 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 50px !important;
    padding: 10px 28px !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    transition: background 0.3s ease;
}

.capea-btn-fb-card .wp-block-button__link:hover {
    background: #1464d8 !important;
}

/* --- Responsive --- */
@media (max-width: 768px) {
    .capea-contact-strip { flex-direction: column !important; }
    .capea-contact-item { padding: 20px 16px; }
    .capea-contact-form-cols { flex-direction: column !important; gap: 30px !important; }
    .capea-form-wrapper { padding: 24px 18px !important; }
    .capea-facebook-section { padding: 50px 16px !important; }
    .capea-fb-card { padding: 28px 20px !important; }
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* White btn outline (already in mem- but adding capea- prefix alias) */
.capea-btn-white-outline .wp-block-button__link {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    border-radius: 30px !important;
    padding: 12px 28px !important;
    font-weight: 700 !important;
    transition: all .2s !important;
}

.capea-btn-white-outline .wp-block-button__link:hover {
    background: rgba(255,255,255,0.15) !important;
}

/* ══════════════════════════════════════════════════════════
   RESOURCES PAGE — Premium card reskin
   Overrides old border-accent styles across all card families
   ══════════════════════════════════════════════════════════ */

/* ── Supplier cards ── */
.capea-resource-supplier-card {
    background: #ffffff;
    border-radius: 18px;
    padding: 28px 24px 22px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.04), 0 8px 24px rgba(0,0,0,0.07);
    text-align: left !important;
    border-top: none !important;
    display: flex;
    flex-direction: column;
    align-items: flex-start !important;
    transition: transform .25s cubic-bezier(.25,.8,.25,1), box-shadow .25s;
}

.capea-resource-supplier-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 2px 6px rgba(0,0,0,0.04), 0 18px 44px rgba(0,108,80,0.13);
}

.capea-card-teal-top  { border-top: none !important; }
.capea-card-purple-top { border-top: none !important; }

/* Supplier card — flag badge */
.capea-supplier-flag {
    display: inline-block !important;
    width: auto !important;
    max-width: none !important;
    height: auto !important;
    object-fit: unset !important;
    background: var(--wp--preset--color--surface-teal-light, #f0f9f6);
    color: var(--clr-primary-dark);
    font-size: 0.72rem;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 20px;
    margin-bottom: 14px !important;
    letter-spacing: 0.2px;
    line-height: 1.5;
}

.capea-supplier-name {
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    color: var(--clr-text) !important;
    margin: 0 0 10px !important;
    text-align: left !important;
    line-height: 1.35 !important;
}

.capea-supplier-desc {
    font-size: .875rem !important;
    color: var(--clr-muted) !important;
    line-height: 1.65 !important;
    flex: 1;
    margin: 0 0 18px !important;
    text-align: left !important;
}

/* Resource link — pill style */
.capea-resource-link {
    display: inline-block;
    font-size: .8rem;
    font-weight: 700;
    color: var(--clr-primary-dark);
    text-decoration: none;
    border-bottom: none;
    padding: 6px 14px;
    background: var(--wp--preset--color--surface-teal-light, #f0f9f6);
    border-radius: 20px;
    transition: background .2s, color .2s;
}

.capea-resource-link:hover {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    border-bottom: none !important;
}

/* On light-section bg, supplier card stays white for contrast */
.capea-section-light .capea-resource-supplier-card {
    background: #ffffff;
    box-shadow: 0 2px 6px rgba(0,0,0,0.05), 0 8px 24px rgba(0,0,0,0.09);
}

/* ── Download cards ── */
.capea-download-card {
    background: linear-gradient(145deg, #e4f7ef 0%, #cef0e1 100%);
    border-radius: 18px;
    padding: 28px 24px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.04), 0 8px 24px rgba(0,108,80,0.09);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    border-left: none !important;
    transition: transform .25s cubic-bezier(.25,.8,.25,1), box-shadow .25s;
}

.capea-download-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 2px 6px rgba(0,0,0,0.05), 0 16px 40px rgba(0,108,80,0.15);
}

.capea-download-teal {
    background: linear-gradient(145deg, #e4f7ef 0%, #cef0e1 100%) !important;
    border-left: none !important;
}

.capea-download-purple {
    background: linear-gradient(145deg, #f2eafb 0%, #e6d5f7 100%) !important;
    border-left: none !important;
    box-shadow: 0 2px 6px rgba(0,0,0,0.04), 0 8px 24px rgba(119,75,152,0.10) !important;
}

.capea-download-purple:hover {
    box-shadow: 0 2px 6px rgba(0,0,0,0.05), 0 16px 40px rgba(119,75,152,0.16) !important;
}

/* Download icon — frosted circle */
.capea-download-icon {
    font-size: 1.7rem !important;
    margin: 0 0 18px !important;
    line-height: 1 !important;
    width: 56px;
    height: 56px;
    background: rgba(255,255,255,0.68);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.07);
}

.capea-download-title {
    font-size: 1.0rem !important;
    font-weight: 700 !important;
    color: var(--clr-primary-dark) !important;
    margin: 0 0 10px !important;
}

.capea-download-purple .capea-download-title { color: var(--clr-secondary) !important; }

.capea-download-desc {
    font-size: .875rem !important;
    color: rgba(20,40,30,0.72) !important;
    line-height: 1.65 !important;
    flex: 1;
    margin: 0 0 20px !important;
}

/* Bento grid: center download card 18% wider */
.capea-download-row.wp-block-columns {
    display: grid !important;
    grid-template-columns: 1fr 1.18fr 1fr !important;
    gap: 20px !important;
    flex-wrap: unset !important;
    align-items: stretch !important;
}

.capea-download-row .wp-block-column {
    width: auto !important;
    min-width: 0 !important;
}

/* ── Unique Needs cards ── */
.capea-unique-needs-card {
    background: linear-gradient(145deg, #f5fdf8 0%, #eaf7f1 100%);
    border-radius: 18px;
    padding: 36px 32px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.04), 0 8px 24px rgba(0,108,80,0.08);
    text-align: left !important;
    border-top: none !important;
    display: flex;
    flex-direction: column;
    align-items: flex-start !important;
    transition: transform .25s, box-shadow .25s;
}

.capea-unique-needs-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 2px 6px rgba(0,0,0,0.06), 0 16px 40px rgba(0,108,80,0.12);
}

/* Icon in tinted circle */
.capea-unique-needs-icon {
    font-size: 1.7rem !important;
    margin: 0 0 20px !important;
    line-height: 1 !important;
    width: 60px;
    height: 60px;
    background: rgba(0,108,80,0.10);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* ── Stay Connected cards — glassmorphism ── */
.capea-fb-connect-card {
    background: rgba(255,255,255,0.13) !important;
    border: 1px solid rgba(255,255,255,0.22) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-radius: 18px !important;
    padding: 36px 28px !important;
    color: #fff;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    transition: background .25s;
}

.capea-fb-connect-card:hover {
    background: rgba(255,255,255,0.20) !important;
}

/* Stay connected icon in frosted circle */
.capea-fb-icon {
    font-size: 1.7rem !important;
    margin: 0 0 18px !important;
    line-height: 1 !important;
    width: 56px;
    height: 56px;
    background: rgba(255,255,255,0.20);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* ── Responsive ── */
@media (max-width: 768px) {
    .capea-download-row.wp-block-columns {
        display: flex !important;
        flex-direction: column !important;
    }
    .capea-unique-needs-card { padding: 28px 20px !important; }
    .capea-resource-supplier-card { padding: 22px 18px !important; }
    .capea-download-card { padding: 22px 18px !important; }
    .capea-fb-connect-card { padding: 28px 20px !important; }
}

/* ── Facebook card — brand blue override ── */
.capea-fb-facebook-card {
    background: #1877F2 !important;
    border-color: rgba(255,255,255,0.18) !important;
}

.capea-fb-facebook-card:hover {
    background: #1464d8 !important;
}

/* Facebook icon circle on blue bg */
.capea-fb-facebook-card .capea-fb-icon {
    background: rgba(255,255,255,0.18);
}

/* Facebook button — white bg, Facebook blue text */
.wp-block-button.capea-btn-fb .wp-block-button__link {
    color: #1877F2 !important;
}

.wp-block-button.capea-btn-fb .wp-block-button__link:hover {
    background: rgba(255,255,255,0.9) !important;
    color: #1464d8 !important;
}

/* ── Journal badge pills — correct colours + shrink to content ── */
.capea-journal-badge {
    background: var(--clr-secondary) !important;
    color: #ffffff !important;
    align-self: flex-start;
}

.capea-journal-badge-grey {
    background: var(--clr-primary-dark) !important;
    color: #ffffff !important;
    align-self: flex-start;
}


/* ══════════════════════════════════════════════════════════
   state-executive-teams — styles ported from production, capea2 palette applied
   ══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════
   Membership Page — White Solid Button
   ═══════════════════════════════════ */
.capea-btn-white-solid .wp-block-button__link {
  background: #ffffff !important;
  color: var(--clr-primary-dark) !important;
  border: 2px solid #ffffff !important;
  border-radius: 6px !important;
  font-weight: 700 !important;
  padding: 12px 28px !important;
}

.capea-btn-white-solid .wp-block-button__link:hover {
  background: rgba(255,255,255,0.9) !important;
}

/* Force all CAPEA buttons to never show default WordPress blue */
.wp-block-button.capea-btn-teal .wp-block-button__link,
.wp-block-button.capea-btn-teal-outline .wp-block-button__link,
.wp-block-button.capea-btn-white-solid .wp-block-button__link,
.wp-block-button.capea-btn-white-outline .wp-block-button__link {
    box-shadow: none !important;
    text-decoration: none !important;
}

/* ── Members nav bar ──────────────────────────────────────────────────── */
:root { --members-bar-height: 48px; }

.capea-members-bar {
    background: var(--wp--preset--color--secondary);
    width: 100%;
    position: sticky;
    top: 0;
    z-index: 51;
}
/* With admin bar: bar must sit below it (same pattern as the main header) */
.admin-bar .capea-members-bar { top: 32px; }
@media screen and (max-width: 782px) {
    .admin-bar .capea-members-bar { top: 46px; }
}

/* Push the sticky header below the members bar */
body:has(.capea-members-bar) .wp-block-template-part:has(.site-header) {
    top: var(--members-bar-height);
}
/* Admin bar + members bar: header sits below both */
body.admin-bar:has(.capea-members-bar) .wp-block-template-part:has(.site-header) {
    top: calc(32px + var(--members-bar-height));
}
@media screen and (max-width: 782px) {
    body.admin-bar:has(.capea-members-bar) .wp-block-template-part:has(.site-header) {
        top: calc(46px + var(--members-bar-height));
    }
}

.capea-members-bar__inner {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 4px;
    padding: 10px 28px;
    overflow-x: auto;
    scrollbar-width: none;
    max-width: 1280px;
    margin: 0 auto;
}
.capea-members-bar__inner::-webkit-scrollbar {
    display: none;
}
.capea-members-bar__link {
    color: rgba(255,255,255,0.95);
    text-decoration: none;
    font-size: 0.875rem;
    font-family: var(--font-body);
    font-weight: 500;
    white-space: nowrap;
    padding: 5px 13px;
    border-radius: 5px;
    transition: background 0.15s;
    flex-shrink: 0;
    line-height: 1.4;
}
.capea-members-bar__link:hover {
    background: rgba(255,255,255,0.15);
    color: #fff;
    text-decoration: none;
}
.capea-members-bar__link--current {
    background: var(--wp--preset--color--secondary-container);
    color: #2d1a3d;
}
.capea-members-bar__link--current:hover {
    background: var(--wp--preset--color--secondary-container);
    color: #2d1a3d;
}

/* ── Members Dashboard (content-restricted2) ─────────────────────────── */
.capea-dashboard-hero {
    background: linear-gradient(135deg, var(--clr-primary-dark) 0%, var(--clr-primary-dark) 60%, #004a50 100%);
    border-radius: 20px;
    overflow: hidden;
}
.capea-dashboard-hero .wp-block-heading,
.capea-dashboard-hero p { color: #fff !important; }
.capea-dashboard-badge {
    display: block;
    width: fit-content;
    margin-left: auto !important;
    margin-right: auto !important;
    background: rgba(255,255,255,0.15);
    font-size: 0.78rem !important;
    font-weight: 700 !important;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    padding: 5px 18px;
    border-radius: 100px;
    border: 1px solid rgba(255,255,255,0.3);
}
.capea-dashboard-step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: var(--clr-primary-dark);
    color: #fff !important;
    font-size: 0.9rem !important;
    font-weight: 800 !important;
    border-radius: 50%;
    line-height: 1 !important;
    margin-block-start: 0 !important;
}
.capea-dashboard-hero-emoji {
    font-size: 3.5rem !important;
    line-height: 1 !important;
    margin-block-start: 0 !important;
    margin-block-end: 12px !important;
}
.capea-dashboard-step {
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 16px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05);
    transition: transform 0.2s, box-shadow 0.2s;
    display: flex !important;
    flex-direction: column !important;
    height: 100%;
}
.capea-dashboard-step:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,0.10); }
.capea-dashboard-step-icon {
    font-size: 2rem !important;
    line-height: 1 !important;
    margin-block-start: 8px !important;
    margin-block-end: 4px !important;
}
.capea-dashboard-step-link {
    margin-block-start: auto !important;
    padding-block-start: 12px;
}
.capea-dashboard-step-link a {
    color: var(--clr-primary-dark) !important;
    font-size: 0.85rem !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    border-bottom: 2px solid rgba(0,108,80,0.3);
    padding-bottom: 2px;
}
.capea-dashboard-step-link a:hover { border-bottom-color: var(--clr-primary-dark); }
/* Equal-height step columns */
.wp-block-columns:has(.capea-dashboard-step) > .wp-block-column { display: flex; flex-direction: column; }
.wp-block-columns:has(.capea-dashboard-step) > .wp-block-column > .wp-block-group { flex: 1; }
.capea-dashboard-card {
    border-radius: 14px;
    border: 1px solid transparent;
    transition: transform 0.2s, box-shadow 0.2s;
    display: flex !important;
    flex-direction: column !important;
    height: 100%;
}
.capea-dashboard-card:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(0,0,0,0.12); }
.capea-dashboard-card-icon {
    font-size: 2.1rem !important;
    line-height: 1 !important;
    margin-block-start: 0 !important;
    margin-block-end: 8px !important;
}
.capea-dashboard-card-arrow {
    margin-block-start: auto !important;
    padding-block-start: 10px;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
}
.capea-dashboard-card-arrow a { text-decoration: none !important; opacity: 0.8; }
.capea-dashboard-card-teal   { background: linear-gradient(135deg, #e6f7f8, #d0f0f2); border-color: #b2e4e7; }
.capea-dashboard-card-purple { background: linear-gradient(135deg, #f3eeff, #e8dcfc); border-color: #d4b8f5; }
.capea-dashboard-card-gold   { background: linear-gradient(135deg, #fef9e6, #fdf0c0); border-color: #f5dfa0; }
.capea-dashboard-card-green  { background: linear-gradient(135deg, #eafaf0, #d2f5e0); border-color: #a8e8c0; }
.capea-dashboard-card-coral  { background: linear-gradient(135deg, #fff0ee, #ffe0dc); border-color: #f5c0b8; }
.capea-dashboard-card-blue   { background: linear-gradient(135deg, #eef3ff, #dce8fd); border-color: #b8d0f8; }
/* Equal-height benefit card columns */
.wp-block-columns:has(.capea-dashboard-card) > .wp-block-column { display: flex; flex-direction: column; }
.wp-block-columns:has(.capea-dashboard-card) > .wp-block-column > .wp-block-group { flex: 1; }
.capea-dashboard-card-teal   .wp-block-heading { color: var(--clr-primary-dark) !important; }
.capea-dashboard-card-purple .wp-block-heading { color: #5b3fa0 !important; }
.capea-dashboard-card-gold   .wp-block-heading { color: #7a5c00 !important; }
.capea-dashboard-card-green  .wp-block-heading { color: #1a6b3c !important; }
.capea-dashboard-card-coral  .wp-block-heading { color: #8b2a1a !important; }
.capea-dashboard-card-blue   .wp-block-heading { color: #1a3f8b !important; }
.capea-dashboard-card-teal   .capea-dashboard-card-arrow a { color: var(--clr-primary-dark) !important; }
.capea-dashboard-card-purple .capea-dashboard-card-arrow a { color: #5b3fa0 !important; }
.capea-dashboard-card-gold   .capea-dashboard-card-arrow a { color: #7a5c00 !important; }
.capea-dashboard-card-green  .capea-dashboard-card-arrow a { color: #1a6b3c !important; }
.capea-dashboard-card-coral  .capea-dashboard-card-arrow a { color: #8b2a1a !important; }
.capea-dashboard-card-blue   .capea-dashboard-card-arrow a { color: #1a3f8b !important; }
.capea-dashboard-card p { font-size: 0.875rem !important; color: var(--clr-muted) !important; }
.capea-dashboard-highlight {
    background: linear-gradient(135deg, #f8f0ff, #ede5f8);
    border: 2px solid #c9a8e8;
    border-radius: 16px;
    gap: 28px !important;
}
.capea-dashboard-highlight-icon {
    font-size: 3.25rem !important;
    line-height: 1 !important;
    flex-shrink: 0;
    margin-block-start: 0 !important;
}
.capea-dashboard-highlight .wp-block-heading { color: #5b3fa0 !important; }
.capea-dashboard-highlight > .wp-block-group { flex: 1; min-width: 0; }
.capea-dashboard-help {
    background: #f4f4f4;
    border-radius: 12px;
}
.capea-dashboard-help p { color: var(--clr-muted) !important; font-size: 0.9375rem !important; margin-block-start: 0 !important; }

/* ── Member Profile Panel (dashboard) ──────────────────────────────── */
.capea-member-panel {
    display: flex;
    align-items: stretch;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 4px 28px rgba(0,0,0,0.08);
    background: #fff;
}
.capea-member-panel-left {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 32px 28px;
    background: #fff;
    border-right: 1px solid rgba(0,108,80,0.10);
    min-width: 172px;
}
.capea-member-panel-avatar {
    width: 88px;
    height: 88px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid #43b790;
    box-shadow: 0 2px 12px rgba(0,108,80,0.15);
    display: block;
}
.capea-member-panel-change {
    font-size: 0.75rem;
    color: var(--clr-primary-dark, #006c50);
    text-decoration: none;
    opacity: 0.65;
    letter-spacing: 0.2px;
    transition: opacity .2s;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    font-family: inherit;
}
.capea-member-panel-change:hover { opacity: 1; }
.capea-member-panel-change:disabled { opacity: 0.4; cursor: not-allowed; }
.capea-member-panel-name {
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    color: #2b2b2b !important;
    text-align: center;
    margin: 0 !important;
    line-height: 1.3;
}
.capea-member-panel-badge {
    font-size: 0.69rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--clr-primary-dark, #006c50);
    background: rgba(0,108,80,0.08);
    border: 1px solid rgba(0,108,80,0.18);
    border-radius: 99px;
    padding: 3px 10px;
    display: inline-block;
}
.capea-member-panel-edit-btn {
    margin-top: 4px;
    background: var(--clr-primary-dark, #006c50);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 10px 22px;
    font-size: 0.875rem;
    font-weight: 700;
    cursor: pointer;
    transition: background .2s, transform .15s;
    font-family: inherit;
    white-space: nowrap;
}
.capea-member-panel-edit-btn:hover { background: #004d38; transform: translateY(-1px); }
.capea-member-panel-right {
    flex: 1;
    background: var(--wp--preset--color--surface, #effcf6);
    padding: 32px 36px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    align-content: center;
}
/* Welcome header spanning above the scorecard grid */
.capea-member-panel-welcome {
    grid-column: 1 / -1;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(0,108,80,0.12);
}
.capea-member-panel-welcome-heading {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--clr-primary-dark, #006c50) !important;
    margin: 0 0 4px !important;
    line-height: 1.3;
}
.capea-member-panel-welcome-sub {
    font-size: 0.85rem !important;
    color: #555 !important;
    margin: 0 !important;
    line-height: 1.5;
}
.capea-sc-light {
    background: linear-gradient(135deg, #fff, #f8fefc) !important;
    border: 1px solid rgba(0,108,80,0.15) !important;
    box-shadow: 0 2px 12px rgba(0,108,80,0.06) !important;
    margin: 0 !important;
    max-width: none !important;
    color: #2b2b2b !important;
}
.capea-sc-light .capea-jl-sc-label { opacity: 0.65; color: var(--clr-primary-dark, #006c50); }
.capea-sc-light .capea-jl-sc-seen { color: var(--clr-primary-dark, #006c50) !important; }
.capea-sc-light .capea-jl-sc-sep,
.capea-sc-light .capea-jl-sc-total { color: #666; opacity: 1; }
.capea-sc-light .capea-jl-sc-bar-wrap { background: rgba(0,108,80,0.12) !important; }
.capea-sc-light .capea-jl-sc-bar { background: var(--clr-primary-dark, #006c50) !important; }
.capea-sc-light .capea-jl-sc-sub { color: #555; opacity: 1; }
.capea-sc-light .capea-jl-sc-sub a { color: var(--clr-primary-dark, #006c50); }
@media (max-width: 640px) {
    .capea-member-panel { flex-direction: column; }
    .capea-member-panel-left { border-right: none; border-bottom: 1px solid rgba(0,108,80,0.10); flex-direction: row; flex-wrap: wrap; justify-content: center; padding: 20px 24px; }
    .capea-member-panel-right { padding: 24px 20px; }
}
@media (max-width: 480px) {
    .capea-member-panel-right { grid-template-columns: 1fr; }
}

/* ── Edit Profile Modal ─────────────────────────────────────────────── */
.capea-profile-modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.55);
    z-index: 10001;
    align-items: center;
    justify-content: center;
    padding: 16px;
}
.capea-profile-modal-overlay.is-open { display: flex; }
.capea-profile-modal {
    background: #fff;
    border-radius: 18px;
    width: min(520px, 100%);
    max-height: 90vh;
    overflow-y: auto;
    position: relative;
    box-shadow: 0 24px 80px rgba(0,0,0,0.28);
    padding: 36px 32px 28px;
    scrollbar-width: thin;
    scrollbar-color: #b2e4d8 #f4fdf9;
}
.capea-profile-modal-close {
    position: absolute;
    top: 14px;
    right: 16px;
    background: rgba(0,0,0,0.07);
    border: none;
    border-radius: 50%;
    width: 34px;
    height: 34px;
    font-size: 1.25rem;
    line-height: 1;
    cursor: pointer;
    color: #444;
    transition: background .2s;
}
.capea-profile-modal-close:hover { background: rgba(0,0,0,0.15); }
.capea-profile-modal-title {
    font-size: 1.4rem !important;
    font-weight: 800 !important;
    color: #2b2b2b !important;
    margin: 0 0 24px !important;
    font-family: var(--wp--preset--font-family--headline, sans-serif);
}
.capea-profile-form { display: flex; flex-direction: column; gap: 18px; }
.capea-profile-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.capea-profile-field { display: flex; flex-direction: column; gap: 5px; }
.capea-profile-field label { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; color: #555; }
.capea-profile-field input,
.capea-profile-field textarea {
    border: 1.5px solid #d4e8e0;
    border-radius: 8px;
    padding: 10px 12px;
    font-size: 0.95rem;
    font-family: inherit;
    color: #2b2b2b;
    background: #f8fefc;
    transition: border-color .2s;
    width: 100%;
    box-sizing: border-box;
}
.capea-profile-field input:focus,
.capea-profile-field textarea:focus { border-color: var(--clr-primary-dark, #006c50); outline: none; background: #fff; }
.capea-profile-field input[readonly] { background: #f0f0f0; color: #888; cursor: not-allowed; }
.capea-profile-field small { font-size: 0.75rem; color: #888; }
.capea-profile-field textarea { resize: vertical; min-height: 72px; }
.capea-profile-msg { border-radius: 8px; padding: 10px 14px; font-size: 0.875rem; font-weight: 600; }
.capea-profile-msg-ok  { background: #e6f7f0; color: var(--clr-primary-dark, #006c50); }
.capea-profile-msg-err { background: #fef2f2; color: #c0392b; }
.capea-profile-actions { display: flex; gap: 12px; justify-content: flex-end; padding-top: 4px; }
.capea-profile-save-btn {
    background: var(--clr-primary-dark, #006c50);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 10px 24px;
    font-size: 0.9rem;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    transition: background .2s;
}
.capea-profile-save-btn:hover { background: #004d38; }
.capea-profile-save-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.capea-profile-cancel-btn {
    background: none;
    border: 1.5px solid #d4e8e0;
    border-radius: 8px;
    padding: 10px 20px;
    font-size: 0.9rem;
    font-weight: 600;
    color: #555;
    cursor: pointer;
    font-family: inherit;
    transition: all .2s;
}
.capea-profile-cancel-btn:hover { border-color: #888; color: #333; }
.capea-profile-field select {
    border: 1.5px solid #d4e8e0;
    border-radius: 8px;
    padding: 10px 32px 10px 12px;
    font-size: 0.95rem;
    font-family: inherit;
    color: #2b2b2b;
    background: #f8fefc url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24'%3E%3Cpath fill='%23006c50' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E") no-repeat right 10px center;
    transition: border-color .2s;
    width: 100%;
    box-sizing: border-box;
    appearance: none;
    cursor: pointer;
}
.capea-profile-field select:focus { border-color: var(--clr-primary-dark, #006c50); outline: none; background-color: #fff; }
.capea-profile-check-field { gap: 6px !important; }
.capea-profile-check-label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    cursor: pointer;
    font-size: 0.95rem !important;
    font-weight: 400 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    color: #2b2b2b;
}
.capea-profile-check-label input[type="checkbox"] {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    margin-top: 2px;
    accent-color: var(--clr-primary-dark, #006c50);
    cursor: pointer;
    border: none;
    background: none;
    padding: 0;
    box-sizing: border-box;
}
@media (max-width: 480px) {
    .capea-profile-field-row { grid-template-columns: 1fr; }
    .capea-profile-modal { padding: 28px 20px 20px; }
    .capea-profile-actions { flex-direction: column-reverse; }
}

/* ── Dashboard hero rows (stacked, reuse page-hero CSS) ─────────────── */
.dash-heroes-wrap { display: flex; flex-direction: column; gap: 40px; }
.dash-heroes-wrap .ev-hero,
.dash-heroes-wrap .wb-hero,
.dash-heroes-wrap .jl-featured { margin-bottom: 0 !important; margin-top: 0 !important; border-radius: 16px; box-shadow: 0 8px 32px rgba(0,0,0,0.22), 0 2px 8px rgba(0,0,0,0.12); }
.dash-heroes-wrap .jl-featured { background: linear-gradient(135deg, #c98b0c, #9b6700) !important; }
/* White outline secondary button used in dashboard hero rows */
.dash-hero-outline-btn {
    background: transparent !important;
    color: #fff !important;
    border: 2px solid rgba(255,255,255,0.7) !important;
    box-shadow: none !important;
}
.dash-hero-outline-btn:hover {
    background: rgba(255,255,255,0.12) !important;
    border-color: #fff !important;
    color: #fff !important;
}
/* Webinar hero placeholder when no video/thumbnail */
.wb-hero-thumb-ph { width: 100%; aspect-ratio: 16/9; background: rgba(255,255,255,.12); border-radius: 14px; }

/* ── Meetings & Reports Page ─────────────────────── */
.capea-meetings-intro {
    padding-top: var(--wp--preset--spacing--8);
    padding-bottom: var(--wp--preset--spacing--5);
}
.capea-intro-lead {
    max-width: 700px;
    margin: 0 auto;
    color: var(--wp--preset--color--on-surface-variant);
    font-size: 1.05rem;
    line-height: 1.65;
}

.capea-reports-layout {
    padding-top: var(--wp--preset--spacing--5) !important;
    padding-bottom: var(--wp--preset--spacing--10) !important;
}

.capea-year-section {
    background: #fff;
    border-radius: 12px;
    padding: 32px 36px;
    margin-bottom: 16px;
    box-shadow: 0 2px 16px rgba(0,0,0,.07);
}
.capea-year-featured {
    border-left: 4px solid var(--wp--preset--color--primary-dark);
}
.capea-year-title {
    font-size: 1.5rem !important;
    margin-block-start: 0 !important;
    margin-bottom: 8px !important;
    color: var(--wp--preset--color--primary-dark) !important;
}
.capea-meeting-date {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--wp--preset--color--primary-dark);
    background: rgba(0,108,80,.1);
    padding: 4px 14px;
    border-radius: 20px;
    margin-block-start: 0 !important;
    margin-bottom: 24px !important;
}
.capea-meeting-date::before {
    font-family: 'Material Symbols Outlined';
    content: 'calendar_today';
    font-size: 0.85em;
    font-variation-settings: 'FILL' 0, 'wght' 500;
}
.capea-year-watermark {
    font-family: var(--font-hed);
    font-size: 5rem !important;
    font-weight: 900 !important;
    color: var(--wp--preset--color--primary) !important;
    opacity: 0.12;
    line-height: 1 !important;
    margin-block-start: 0 !important;
    letter-spacing: -2px;
    pointer-events: none;
    user-select: none;
}

.capea-doc-category-label {
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    color: var(--wp--preset--color--primary-dark) !important;
    margin-block-start: 24px !important;
    margin-bottom: 6px !important;
    padding-bottom: 6px;
    border-bottom: 1px solid rgba(0,108,80,.2);
}
.capea-year-section > .capea-doc-category-label:first-of-type,
.capea-year-accordion-body > .capea-doc-category-label:first-of-type {
    margin-block-start: 0 !important;
}

.capea-doc-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 4px 0 !important;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 6px;
}
.capea-doc-list li {
    margin: 0 !important;
    padding: 0 !important;
}
.capea-doc-list li::before { display: none !important; }
.capea-doc-list li a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 5px;
    background: var(--wp--preset--color--surface);
    border: 1px solid rgba(0,108,80,.12);
    color: var(--wp--preset--color--on-background);
    text-decoration: none !important;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.3;
    transition: background 0.15s, color 0.15s, box-shadow 0.15s, transform 0.15s, border-color 0.15s;
}
.capea-doc-list li a:hover {
    background: var(--wp--preset--color--primary-dark);
    color: rgba(255,255,255,.96) !important;
    border-color: transparent;
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(0,108,80,.22);
}
.capea-doc-list li a::before {
    font-family: 'Material Symbols Outlined';
    font-size: 1.1rem;
    flex-shrink: 0;
    color: #555;
    font-variation-settings: 'FILL' 0, 'wght' 400;
    content: 'description';
}
.capea-doc-list li a[href$=".pdf"]::before  { content: 'picture_as_pdf'; color: #c62828; }
.capea-doc-list li a[href$=".docx"]::before,
.capea-doc-list li a[href$=".doc"]::before  { content: 'article'; color: #1565c0; }
.capea-doc-list li a[href$=".xlsx"]::before,
.capea-doc-list li a[href$=".xls"]::before  { content: 'table_chart'; color: #2e7d32; }
.capea-doc-list li a[href$=".pptx"]::before,
.capea-doc-list li a[href$=".ppt"]::before  { content: 'slideshow'; color: #e65100; }
.capea-doc-list li a::after {
    font-family: 'Material Symbols Outlined';
    content: 'download';
    margin-left: auto;
    flex-shrink: 0;
    font-size: 1rem;
    opacity: 0.25;
    transition: opacity 0.15s;
}
.capea-doc-list li a:hover::before { color: rgba(255,255,255,.85) !important; }
.capea-doc-list li a:hover::after  { opacity: 0.6; }

.capea-prev-years-header {
    padding-top: var(--wp--preset--spacing--5) !important;
    padding-bottom: var(--wp--preset--spacing--2) !important;
}
.capea-archive-heading {
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    color: var(--wp--preset--color--on-surface-variant) !important;
    margin: 0 !important;
}

.capea-year-accordion {
    border: 1px solid rgba(0,108,80,.15);
    border-radius: 12px;
    margin-bottom: 10px;
    overflow: hidden;
}
.capea-year-accordion > summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 17px 24px;
    cursor: pointer;
    background: var(--wp--preset--color--surface);
    font-family: var(--font-hed);
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--wp--preset--color--primary-dark);
    list-style: none;
    user-select: none;
    transition: background 0.15s;
}
.capea-year-accordion > summary::-webkit-details-marker { display: none; }
.capea-year-accordion > summary::after {
    font-family: 'Material Symbols Outlined';
    content: 'expand_more';
    font-size: 1.25rem;
    flex-shrink: 0;
    transition: transform 0.2s;
    font-variation-settings: 'FILL' 0, 'wght' 500;
}
.capea-year-accordion[open] > summary { background: rgba(0,108,80,.06); }
.capea-year-accordion[open] > summary::after { transform: rotate(180deg); }
.capea-year-accordion > summary:hover { background: rgba(0,108,80,.08); }

.capea-year-accordion-body {
    padding: 24px 28px !important;
    border-top: 1px solid rgba(0,108,80,.1);
    background: #fff;
}

.capea-meetings-stat-strip,
.capea-meetings-contact {
    border-radius: 5px;
    overflow: hidden;
}
.capea-meetings-contact {
    text-align: center;
    padding-top: var(--wp--preset--spacing--6) !important;
    padding-bottom: var(--wp--preset--spacing--6) !important;
}
.capea-meetings-contact h3 {
    margin-block-start: 0 !important;
    font-size: 1.2rem !important;
}
.capea-meetings-contact p { margin-block-start: 8px !important; }
.capea-meetings-contact a { color: rgba(255,255,255,.9) !important; text-decoration: underline; }
.capea-meetings-contact a:hover { color: #fff !important; }

/* ── Scholarships Bento Page ─────────────────────── */
.capea-schol-page-section {
    padding-top: var(--wp--preset--spacing--8) !important;
    padding-bottom: var(--wp--preset--spacing--10) !important;
}

.wp-block-group.capea-bento-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.capea-bento-card {
    border-radius: 16px !important;
    padding: 28px 30px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px;
}

.capea-bento-wide { grid-column: span 2; }

/* Card colour themes */
.capea-schol-dark     { background: #3d1a5c !important; }
.capea-schol-brand    { background: #774b98 !important; }
.capea-schol-light    { background: #f3e8ff !important; }
.capea-schol-lavender { background: #ede0ff !important; }
.capea-schol-teal     { background: var(--wp--preset--color--primary-dark) !important; }

/* Text colours */
.capea-schol-dark *,
.capea-schol-brand *,
.capea-schol-teal * { color: rgba(255,255,255,.95) !important; }

.capea-schol-light *,
.capea-schol-lavender * { color: #3d1a5c !important; }

/* Icon */
.capea-bento-icon {
    font-family: 'Material Symbols Outlined' !important;
    font-variation-settings: 'FILL' 1, 'wght' 300;
    font-size: 2.25rem !important;
    line-height: 1 !important;
    margin-block-start: 0 !important;
    opacity: 0.8;
}

/* Headings inside cards */
.capea-bento-card .wp-block-heading, .capea-schol-cta .wp-block-heading {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    margin-block-start: 0 !important;
    margin-bottom: 2px !important;
    line-height: 1.3 !important;
}

/* Body text inside cards */
.capea-bento-card p:not(.capea-bento-icon):not(.capea-bento-stat):not(.capea-bento-stat-label) {
    font-size: 0.875rem !important;
    line-height: 1.6 !important;
    margin-block-start: 0 !important;
    opacity: 0.9;
}

/* List inside cards */
.capea-bento-card .wp-block-list {
    margin-block-start: 0 !important;
    padding-left: 1.3em !important;
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.capea-bento-card .wp-block-list li {
    font-size: 0.875rem !important;
    margin: 0 !important;
    line-height: 1.45 !important;
}

/* Big stat number */
.capea-bento-stat {
    font-family: var(--font-hed) !important;
    font-size: 3rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    margin-block-start: 0 !important;
    letter-spacing: -1px;
}
.capea-bento-stat-label {
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    margin-block-start: 0 !important;
    opacity: 0.65 !important;
}

/* Purple CTA footer */
.capea-schol-cta {
    text-align: center;
    padding-top: var(--wp--preset--spacing--6) !important;
    padding-bottom: var(--wp--preset--spacing--6) !important;
    border-radius: 5px;
    overflow: hidden;
}
.capea-schol-cta h3 {
    margin-block-start: 0 !important;
    font-size: 1.2rem !important;
}
.capea-schol-cta p { margin-block-start: 8px !important; font-size: 0.95rem !important; }
.capea-schol-cta a { color: rgba(255,255,255,.9) !important; text-decoration: underline; }
.capea-schol-cta a:hover { color: #fff !important; }

/* Responsive: collapse bento to single column on mobile */
@media (max-width: 767px) {
    .wp-block-group.capea-bento-grid {
        grid-template-columns: 1fr !important;
    }
    .capea-bento-wide { grid-column: span 1 !important; }
}

/* ── Journal Archive (capea_journal CPT shortcode) ─────────────────── */

.jl-wrap { font-family: Roboto, sans-serif; max-width: 1200px; margin: 0 auto; padding: 0 20px 40px; color: var(--clr-text); }

/* Featured latest issue */
.jl-featured { background: linear-gradient(135deg,#9b6bbf,#774b98); border-radius: 12px; padding: 30px; margin-top: 28px; margin-bottom: 30px; display: flex; gap: 30px; align-items: flex-start; color: #fff; }
.jl-featured-img { flex-shrink: 0; width: 140px; }
.jl-featured-img img { width: 140px; border-radius: 8px; box-shadow: 0 8px 24px rgba(0,0,0,.3); display: block; }
.jl-featured-badge { display: inline-block; background: rgba(255,255,255,.25); border: 2px solid rgba(255,255,255,.6); border-radius: 20px; padding: 4px 14px; font-size: .8rem; font-weight: 700; letter-spacing: 1px; margin-bottom: 12px; text-transform: uppercase; }
.jl-featured-content h2 { font-size: 1.6rem; font-weight: 700; margin: 0 0 8px; color: #fff !important; }
.jl-featured-content .jl-meta { font-size: .9rem; opacity: .85; margin-bottom: 12px; }
.jl-featured-focus { background: rgba(255,255,255,.2); border-radius: 8px; padding: 10px 16px; margin-bottom: 12px; font-size: .95rem; }

/* Section header row with add button */
.jl-section-header { display: flex; align-items: center; gap: 12px; margin-bottom: 0; }
.jl-section-title { font-size: 1.4rem; font-weight: 700; color: var(--clr-primary-dark) !important; margin: 30px 0 6px; padding-bottom: 8px; border-bottom: 3px solid var(--clr-primary-dark); flex: 1; }
.jl-section-title + * { margin-top: 30px; }
.jl-section-header .jl-section-title { margin-bottom: 0; }
.jl-int-title { font-size: 1.3rem; font-weight: 700; color: #5b3fa0 !important; margin: 0 0 6px; flex: 1; }
.jl-section-sub { color: var(--clr-muted); font-size: .9rem; margin-bottom: 20px; }
.jl-int-sub { color: var(--clr-muted); font-size: .9rem; margin-bottom: 20px; }

/* Volume filter */
.jl-filter { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; }
.jl-filter-btn { background: #f0f0f0; border: 2px solid transparent; border-radius: 20px; padding: 6px 16px; font-size: .85rem; cursor: pointer; transition: all .2s; font-weight: 600; color: var(--clr-muted); }
.jl-filter-btn:hover { border-color: var(--clr-primary-dark); color: var(--clr-primary-dark); }
.jl-filter-btn.active { background: var(--clr-primary-dark); color: #fff; border-color: var(--clr-primary-dark); }

/* IJBPE grid — max 4 columns, equal card heights */
.jl-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-bottom: 30px; }
.jl-card-wrap { position: relative; display: flex; flex-direction: column; }
.jl-card { background: #fff; border-radius: 10px; box-shadow: 0 2px 10px rgba(0,0,0,.1); overflow: hidden; transition: transform .2s, box-shadow .2s; text-decoration: none !important; display: flex; flex-direction: column; flex: 1; }
.jl-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,.18); }
.jl-card-img { width: 100%; aspect-ratio: 3/4; object-fit: cover; display: block; background: #e8f5f6; }
.jl-card-body { padding: 12px; flex: 1; display: flex; flex-direction: column; }
.jl-card-vol { font-size: .75rem; font-weight: 700; color: var(--clr-primary-dark); text-transform: uppercase; letter-spacing: .5px; margin-block-start: 0; }
.jl-card-date { font-size: .8rem; color: #888; margin-bottom: 6px; margin-block-start: 0; }
.jl-card-focus { font-size: .85rem; font-weight: 600; color: var(--clr-text); margin-bottom: 8px; line-height: 1.3; flex: 1; margin-block-start: 0; }
.jl-card-btn { display: block; text-align: center; background: var(--clr-primary-dark); color: #fff !important; border-radius: 6px; padding: 7px; font-size: .8rem; font-weight: 700; text-decoration: none !important; margin-top: auto; transition: background .2s; }
.jl-card:hover .jl-card-btn { background: #005040; }

/* Interaction Journal section */
.jl-int-section { background: #f5f0fb; border-radius: 12px; padding: 24px 30px; margin-top: 10px; }
.jl-int-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap: 16px; }
.jl-int-card-wrap { position: relative; }
.jl-int-card { background: #fff; border-radius: 10px; padding: 16px; box-shadow: 0 2px 8px rgba(91,63,160,.12); display: flex; justify-content: space-between; align-items: center; text-decoration: none !important; transition: transform .2s, box-shadow .2s; }
.jl-int-card:hover { transform: translateY(-3px); box-shadow: 0 6px 16px rgba(91,63,160,.2); }
.jl-int-card-info .vol { font-size: .8rem; font-weight: 700; color: #5b3fa0; display: block; }
.jl-int-card-info .date { font-size: .9rem; font-weight: 600; color: var(--clr-text); display: block; }
.jl-int-card-arrow { color: #5b3fa0; font-size: 1.2rem; }

/* Action buttons (btn styles shared with jl-featured) */
.jl-btn { display: inline-block; padding: 11px 28px; border-radius: 25px; font-size: .95rem; font-weight: 700; text-decoration: none !important; cursor: pointer; transition: all .2s; }
.jl-btn-white { background: #fff; color: #774b98 !important; border: none; }
.jl-btn-white:hover { background: #f5f5f5; transform: translateY(-2px); }

/* Admin-only controls */
.capea-jl-add-btn {
    background: var(--clr-primary-dark);
    color: #fff;
    border: none;
    border-radius: 16px;
    padding: 4px 14px;
    font-size: .8rem;
    font-weight: 700;
    cursor: pointer;
    flex-shrink: 0;
    align-self: flex-end;
    margin-bottom: 6px;
    transition: background .2s;
}
.capea-jl-add-btn:hover { background: #005040; }
.capea-jl-edit-btn {
    position: absolute;
    top: 6px;
    right: 6px;
    background: rgba(0,0,0,.65);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 4px 9px;
    font-size: .75rem;
    cursor: pointer;
    opacity: 0;
    transition: opacity .2s;
    z-index: 2;
    white-space: nowrap;
}
.jl-card-wrap:hover .capea-jl-edit-btn,
.jl-int-card-wrap:hover .capea-jl-edit-btn { opacity: 1; }
.jl-featured .capea-jl-edit-btn {
    position: static;
    opacity: 1;
    margin-left: 12px;
    background: rgba(255,255,255,.25);
    border: 2px solid rgba(255,255,255,.6);
    font-size: .85rem;
    padding: 8px 16px;
    border-radius: 20px;
    margin-top: 10px;
}
.jl-featured .capea-jl-edit-btn:hover { background: rgba(255,255,255,.4); }

/* Admin modal */
.capea-jl-modal {
    background: #fff;
    border-radius: 16px;
    padding: 32px;
    width: 100%;
    max-width: 520px;
    max-height: 90vh;
    overflow-y: auto;
    position: relative;
    box-shadow: 0 24px 80px rgba(0,0,0,.35);
}
.capea-jl-modal h3 { margin: 0 0 20px; font-size: 1.3rem; color: var(--clr-primary-dark); }
.capea-jl-row { display: flex; flex-direction: column; gap: 4px; margin-bottom: 14px; }
.capea-jl-row label { font-size: .8rem; font-weight: 700; color: #555; text-transform: uppercase; letter-spacing: .5px; }
.capea-jl-row input[type="text"],
.capea-jl-row input[type="number"],
.capea-jl-row select { width: 100%; border: 1.5px solid #ddd; border-radius: 8px; padding: 8px 12px; font-size: .95rem; color: var(--clr-text); outline: none; transition: border-color .2s; box-sizing: border-box; }
.capea-jl-row input:focus,
.capea-jl-row select:focus { border-color: var(--clr-primary-dark); }
.capea-jl-inline { display: flex; gap: 8px; align-items: center; }
.capea-jl-inline input[type="number"] { width: 80px !important; }
.capea-jl-inline input[type="text"] { flex: 1; }

/* Media pickers (image + PDF) */
.capea-jl-media-pick {
    border: 2px dashed #ccc;
    border-radius: 10px;
    cursor: pointer;
    transition: border-color .2s, background .2s;
    overflow: hidden;
    min-height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.capea-jl-media-pick:hover { border-color: var(--clr-primary-dark); background: #f5fdfb; }
.capea-jl-media-ph { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 16px; color: #888; font-size: .9rem; }
.capea-jl-media-ph span:first-child { font-size: 1.8rem; }
.capea-jl-media-pick img { width: 100%; max-height: 160px; object-fit: contain; display: block; padding: 8px; box-sizing: border-box; }
.capea-jl-pdf-pick { min-height: 60px; }
.capea-jl-pdf-selected { display: flex; align-items: center; gap: 8px; padding: 12px 16px; font-size: .9rem; font-weight: 600; color: var(--clr-primary-dark); word-break: break-all; }
.capea-jl-actions { display: flex; gap: 10px; margin-top: 20px; }
.capea-jl-save-btn { background: var(--clr-primary-dark); color: #fff; border: none; border-radius: 8px; padding: 10px 24px; font-size: .95rem; font-weight: 700; cursor: pointer; transition: background .2s; }
.capea-jl-save-btn:hover { background: #005040; }
.capea-jl-cancel-btn { background: #f0f0f0; color: #555; border: none; border-radius: 8px; padding: 10px 20px; font-size: .95rem; font-weight: 600; cursor: pointer; transition: background .2s; }
.capea-jl-cancel-btn:hover { background: #e4e4e4; }
.capea-jl-delete-btn { background: #fee2e2; color: #b91c1c; border: none; border-radius: 8px; padding: 10px 20px; font-size: .95rem; font-weight: 700; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: background .2s; }
.capea-jl-delete-btn:hover { background: #fca5a5; }

/* Responsive */
@media (max-width: 960px) {
    .jl-grid { grid-template-columns: repeat(3,1fr); }
}
@media (max-width: 640px) {
    .jl-grid { grid-template-columns: repeat(2,1fr); }
    .jl-featured { flex-direction: column; }
    .jl-featured-img { width: 100%; text-align: center; }
    .jl-featured-img img { width: 120px; margin: 0 auto; }
}
@media (max-width: 380px) {
    .jl-grid { grid-template-columns: 1fr; }
}

/* ── Journal scorecard (dashboard widget) ───────────────────────────── */
.capea-jl-scorecard {
    display: flex;
    align-items: center;
    gap: 20px;
    background: linear-gradient(135deg, var(--clr-primary-dark), #005040);
    color: #fff;
    border-radius: 14px;
    padding: 20px 28px;
    margin: 0 auto 24px;
    max-width: 480px;
}
.capea-jl-sc-icon { font-size: 2.4rem; flex-shrink: 0; }
.capea-jl-sc-body { flex: 1; }
.capea-jl-sc-label { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; opacity: .8; margin-bottom: 4px; }
.capea-jl-sc-counts { font-size: 1.8rem; font-weight: 700; line-height: 1; margin-bottom: 8px; }
.capea-jl-sc-seen { color: #fff; }
.capea-jl-sc-sep { font-size: 1rem; opacity: .7; margin: 0 4px; }
.capea-jl-sc-total { font-size: 1rem; opacity: .7; }
.capea-jl-sc-bar-wrap { background: rgba(255,255,255,.25); border-radius: 99px; height: 6px; margin-bottom: 6px; overflow: hidden; }
.capea-jl-sc-bar { height: 100%; background: #fff; border-radius: 99px; transition: width .4s ease; min-width: 2px; }
.capea-jl-sc-sub { font-size: .8rem; opacity: .8; }
.capea-jl-sc-sub a { color: #fff; font-weight: 700; }

/* ── Webinar Archive ─────────────────────────────────────────────── */
.wb-wrap { max-width: 1280px; margin: 0 auto; padding: 40px 20px; }
.wb-section-header { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; margin-bottom: 8px; }
.wb-section-title { font-size: 1.5rem; font-weight: 700; color: var(--wp--preset--color--primary-dark, #006c50); margin: 0; }
.wb-section-sub { color: #4a4a4a; margin: 0 0 24px; line-height: 1.6; font-size: .95rem; }
.wb-section-sub a { color: #006c50; font-weight: 600; }

/* Filter buttons */
.wb-filter { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; }
.wb-filter-btn { background: #fff; border: 1.5px solid #c9a8e8; border-radius: 20px; padding: 6px 16px; font-size: .82rem; cursor: pointer; transition: background .15s, color .15s, border-color .15s; color: #774b98; font-family: inherit; font-weight: 600; }
.wb-filter-btn.active, .wb-filter-btn:hover { background: #774b98; color: #fff; border-color: #774b98; }

/* Member webinars grid */
.wb-members-section { margin-bottom: 48px; background: #f8f0ff; padding: 64px 0 40px; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
.wb-members-section > * { max-width: 1280px; margin-left: auto; margin-right: auto; padding-left: 28px; padding-right: 28px; }
.wb-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: 8px; }
@media (max-width: 960px) { .wb-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) { .wb-grid { grid-template-columns: 1fr; } }

/* Webinar card */
.wb-card-wrap { position: relative; }
.wb-card { display: flex; flex-direction: column; background: #fff; border-radius: 12px; box-shadow: 0 6px 20px rgba(0,0,0,.12); overflow: hidden; text-decoration: none; color: inherit; transition: transform .2s, box-shadow .2s; height: 100%; }
.wb-card:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(0,0,0,.18); }
.wb-card-thumb { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; }
.wb-card-thumb-ph { width: 100%; aspect-ratio: 16/9; background: #e8f5f0; display: flex; align-items: center; justify-content: center; font-size: 2rem; }
.wb-card-body { padding: 16px; display: flex; flex-direction: column; flex: 1; }
.wb-card-badge { display: inline-block; background: #774b98; color: #fff; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; padding: 3px 9px; border-radius: 20px; margin-bottom: 10px; align-self: flex-start; }
.wb-card-badge.wb-badge-public { background: #43b790; }
.wb-card-badge.wb-badge-purchased { background: #c8860a; }
.wb-card-title { font-size: 1rem; font-weight: 700; color: #2d1a45; margin: 0 0 6px; line-height: 1.4; flex: 1; }
.wb-card-presenter { font-size: .82rem; font-weight: 500; color: #006c50; margin: 0 0 8px; }
.wb-card-meta { font-size: .75rem; color: #888; margin: 0 0 12px; }
.wb-card-btn { display: inline-flex; align-items: center; gap: 4px; font-size: .85rem; color: #006c50; font-weight: 700; margin-top: auto; }
.wb-card-btn::after { content: ' →'; }

/* Admin edit overlay button */
.wb-card-has-edit { }
.wb-edit-btn { position: absolute; top: 8px; right: 8px; background: rgba(0,0,0,.55); color: #fff; border: none; border-radius: 4px; padding: 4px 10px; font-size: .75rem; cursor: pointer; z-index: 2; transition: background .15s; }
.wb-edit-btn:hover { background: rgba(0,0,0,.8); }
.wb-add-btn { background: #006c50; color: #fff; border: none; border-radius: 6px; padding: 8px 18px; font-size: .88rem; cursor: pointer; font-family: inherit; font-weight: 600; transition: background .15s; }
.wb-add-btn:hover { background: #005a42; }
.wb-add-btn-light { background: rgba(255,255,255,.2); }
.wb-add-btn-light:hover { background: rgba(255,255,255,.35); }

/* Purchased webinars section */
.wb-purchased-section { background: linear-gradient(135deg,#f0faf5,#e8f8f0); border-radius: 16px; padding: 32px 28px 28px; margin-bottom: 48px; border: 2px solid #43b790; }
.wb-purchased-section .wb-section-title { color: #005a42; }

/* Shop preview section */
.wb-shop-section { background: #006c50; border-radius: 16px; padding: 40px 32px; margin-bottom: 40px; }
.wb-shop-section .wb-section-title { color: #fff; }
.wb-shop-section .wb-section-sub { color: rgba(255,255,255,.85); }
.wb-shop-section .wb-section-sub a { color: #a8f0d8; }
.wb-shop-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 28px; }
@media (max-width: 960px) { .wb-shop-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .wb-shop-grid { grid-template-columns: 1fr; } }
.wb-shop-card-wrap { position: relative; }
.wb-shop-card { display: flex; flex-direction: column; background: rgba(255,255,255,.12); border-radius: 10px; overflow: hidden; text-decoration: none; color: #fff; transition: background .2s, transform .2s; height: 100%; }
.wb-shop-card:hover { background: rgba(255,255,255,.2); transform: translateY(-2px); }
.wb-shop-card-thumb { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; }
.wb-shop-card-thumb-ph { width: 100%; aspect-ratio: 16/9; background: rgba(255,255,255,.1); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; }
.wb-shop-card-body { padding: 12px; flex: 1; display: flex; flex-direction: column; }
.wb-shop-card-presenter { font-size: .82rem; font-weight: 700; margin: 0 0 4px; color: rgba(255,255,255,.95); }
.wb-shop-card-title { font-size: .75rem; color: rgba(255,255,255,.75); margin: 0 0 8px; line-height: 1.35; flex: 1; }
.wb-shop-card-price { font-size: .88rem; color: #a8f0d8; font-weight: 700; margin: 0; }
.wb-shop-cta { text-align: center; margin-top: 8px; }
.wb-browse-btn { display: inline-flex; align-items: center; gap: 6px; background: #fff; color: #006c50; font-weight: 700; padding: 13px 32px; border-radius: 8px; text-decoration: none; font-size: 1rem; transition: background .2s, transform .2s; }
.wb-browse-btn:hover { background: #effcf6; transform: translateY(-1px); }

/* Modal extra actions row */
.wb-modal-extra-actions { display: none; flex-wrap: wrap; gap: 10px; margin-top: 14px; padding-top: 14px; border-top: 1px solid #e0e0e0; }
.wb-newsletter-btn { background: #774b98; color: #fff; border: none; border-radius: 6px; padding: 8px 16px; font-size: .88rem; cursor: pointer; font-family: inherit; font-weight: 600; transition: background .15s; }
.wb-newsletter-btn:hover { background: #5e3a7a; }
.wb-convert-btn { background: #c8860a; color: #fff; border: none; border-radius: 6px; padding: 8px 16px; font-size: .88rem; cursor: pointer; font-family: inherit; font-weight: 600; transition: background .15s; }
.wb-convert-btn:hover { background: #a36d07; }
.wb-shop-fields { background: #f9f9f9; border-radius: 8px; padding: 14px 16px; margin-top: 8px; border: 1px solid #e8e8e8; }
.wb-shop-fields-label { font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: #888; margin: 0 0 10px; }
.capea-jl-inline-row { display: flex; gap: 12px; }
@media (max-width: 500px) { .capea-jl-inline-row { flex-direction: column; } }

/* Modal textarea */
.capea-wb-modal textarea { width: 100%; min-height: 70px; padding: 8px 10px; border: 1px solid #d0d0d0; border-radius: 6px; font-size: .9rem; font-family: inherit; resize: vertical; box-sizing: border-box; }
.capea-wb-modal { background: #fff; border-radius: 16px; padding: 28px 28px 24px; width: min(640px,96vw); max-height: 90vh; overflow-y: auto; position: relative; }

/* ── Webinar Hero ────────────────────────────────────────────────── */
.wb-hero { background: #774b98; padding: 56px 20px 48px; margin-bottom: 40px; border-radius: 5px; }
.wb-hero-inner { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1.1fr 1fr; gap: 48px; align-items: center; }
@media (max-width: 800px) { .wb-hero-inner { grid-template-columns: 1fr; } }

/* Hero video thumbnail */
.wb-hero-media { position: relative; }
.wb-hero-thumb { width: 100%; border-radius: 14px; overflow: hidden; box-shadow: 0 8px 32px rgba(0,0,0,.35); display: block; }
.wb-hero-thumb img { width: 100%; display: block; aspect-ratio: 16/9; object-fit: cover; }
.wb-hero-play { width: 72px !important; height: 72px !important; }

/* When capea-video-thumb-wrap is the hero thumb */
.wb-hero-media .capea-video-thumb-wrap.wb-hero-thumb { cursor: pointer; }
.wb-hero-media .capea-video-thumb-wrap.wb-hero-thumb img { border-radius: 14px; }
.wb-hero-media .wb-edit-btn { top: 12px; right: 12px; z-index: 3; }

/* Hero content */
.wb-hero-content { color: #fff; }
.wb-hero-new-badge { display: inline-block; background: rgba(255,255,255,.18); color: #fff; font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; padding: 4px 12px; border-radius: 20px; margin: 0 0 14px; line-height: 1.4; font-family: inherit; }
.wb-hero-category { color: #daa8fd; font-size: .88rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; margin: 0 0 8px; }
.wb-hero-presenter { font-size: 2rem; font-weight: 700; color: #fff; margin: 0 0 8px; line-height: 1.2; font-family: var(--wp--preset--font-family--headline, sans-serif); }
@media (max-width: 800px) { .wb-hero-presenter { font-size: 1.5rem; } }
.wb-hero-title { font-size: 1rem; color: rgba(255,255,255,.85); margin: 0 0 10px; line-height: 1.5; }
.wb-hero-meta { font-size: .82rem; color: rgba(255,255,255,.6); margin: 0 0 16px; }
.wb-hero-desc { font-size: .95rem; color: rgba(255,255,255,.82); margin: 0 0 24px; line-height: 1.65; }

/* Hero watch button */
.wb-hero-watch-wrap { display: inline-block; cursor: pointer; }
.wb-hero-watch-btn { display: inline-flex; align-items: center; gap: 8px; background: #fff; color: #774b98; font-weight: 700; padding: 13px 28px; border-radius: 8px; text-decoration: none; font-size: 1rem; transition: background .2s, transform .2s; border: none; cursor: pointer; font-family: inherit; letter-spacing: .01em; }
.wb-hero-watch-btn:hover, .wb-hero-watch-wrap:hover .wb-hero-watch-btn { background: #f3e8ff; transform: translateY(-1px); }

/* Webinar card as block (non-link wrapper) */
.wb-card-thumb-wrap { width: 100%; aspect-ratio: 16/9; overflow: hidden; display: block; cursor: pointer; }
.wb-card-thumb-wrap img, .wb-card-thumb-wrap .wb-card-thumb { width: 100%; height: 100%; object-fit: cover; display: block; }
.wb-card-thumb-wrap.capea-video-thumb-wrap { aspect-ratio: 16/9; }
.wb-card-thumb-wrap.capea-video-thumb-wrap img { aspect-ratio: unset; height: 100%; }

/* ── Event Archive (capea_event CPT shortcode) ───────────────────────── */
.ev-wrap { max-width: 1280px; margin: 0 auto; padding: 32px 0 40px; }

/* Hero */
.ev-hero { background: linear-gradient(135deg,#008060,#006c50); border-radius: 12px; padding: 36px 32px; margin-bottom: 40px; color: #fff; }
.ev-hero-inner { display: grid; grid-template-columns: 320px 1fr; gap: 36px; align-items: center; }
.ev-hero-media { position: relative; }
.ev-hero-img { width: 100%; border-radius: 10px; box-shadow: 0 8px 28px rgba(0,0,0,.3); display: block; aspect-ratio: 4/3; object-fit: cover; }
.ev-hero-img-ph { width: 100%; aspect-ratio: 4/3; background: rgba(255,255,255,.12); border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.ev-hero-img-ph .card-icon { font-size: 4rem !important; color: rgba(255,255,255,.5) !important; margin: 0 !important; }
.ev-hero-badge { display: inline-block; background: rgba(255,255,255,.18); border: 1.5px solid rgba(255,255,255,.5); border-radius: 20px; padding: 4px 14px; font-size: .78rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; margin-bottom: 14px; }
.ev-hero-title { font-size: 1.9rem; font-weight: 700; color: #fff; margin: 0 0 12px; line-height: 1.2; font-family: var(--wp--preset--font-family--headline,sans-serif); }
@media (max-width: 800px) { .ev-hero-title { font-size: 1.4rem; } }
.ev-hero-meta { font-size: .9rem; color: rgba(255,255,255,.75); margin-bottom: 12px; display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
.ev-meta-sep { opacity: .5; }
.ev-cpd-badge { display: inline-block; background: rgba(255,255,255,.18); border: 1.5px solid rgba(255,255,255,.4); border-radius: 20px; padding: 4px 14px; font-size: .82rem; font-weight: 700; margin-bottom: 14px; }
.ev-hero-desc { font-size: .95rem; color: rgba(255,255,255,.88); margin-bottom: 24px; line-height: 1.65; white-space: pre-line; }

/* Hero edit button */
.ev-edit-btn { position: absolute; top: 8px; right: 8px; background: rgba(0,0,0,.55); color: #fff; border: none; border-radius: 6px; padding: 5px 10px; font-size: .78rem; cursor: pointer; z-index: 5; }
.ev-edit-btn:hover { background: rgba(0,0,0,.75); }

/* Buttons */
.ev-btn { display: inline-block; padding: 11px 28px; border-radius: 8px; font-size: .95rem; font-weight: 700; text-decoration: none !important; cursor: pointer; transition: all .2s; border: none; font-family: inherit; }
.ev-btn-white { background: #fff; color: #006c50 !important; }
.ev-btn-white:hover { background: #effcf6; transform: translateY(-2px); }
.ev-btn-teal { background: #006c50; color: #fff !important; }
.ev-btn-teal:hover { background: #005040; transform: translateY(-1px); }
.ev-btn-purple { background: #774b98; color: #fff !important; }
.ev-btn-purple:hover { background: #5f3a7a; transform: translateY(-1px); }
.ev-hero-btns { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 4px; }

/* Section header */
.ev-section { margin-bottom: 40px; }
.ev-section-header { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; flex-wrap: wrap; }
.ev-section-title { font-size: 1.4rem; font-weight: 700; color: var(--clr-primary-dark); margin: 0; }
.ev-add-btn { background: #006c50; color: #fff; border: none; border-radius: 20px; padding: 7px 18px; font-size: .82rem; font-weight: 700; cursor: pointer; transition: background .2s; font-family: inherit; }
.ev-add-btn:hover { background: #005040; }
.ev-empty { color: #666; font-size: .95rem; padding: 20px 0; }

/* Card grid */
.ev-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
@media (max-width: 960px) { .ev-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 580px) { .ev-grid { grid-template-columns: 1fr; } }
.ev-card { background: #fff; border-radius: 12px; box-shadow: 0 2px 12px rgba(0,0,0,.08); display: flex; flex-direction: column; overflow: hidden; transition: box-shadow .2s, transform .2s; }
.ev-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,.13); transform: translateY(-2px); }
.ev-card-past { opacity: .78; }
.ev-card-past:hover { opacity: 1; }
.ev-card-img-wrap { position: relative; aspect-ratio: 1/1; overflow: hidden; cursor: pointer; }
.ev-card-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ev-card-img-ph { width: 100%; height: 100%; background: #e8f5f0; display: flex; align-items: center; justify-content: center; }
.ev-card-img-ph .card-icon { font-size: 2.5rem !important; color: #006c50 !important; margin: 0 !important; }
.ev-card-date-pill { position: absolute; bottom: 8px; left: 8px; background: #774b98; color: #fff; font-size: .72rem; font-weight: 700; padding: 3px 10px; border-radius: 12px; letter-spacing: .02em; }
.ev-date-pill-past { background: #888; }
.ev-card-body { padding: 18px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.ev-card-title { font-size: 1rem; font-weight: 700; color: #1a1a2e; margin: 0; line-height: 1.35; }
.ev-card-loc { font-size: .82rem; color: #555; margin: 0; }
.ev-card-cpd { display: inline-block; background: #f0e6fa; color: #774b98; font-size: .75rem; font-weight: 700; padding: 2px 10px; border-radius: 10px; }
.ev-card-desc { font-size: .82rem; color: #666; margin: 0; line-height: 1.5; flex: 1; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.ev-card-actions { margin-top: auto; padding-top: 12px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

/* Past events accordion */
.ev-past-section { border-top: 2px solid #e8e8e8; padding-top: 32px; }
.ev-past-details { }
.ev-past-summary { font-size: 1rem; font-weight: 700; color: #555; cursor: pointer; padding: 10px 0; list-style: none; display: flex; align-items: center; gap: 8px; user-select: none; }
.ev-past-summary::before { content: '▶'; font-size: .65rem; transition: transform .2s; display: inline-block; }
.ev-past-details[open] .ev-past-summary::before { transform: rotate(90deg); }
.ev-past-summary::-webkit-details-marker { display: none; }
.ev-past-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 20px; }
@media (max-width: 960px) { .ev-past-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 580px) { .ev-past-grid { grid-template-columns: 1fr; } }

/* Responsive hero */
@media (max-width: 800px) {
    .ev-hero-inner { grid-template-columns: 1fr; }
    .ev-hero-media { max-width: 320px; margin: 0 auto; }
}

/* Admin modal */
.capea-ev-modal { background: #fff; border-radius: 16px; padding: 28px 28px 24px; width: min(600px,96vw); max-height: 90vh; overflow-y: auto; position: relative; box-shadow: 0 24px 80px rgba(0,0,0,.35); }
.capea-ev-modal h3 { margin: 0 0 20px; font-size: 1.3rem; color: var(--clr-primary-dark); }
.capea-jl-inline-row { display: flex; gap: 12px; }
@media (max-width: 480px) { .capea-jl-inline-row { flex-direction: column; gap: 0; } }
.capea-ev-newsletter-btn { background: #006c50; color: #fff; border: none; border-radius: 8px; padding: 9px 20px; font-size: .9rem; font-weight: 700; cursor: pointer; transition: background .2s; font-family: inherit; }
.capea-ev-newsletter-btn:hover { background: #005040; }
.capea-nl-preview-btn { background: #f0f0f0; color: #333; border: none; border-radius: 8px; padding: 9px 18px; font-size: .9rem; font-weight: 600; cursor: pointer; transition: background .2s; font-family: inherit; }
.capea-nl-preview-btn:hover { background: #e0e0e0; }

/* ── Upcoming Events teaser (front page) ─────────────────────────────────── */
.wp-block-group:has(.ev-teaser-empty) { display: none !important; padding: 0 !important; }
.ev-teaser-wrap { max-width: 1280px; margin: 0 auto; padding: 0 var(--wp--style--root--padding-left, 40px); }
.ev-teaser-header { text-align: center; margin-bottom: 40px; }
.ev-teaser-label { font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: #774b98; margin: 0 0 8px; }
.ev-teaser-title { font-size: 1.9rem; font-weight: 800; color: #3d1a5c; margin: 0; line-height: 1.2; }
.ev-teaser-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-bottom: 36px; }
.ev-teaser-grid .ev-card-body { padding: 14px 16px 16px; gap: 4px; }
.ev-teaser-grid .ev-card-desc { flex: none; }
.ev-teaser-grid .ev-card-actions { padding-top: 8px; }
.ev-teaser-footer { text-align: center; }
.ev-teaser-all-link { display: inline-block; color: #774b98; font-size: .95rem; font-weight: 700; text-decoration: none; border: 2px solid #774b98; border-radius: 8px; padding: 11px 28px; transition: all .2s; }
.ev-teaser-all-link:hover { color: #fff; border-color: #774b98; background: #774b98; }
@media (max-width: 960px) { .ev-teaser-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px) { .ev-teaser-grid { grid-template-columns: 1fr; } .ev-teaser-title { font-size: 1.5rem; } }
.ev-teaser-grid .ev-card-title { cursor: pointer; }
.ev-teaser-grid .ev-card-title:hover { color: #774b98; }

/* Event detail modal */
.ev-detail-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 10000; align-items: center; justify-content: center; padding: 16px; }
.ev-detail-overlay.is-open { display: flex; }
.ev-detail-modal { background: #fff; border-radius: 16px; width: min(640px,100%); max-height: 90vh; overflow-y: auto; position: relative; box-shadow: 0 24px 80px rgba(0,0,0,.35); scrollbar-width: thin; scrollbar-color: #c4a0e0 #f5f0fb; }
.ev-detail-modal::-webkit-scrollbar { width: 6px; }
.ev-detail-modal::-webkit-scrollbar-track { background: #f5f0fb; border-radius: 0 16px 16px 0; }
.ev-detail-modal::-webkit-scrollbar-thumb { background: #c4a0e0; border-radius: 6px; }
.ev-detail-modal::-webkit-scrollbar-thumb:hover { background: #774b98; }
.ev-detail-modal-close { position: absolute; top: 12px; right: 14px; background: rgba(0,0,0,.08); border: none; border-radius: 50%; width: 32px; height: 32px; font-size: 1.2rem; line-height: 1; cursor: pointer; color: #333; z-index: 2; }
.ev-detail-modal-close:hover { background: rgba(0,0,0,.18); }
.ev-detail-modal-img { width: 100%; height: auto; border-radius: 16px 16px 0 0; display: block; }
.ev-detail-modal-img-ph { width: 100%; aspect-ratio: 16/9; background: #f0e6fa; display: flex; align-items: center; justify-content: center; border-radius: 16px 16px 0 0; }
.ev-detail-modal-img-ph .card-icon { font-size: 4rem !important; color: #774b98 !important; margin: 0 !important; }
.ev-detail-modal-body { padding: 24px 28px 28px; }
.ev-detail-modal-title { font-size: 1.4rem; font-weight: 800; color: #3d1a5c; margin: 0 0 12px; line-height: 1.25; font-family: var(--wp--preset--font-family--headline,sans-serif); }
.ev-detail-modal-meta { font-size: .88rem; color: #555; margin: 0 0 10px; display: flex; flex-wrap: wrap; gap: 6px 12px; }
.ev-detail-modal-cpd { display: inline-block; background: #f0e6fa; color: #774b98; font-size: .78rem; font-weight: 700; padding: 3px 12px; border-radius: 10px; margin-bottom: 14px; }
.ev-detail-modal-long-desc { font-size: .95rem; color: #333; line-height: 1.7; white-space: pre-line; margin: 0 0 24px; }
.ev-detail-modal-short-desc { font-size: .88rem; color: #666; line-height: 1.6; margin: 0 0 20px; font-style: italic; }
.ev-detail-modal-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* ── Member Directory (member-list page) ─────────────────────────────── */
.capea-member-dir { padding: 32px 0; }
.capea-dir-header { display: flex; align-items: center; flex-wrap: wrap; gap: 16px 24px; margin-bottom: 32px; }
.capea-dir-count { margin: 0 !important; font-size: 0.9rem; color: var(--clr-muted); flex-shrink: 0; }
.capea-dir-filters { display: flex; flex-wrap: wrap; gap: 8px; }
.capea-dir-filter-btn { background: #fff; border: 2px solid #774b98; color: #774b98; border-radius: 20px; padding: 5px 16px; font-size: 0.85rem; font-weight: 600; cursor: pointer; transition: background 0.15s, color 0.15s; }
.capea-dir-filter-btn.is-active, .capea-dir-filter-btn:hover { background: #774b98; color: #fff; }
.capea-dir-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.capea-dir-card { background: #fff; border-radius: 14px; padding: 24px 20px; box-shadow: 0 2px 14px rgba(0,0,0,0.07); text-align: center; transition: transform 0.18s, box-shadow 0.18s; }
.capea-dir-card:hover { transform: translateY(-3px); box-shadow: 0 6px 24px rgba(0,0,0,0.12); }
.capea-dir-avatar { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; display: block; margin: 0 auto 12px; border: 3px solid var(--wp--preset--color--surface); box-shadow: 0 2px 8px rgba(0,0,0,0.1); }
.capea-dir-name { font-size: 1rem; font-weight: 700; color: var(--clr-text); margin: 0 0 8px !important; }
.capea-dir-state-badge { display: inline-block; background: #774b98; color: #fff; font-size: 0.75rem; font-weight: 700; padding: 3px 12px; border-radius: 10px; text-transform: uppercase; letter-spacing: 0.04em; }
.capea-dir-bio { font-size: 0.85rem; color: var(--clr-muted); margin: 8px 0 0 !important; line-height: 1.5; }
.capea-dir-empty { color: var(--clr-muted); text-align: center; padding: 48px 0; font-size: 0.95rem; }
.capea-dir-link { display: inline-block; margin-top: 10px; font-size: 0.82rem; font-weight: 600; color: var(--clr-primary-dark); text-decoration: none; border: 1.5px solid var(--clr-primary-dark); border-radius: 12px; padding: 3px 12px; transition: background 0.15s, color 0.15s; }
.capea-dir-link:hover { background: var(--clr-primary-dark); color: #fff; }
.capea-profile-link-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.capea-profile-link-row small { grid-column: 1 / -1; margin-top: 0; }
@media (max-width: 960px) { .capea-dir-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) { .capea-dir-grid { grid-template-columns: 1fr; } .capea-dir-header { flex-direction: column; align-items: flex-start; } .capea-profile-link-row { grid-template-columns: 1fr; } }

/* ── Contact Form 7 ──────────────────────────────────────────────────── */
.wpcf7 { width: 100%; }
.capea-cf7-field { margin-bottom: 18px; }
.capea-cf7-field label { display: block; font-size: .9rem; font-weight: 600; color: #333; margin-bottom: 6px; }
.capea-cf7-field label abbr { text-decoration: none; color: #c0392b; margin-left: 2px; }
.wpcf7-text, .wpcf7-email, .wpcf7-select, .wpcf7-textarea { width: 100%; box-sizing: border-box; border: 1.5px solid #d0d5dd; border-radius: 8px; padding: 11px 14px; font-size: 1rem; font-family: inherit; color: #1a1a1a; background: #fff; transition: border-color .15s, box-shadow .15s; appearance: none; -webkit-appearance: none; }
.wpcf7-select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24'%3E%3Cpath fill='%23555' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 36px; cursor: pointer; }
.wpcf7-text:focus, .wpcf7-email:focus, .wpcf7-select:focus, .wpcf7-textarea:focus { border-color: #006c50; box-shadow: 0 0 0 3px rgba(0,108,80,.12); outline: none; }
.wpcf7-textarea { resize: vertical; min-height: 130px; }
.wpcf7-not-valid { border-color: #c0392b !important; }
.wpcf7-not-valid-tip { display: block; font-size: .8rem; color: #c0392b; margin-top: 4px; }
.capea-cf7-submit { margin-top: 8px; }
.wpcf7-submit { background: #006c50; color: #fff; border: none; border-radius: 8px; padding: 13px 36px; font-size: 1rem; font-weight: 700; cursor: pointer; width: 100%; transition: background .15s; font-family: inherit; }
.wpcf7-submit:hover { background: #004f3a; }
.wpcf7-submit:disabled, .wpcf7-submit[aria-disabled=true] { background: #7fb5a8; cursor: not-allowed; }
.wpcf7-response-output { margin: 16px 0 0 !important; padding: 12px 16px; border-radius: 8px; font-size: .9rem; border: none !important; }
.wpcf7-form.sent .wpcf7-response-output { background: #f0faf5; color: #006c50; border-left: 4px solid #006c50 !important; }
.wpcf7-form.failed .wpcf7-response-output, .wpcf7-form.aborted .wpcf7-response-output { background: #fff5f5; color: #c0392b; border-left: 4px solid #c0392b !important; }
.wpcf7-form.invalid .wpcf7-response-output, .wpcf7-form.unaccepted .wpcf7-response-output { background: #fffbf0; color: #856404; border-left: 4px solid #ffc107 !important; }
.wpcf7-spinner { display: none; }

/* ── 404 Page ─────────────────────────────────────────────────────────── */
.capea-404-section { text-align: center; }
.capea-404-section .wp-block-heading { color: #3d1a5c; font-size: clamp(2rem, 5vw, 3rem); margin: 0 0 16px !important; }
.capea-404-section > .has-text-align-center:not(.capea-404-icon):not(.wp-block-heading) { max-width: 520px; margin: 0 auto 32px !important; color: var(--clr-muted); }
.capea-404-icon { font-family: 'Material Symbols Outlined'; font-size: 5rem !important; font-weight: 100; color: #774b98; line-height: 1; margin: 0 0 24px !important; }

/* ── Login Page ───────────────────────────────────────────────────────── */
.capea-login-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: start; padding: 48px 0 64px; }
.capea-login-form-card { background: #fff; border-radius: 16px; padding: 36px 40px; box-shadow: 0 4px 24px rgba(0,0,0,.08); }
.capea-login-form-card h2 { margin: 0 0 24px !important; font-size: 1.5rem; color: #3d1a5c; }
.capea-login-form-wrap #capea-login-form { margin: 0; }
.capea-login-form-wrap #capea-login-form p { margin: 0 0 16px; }
.capea-login-form-wrap #capea-login-form label { display: block; font-size: .9rem; font-weight: 600; color: #333; margin-bottom: 6px; }
.capea-login-form-wrap #capea-login-form input[type=text],
.capea-login-form-wrap #capea-login-form input[type=password] { width: 100%; box-sizing: border-box; border: 1.5px solid #d0d5dd; border-radius: 8px; padding: 11px 14px; font-size: 1rem; transition: border-color .15s, box-shadow .15s; }
.capea-login-form-wrap #capea-login-form input[type=text]:focus,
.capea-login-form-wrap #capea-login-form input[type=password]:focus { border-color: #006c50; box-shadow: 0 0 0 3px rgba(0,108,80,.12); outline: none; }
.capea-login-form-wrap #capea-login-form input[type=submit] { background: #006c50; color: #fff; border: none; border-radius: 8px; padding: 12px 32px; font-size: 1rem; font-weight: 700; cursor: pointer; width: 100%; margin-top: 4px; transition: background .15s; }
.capea-login-form-wrap #capea-login-form input[type=submit]:hover { background: #004f3a; }
.capea-login-form-wrap #capea-login-form .forgetmenot { display: flex; align-items: center; gap: 8px; font-size: .88rem; color: #555; margin: 0; }
.capea-login-form-wrap #capea-login-form .forgetmenot input { width: auto; margin: 0; }
.capea-login-forgot { margin: 14px 0 0 !important; text-align: center; font-size: .88rem; }
.capea-login-forgot a { color: #006c50; text-decoration: none; }
.capea-login-forgot a:hover { text-decoration: underline; }
.capea-login-already { text-align: center; padding: 24px; background: #f0faf5; border-radius: 12px; border: 1.5px solid #43b790; }
.capea-login-already .card-icon { font-size: 3rem !important; margin: 0 0 12px !important; color: #006c50; }
.capea-join-card { background: #fff; border-radius: 16px; padding: 28px; box-shadow: 0 4px 24px rgba(0,0,0,.08); margin-bottom: 16px; border: 2px solid transparent; transition: border-color .15s, transform .15s; cursor: pointer; }
.capea-join-card:hover { border-color: #006c50; transform: translateY(-2px); }
.capea-join-card-featured { border-color: #774b98 !important; position: relative; }
.capea-join-badge { position: absolute; top: -12px; right: 20px; background: #774b98; color: #fff; font-size: .75rem; font-weight: 700; padding: 3px 14px; border-radius: 10px; text-transform: uppercase; letter-spacing: .05em; }
.capea-join-card h3 { margin: 0 0 4px !important; font-size: 1.1rem; color: #3d1a5c; }
.capea-join-card .capea-join-price { font-size: 1.6rem; font-weight: 800; color: #006c50; margin: 0 0 12px !important; }
.capea-join-card ul { margin: 0 0 16px !important; padding-left: 20px; color: #444; font-size: .9rem; }
.capea-join-card ul li { margin-bottom: 4px; }
.capea-join-card .capea-join-btn { display: block; text-align: center; background: #006c50; color: #fff; border-radius: 8px; padding: 11px; font-weight: 700; font-size: .95rem; text-decoration: none; transition: background .15s; }
.capea-join-card-featured .capea-join-btn { background: #774b98; }
.capea-join-card .capea-join-btn:hover { background: #004f3a; }
.capea-join-card-featured .capea-join-btn:hover { background: #5c3a78; }
.capea-join-section-title { font-size: 1.2rem; font-weight: 800; color: #3d1a5c; margin: 0 0 6px !important; }
.capea-join-section-sub { font-size: .88rem; color: var(--clr-muted); margin: 0 0 20px !important; }
@media (max-width: 860px) { .capea-login-wrap { grid-template-columns: 1fr; } }

/* ── CAPEA Shop (archive) ─────────────────────────────────────────────── */

/* Hero */
.capea-shop-hero .wp-block-cover__background {
    background: linear-gradient(150deg, #4a1f78 0%, #774b98 55%, #3d1a5c 100%) !important;
}
.capea-shop-hero .wp-block-cover__inner-container { padding: 52px 0; text-align: center; }
.capea-shop-hero h1 { font-size: clamp(1.9rem, 4vw, 2.8rem); margin: 0 auto 12px !important; text-align: center !important; }
.capea-shop-hero p { max-width: 620px; margin: 0 auto !important; text-align: center !important; }
.capea-shop-hero-eyebrow {
    display: inline-flex !important;
    align-items: center;
    gap: 5px;
    font-size: .75rem !important;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .11em;
    margin: 0 auto 14px !important;
    padding: 4px 14px;
    border: 1px solid rgba(255,255,255,.28);
    border-radius: 20px;
    justify-content: center;
}
.capea-shop-hero-eyebrow::before {
    content: 'storefront';
    font-family: 'Material Symbols Outlined';
    font-variation-settings: 'FILL' 1;
    font-size: .9rem;
    line-height: 1;
}

/* Stats strip — use same global padding as hero inner group; only override vertical */
.capea-section-teal.capea-shop-stats { padding-block: 24px !important; }
.capea-shop-stats .capea-stat-row { margin: 0 !important; justify-content: center !important; }

/* Full-bleed background breakout — WC wrapper lacks has-global-padding so WP's
   alignfull negative-margin rule doesn't fire; force it manually */
.capea-shop-stats.alignfull,
.capea-shop-member-cta.alignfull {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}
/* Inner wide-content group: centered at wide-size within the full-bleed bg */
.capea-shop-stats.alignfull > .wp-block-group.alignwide {
    max-width: var(--wp--style--global--wide-size, 1440px);
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100%;
    box-sizing: border-box;
}
.capea-shop-stat-icon {
    font-family: 'Material Symbols Outlined';
    font-variation-settings: 'FILL' 1;
    font-size: 1.55rem !important;
    color: rgba(255,255,255,.72) !important;
    text-align: center;
    margin: 0 0 2px !important;
    line-height: 1;
}

/* Filter bar */
.capea-shop-filter-bar { padding-top: 14px !important; padding-bottom: 12px !important; border-bottom: 1.5px solid #e5e7eb; }
.capea-shop-filter-inner { gap: 10px !important; }
.capea-shop-filter-label { margin: 0 !important; font-size: .88rem; font-weight: 600; color: var(--clr-muted); white-space: nowrap; }
.wp-block-button.shop-filter-btn .wp-block-button__link {
    background: #fff;
    border: 1.5px solid #d0d0d0;
    color: #4a4a4a;
    padding: 7px 18px;
    font-size: .85rem;
    font-weight: 600;
    transition: background .15s, color .15s, border-color .15s;
}
.wp-block-button.shop-filter-all .wp-block-button__link:hover,
.wp-block-button.shop-filter-all .wp-block-button__link:focus,
.wp-block-button.shop-filter-all.is-active .wp-block-button__link { background: #4a4a4a; border-color: #4a4a4a; color: #fff; }
.wp-block-button.shop-filter-webinar .wp-block-button__link:hover,
.wp-block-button.shop-filter-webinar .wp-block-button__link:focus,
.wp-block-button.shop-filter-webinar.is-active .wp-block-button__link { background: #774b98; border-color: #774b98; color: #fff; }
.wp-block-button.shop-filter-membership .wp-block-button__link:hover,
.wp-block-button.shop-filter-membership .wp-block-button__link:focus,
.wp-block-button.shop-filter-membership.is-active .wp-block-button__link { background: #006c50; border-color: #006c50; color: #fff; }
.wp-block-button.shop-filter-free .wp-block-button__link:hover,
.wp-block-button.shop-filter-free .wp-block-button__link:focus,
.wp-block-button.shop-filter-free.is-active .wp-block-button__link { background: #1565c0; border-color: #1565c0; color: #fff; }

/* Product grid background — lavender section */
.capea-shop-grid-bg {
    background: #f3e8ff;
    padding-top: 36px !important;
    padding-bottom: 48px !important;
}
.capea-shop-grid-bg.alignfull {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

/* Product grid cards */
.wc-block-product-template { gap: 20px !important; }
.wc-block-product {
    position: relative;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 2px 18px rgba(119,75,152,.12);
    overflow: hidden;
    transition: transform .18s ease, box-shadow .18s ease;
    display: flex;
    flex-direction: column;
}
.wc-block-product:hover { transform: translateY(-5px); box-shadow: 0 10px 36px rgba(119,75,152,.22); }

/* Category badge overlays */
.wc-block-product::before {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 3;
    font-size: .68rem;
    font-weight: 800;
    padding: 3px 10px;
    border-radius: 20px;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: #fff;
    font-family: var(--font-body);
    line-height: 1.65;
    pointer-events: none;
}
.wc-block-product.product_cat-webinar::before { content: "Webinar"; background: rgba(119,75,152,.88); }
.wc-block-product.product_cat-membership::before { content: "Membership"; background: rgba(0,108,80,.88); }
.wc-block-product.product_cat-free-download::before { content: "Free"; background: rgba(21,101,192,.88); }

/* Product image / name / price / button */
.wc-block-components-product-image__inner-container img { width: 100%; height: 186px; object-fit: cover; display: block; }
.wc-block-components-product-name { font-weight: 700; font-size: .94rem; color: #1a1a2e; margin: 12px 14px 5px !important; display: block; line-height: 1.35; }
.wc-block-components-product-price { color: #006c50; font-weight: 800; font-size: 1rem; margin: 0 14px 12px !important; display: block; }
.wp-block-button.wc-block-components-product-button { margin: auto 14px 14px !important; }
.wp-block-button.wc-block-components-product-button .wp-block-button__link {
    display: block;
    width: 100%;
    text-align: center;
    background: #006c50;
    color: #fff;
    border-radius: 8px;
    padding: 10px;
    font-weight: 700;
    font-size: .88rem;
    border: none;
    transition: background .15s;
}
.wp-block-button.wc-block-components-product-button .wp-block-button__link:hover { background: #004f3a; }
.wc-block-product-results-count { font-size: .88rem; color: var(--clr-muted); }

/* Membership CTA banner */
.capea-shop-member-cta {
    background: linear-gradient(135deg, #3d1a5c 0%, #004f3a 100%);
    padding-top: 52px !important;
    padding-bottom: 52px !important;
    margin-top: 8px;
}
.capea-shop-member-cta-inner { gap: 40px !important; align-items: center !important; }
.capea-shop-member-cta-text { gap: 12px !important; max-width: 560px; }
.capea-shop-member-eyebrow {
    font-size: .74rem !important;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: rgba(255,255,255,.65);
    margin: 0 !important;
}
.capea-shop-member-eyebrow::before {
    content: 'workspace_premium  ';
    font-family: 'Material Symbols Outlined';
    font-variation-settings: 'FILL' 1;
    font-size: .9rem;
    vertical-align: middle;
    margin-right: 3px;
}
.capea-shop-member-cta .wp-block-heading {
    color: #fff !important;
    font-size: clamp(1.3rem, 2.8vw, 1.85rem) !important;
    margin: 0 !important;
    line-height: 1.22;
}
.capea-shop-member-cta p:not(.capea-shop-member-eyebrow) {
    color: rgba(255,255,255,.85);
    margin: 0 !important;
    font-size: .96rem;
    line-height: 1.65;
}
.wp-block-button.capea-shop-cta-btn-primary .wp-block-button__link {
    background: #fff !important;
    color: #006c50 !important;
    font-weight: 700 !important;
    white-space: nowrap;
    padding: 13px 28px !important;
}
.wp-block-button.capea-shop-cta-btn-primary .wp-block-button__link:hover { background: #effcf6 !important; }
.wp-block-button.is-style-outline.capea-shop-cta-btn-secondary .wp-block-button__link {
    border: 2px solid rgba(255,255,255,.5) !important;
    color: #fff !important;
    background: transparent !important;
    white-space: nowrap;
    padding: 11px 28px !important;
}
.wp-block-button.is-style-outline.capea-shop-cta-btn-secondary .wp-block-button__link:hover {
    background: rgba(255,255,255,.12) !important;
    border-color: rgba(255,255,255,.85) !important;
}

/* Shop responsive */
@media (max-width: 900px) {
    .capea-shop-filter-inner { flex-direction: column; align-items: flex-start !important; }
    .wc-block-product-template__responsive.columns-4 { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 760px) {
    .capea-shop-member-cta-inner { flex-direction: column !important; align-items: flex-start !important; }
}
@media (max-width: 480px) {
    .wc-block-product-template__responsive.columns-4 { grid-template-columns: 1fr !important; }
}

/* ── Single Product Page ─────────────────────────────────────────────── */

/* Breadcrumb bar */
.capea-product-breadcrumb { background: #f8f9fa; padding-top: 14px !important; padding-bottom: 14px !important; border-bottom: 1px solid #e5e7eb; }
.capea-product-breadcrumb.alignfull {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}
.capea-product-breadcrumb.alignfull > .wp-block-group.alignwide {
    max-width: var(--wp--style--global--wide-size, 1440px);
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100%;
    box-sizing: border-box;
}
.woocommerce-breadcrumb,
.wc-block-breadcrumbs { font-size: .84rem; color: var(--clr-muted); margin: 0 !important; padding: 0 !important; }
.woocommerce-breadcrumb a,
.wc-block-breadcrumbs a { color: #006c50; text-decoration: none; }
.woocommerce-breadcrumb a:hover,
.wc-block-breadcrumbs a:hover { text-decoration: underline; }
/* Reset WC's alignwide breakout — keep breadcrumb inside the constrained padding */
.capea-product-breadcrumb .wc-block-breadcrumbs.alignwide {
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Product layout */
/* padding-top/bottom only — do NOT use shorthand (would zero has-global-padding horizontal) */
.capea-product-main.wp-block-group { padding-top: 64px !important; padding-bottom: 64px !important; }
.capea-product-cols { gap: 48px !important; align-items: flex-start !important; }
.capea-product-image-col .wc-block-product-image-gallery,
.capea-product-image-col .woocommerce-product-gallery { border-radius: 12px; overflow: hidden; position: sticky; top: 96px; }
.capea-product-details-col { padding: 4px 0 0; }

/* Product title */
.capea-product-title.wp-block-post-title,
.product_title.entry-title {
    font-size: clamp(1.5rem, 3vw, 2.1rem) !important;
    font-weight: 800 !important;
    color: #1a1a2e !important;
    margin: 0 0 12px !important;
    line-height: 1.22 !important;
}

/* Star rating */
.capea-product-rating { margin: 0 0 16px !important; }
.wc-block-components-product-rating__stars,
.star-rating span { color: #f59e0b !important; }
.star-rating::before { color: #ddd; }

/* Price */
.capea-product-price { margin: 0 0 20px !important; display: block; }
.capea-product-price .wc-block-components-product-price { display: block; }
.capea-product-price .price .amount,
.capea-product-price .wc-block-components-formatted-money-amount {
    font-size: 1.9rem !important;
    font-weight: 800 !important;
    color: #006c50 !important;
    line-height: 1.1;
}
.capea-product-price del .amount { font-size: 1.1rem !important; color: var(--clr-muted) !important; font-weight: 400 !important; }
.capea-product-price ins { text-decoration: none !important; }

/* Short description */
.capea-product-summary { margin: 0 0 24px !important; }
.capea-product-summary p { font-size: .98rem; line-height: 1.72; color: var(--clr-text); margin: 0 0 10px !important; }

/* Add to cart */
.capea-add-to-cart { margin: 24px 0 !important; }
.capea-add-to-cart form.cart { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.woocommerce .quantity .qty,
.wc-block-components-quantity-selector input {
    border: 2px solid #e0e0e0 !important;
    border-radius: 8px !important;
    padding: 10px 14px !important;
    font-size: 1rem !important;
    width: 80px !important;
    text-align: center;
    font-weight: 600;
    color: #1a1a2e;
}
.woocommerce .quantity .qty:focus,
.wc-block-components-quantity-selector input:focus {
    border-color: #006c50 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(0,108,80,.1) !important;
}
.woocommerce a.button,
.woocommerce button.button,
.woocommerce .single_add_to_cart_button,
.capea-add-to-cart .wp-block-button__link {
    background: #006c50 !important;
    color: #fff !important;
    font-size: 1.04rem !important;
    font-weight: 700 !important;
    padding: 13px 32px !important;
    border-radius: 8px !important;
    border: none !important;
    cursor: pointer;
    transition: background .15s !important;
    text-decoration: none !important;
    display: inline-block;
    line-height: 1.5;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce .single_add_to_cart_button:hover,
.capea-add-to-cart .wp-block-button__link:hover { background: #004f3a !important; }
.woocommerce a.button.added_to_cart { background: #004f3a !important; }

/* Product meta */
.capea-product-meta { margin: 0 !important; padding-top: 18px; border-top: 1px solid #e5e7eb; font-size: .84rem; color: var(--clr-muted); }
.capea-product-meta .posted_in,
.capea-product-meta .tagged_as { display: block; margin: 4px 0 !important; }
.capea-product-meta a { color: #006c50; }
.capea-product-meta a:hover { text-decoration: underline; }

/* Product details tabs */
.capea-product-tabs { padding-top: 0 !important; padding-bottom: 48px !important; }
.capea-product-tabs > .wp-block-group { border-top: 1.5px solid #e5e7eb; }
.woocommerce-tabs ul.tabs.wc-tabs {
    display: flex;
    gap: 0;
    padding: 0;
    margin: 0 0 0 !important;
    list-style: none;
    border-bottom: 2px solid #e5e7eb;
}
.woocommerce-tabs ul.tabs li { margin: 0; padding: 0; border: none !important; background: none !important; border-radius: 0 !important; }
.woocommerce-tabs ul.tabs li a {
    display: block;
    padding: 14px 22px;
    font-size: .92rem;
    font-weight: 600;
    color: var(--clr-muted);
    text-decoration: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: color .15s, border-color .15s;
}
.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover { color: #006c50; border-bottom-color: #006c50; }
.woocommerce-tabs .panel { padding: 28px 0; font-size: .97rem; line-height: 1.75; max-width: none !important; }
.woocommerce-tabs .panel h2 { font-size: 1.2rem; margin-top: 0; color: #1a1a2e; }

/* Related products */
.capea-product-related { padding-top: 0 !important; padding-bottom: 80px !important; }
.capea-product-related.alignwide {
    max-width: var(--wp--style--global--wide-size, 1440px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100%;
    box-sizing: border-box;
}
.capea-related-heading.wp-block-heading {
    font-size: 1.4rem !important;
    color: #1a1a2e !important;
    margin: 0 0 24px !important;
    padding-top: 32px;
    border-top: 1.5px solid #e5e7eb;
}
.woocommerce .related ul.products,
.wc-block-related-products .wp-block-woocommerce-product-collection {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 20px !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.woocommerce .related h2 { display: none; }

/* Single product responsive */
@media (max-width: 860px) {
    .capea-product-cols { flex-direction: column !important; }
    .capea-product-image-col,
    .capea-product-details-col { width: 100% !important; flex-basis: 100% !important; }
    .capea-product-image-col .wc-block-product-image-gallery,
    .capea-product-image-col .woocommerce-product-gallery { position: static; }
    .woocommerce .related ul.products,
    .wc-block-related-products .wp-block-woocommerce-product-collection { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 480px) {
    .woocommerce .related ul.products,
    .wc-block-related-products .wp-block-woocommerce-product-collection { grid-template-columns: 1fr !important; }
    .capea-add-to-cart form.cart { flex-direction: column; align-items: stretch; }
}
@media (max-width: 600px) { .capea-login-form-card { padding: 24px 20px; } }

/* ── Webinar View Page (purchased webinar player) ─────────────────────────── */
.webinar-view-page { padding: 40px 0 80px; }
.webinar-view-page .wp-block-post-content h1 {
    color: var(--wp--preset--color--secondary);
    font-size: clamp(1.3rem, 3vw, 1.9rem);
    margin: 0 0 24px;
    line-height: 1.3;
}
.webinar-view-page .wp-block-post-content p { margin-bottom: 0; }
.webinar-view-page .wp-block-post-content iframe[src*="youtube.com/embed"],
.webinar-view-page .wp-block-post-content iframe[src*="youtu.be"] {
    width: 100% !important;
    max-width: 900px;
    height: auto !important;
    aspect-ratio: 16/9;
    display: block;
    margin: 0 auto 24px;
    border-radius: 8px;
    box-shadow: 0 4px 24px rgba(0,0,0,.15);
}
.webinar-view-page .wp-block-post-content a[role="button"],
.webinar-view-page .wp-block-post-content a[href$=".pdf"] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 16px;
    color: var(--wp--preset--color--primary-dark, #006c50);
    font-weight: 600;
}
@media (max-width: 600px) { .webinar-view-page { padding: 24px 0 60px; } }
