/**
 * King's College London — site theme (Strand and London campuses)
 * Design: deep navy + gold + warm ivory, aligned with King's College London’s traditional colours.
 */
:root {
  --kc-navy:      #0d2240;
  --kc-navy-dark: #081629;
  --kc-gold:      #b8912a;
  --kc-gold-light:#d4ab4e;
  --kc-gold-dark: #6b4f00; /* NEW: dark gold for use on light/white backgrounds (7.7:1 on white) */
  --kc-text:      #1a1a1a;
  --kc-muted:     #4d4d4d;
  --kc-bg:        #fdfcf9;
  --kc-subtle:    #f5f3ee;
  --kc-line:      #e2ddd4;
  --kc-font-body: "DM Sans", system-ui, -apple-system, sans-serif;
  --kc-font-head: "EB Garamond", Georgia, serif;

  --kc-radius-sm: 8px;
  --kc-radius-md: 14px;
  --kc-radius-lg: 22px;
  --kc-shadow-sm: 0 2px 12px rgba(13, 34, 64, 0.06);
  --kc-shadow-md: 0 14px 48px rgba(13, 34, 64, 0.1);
  --kc-shadow-lg: 0 28px 80px rgba(8, 22, 41, 0.22);
  --kc-shadow-glow: 0 0 0 1px rgba(184, 145, 42, 0.12), 0 20px 60px rgba(0, 0, 0, 0.35);
  --kc-ease: cubic-bezier(0.22, 1, 0.36, 1);

  /* legacy aliases so shared components still work */
  --kngcl-red:      var(--kc-gold);
  --kngcl-red-dark: var(--kc-gold-light);
  --kngcl-text:     var(--kc-text);
  --kngcl-muted:    var(--kc-muted);
  --kngcl-bg:       var(--kc-bg);
  --kngcl-subtle:   var(--kc-subtle);
  --kngcl-line:     var(--kc-line);
  --kngcl-font:     var(--kc-font-body);
}

html { scroll-behavior: smooth; }

body.kngcl-site {
  font-family: var(--kc-font-body);
  color: var(--kc-text);
  background:
    radial-gradient(1200px 600px at 12% -8%, rgba(184, 145, 42, 0.06), transparent 55%),
    radial-gradient(900px 500px at 100% 0%, rgba(13, 34, 64, 0.04), transparent 50%),
    var(--kc-bg);
  padding-top: 0;
  -webkit-font-smoothing: antialiased;
}

body.kngcl-site .kngcl-skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 10001;
  padding: 12px 20px; background: var(--kc-navy); color: #fff;
  font-weight: 700; text-decoration: none; border-radius: 0 0 4px 0;
}
body.kngcl-site .kngcl-skip-link:focus { left: 0; outline: 3px solid var(--kc-gold); outline-offset: 2px; }

/* ─── HEADER ─── */
body.kngcl-site .main-header {
  position: sticky !important; top: 0; z-index: 1000;
  background: linear-gradient(180deg, rgba(15, 42, 78, 0.97) 0%, rgba(13, 34, 64, 0.98) 45%, rgba(8, 22, 41, 0.99) 100%) !important;
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid rgba(184, 145, 42, 0.45);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset, 0 12px 40px rgba(0, 0, 0, 0.25);
  height: auto; min-height: 72px;
}
body.kngcl-site .main-header::after { content: ""; display: table; clear: both; }
body.kngcl-site .main-header .logo {
  float: left; line-height: 1.25; padding: 1.1rem 1rem 1.1rem 1.5rem;
}
body.kngcl-site .main-header .logo a {
  color: rgba(255,255,255,0.92) !important; font-weight: 700;
  font-size: 1.05rem !important; letter-spacing: -0.01em; text-decoration: none;
}
body.kngcl-site .main-header .logo em {
  color: var(--kc-gold-light) !important; font-style: normal; font-weight: 800;
  letter-spacing: -0.02em; font-family: "EB Garamond", Georgia, serif; font-size: 1.15em;
}
body.kngcl-site .menu-link { color: var(--kc-gold-light) !important; }
body.kngcl-site #menu.main-nav { background: transparent; }
body.kngcl-site .main-menu {
  float: right; padding-right: 1.5rem; list-style: none; margin: 0;
}
body.kngcl-site .main-menu > li {
  line-height: 72px; margin-left: 2px; display: inline-block;
  position: relative; vertical-align: middle;
}
body.kngcl-site .main-menu > li > a {
  color: rgba(255,255,255,0.88) !important; font-weight: 500;
  font-size: 0.82rem !important; padding: 8px 12px !important;
  text-transform: none !important; letter-spacing: 0.02em !important;
  border: 2px solid transparent !important; border-radius: 999px;
  transition: color 0.2s var(--kc-ease), border-color 0.2s var(--kc-ease), background-color 0.2s var(--kc-ease);
}
body.kngcl-site .main-menu > li > a:hover {
  color: var(--kc-gold-light) !important;
  background: rgba(255, 255, 255, 0.04);
}
body.kngcl-site .main-nav li:hover > a,
body.kngcl-site .main-nav > ul > li.active > a {
  border-color: rgba(184,145,42,0.7) !important; color: var(--kc-gold-light) !important;
}
body.kngcl-site .sub-menu {
  background: rgba(8, 22, 41, 0.98) !important;
  border: 1px solid rgba(184,145,42,0.28) !important;
  border-radius: var(--kc-radius-sm);
  box-shadow: var(--kc-shadow-glow);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
body.kngcl-site .sub-menu li a { color: rgba(255,255,255,0.82) !important; font-size: 0.82rem; }
body.kngcl-site .sub-menu li a:hover { color: var(--kc-gold-light) !important; }
body.kngcl-site .main-menu li.has-submenu > a:after { display: none !important; }
body.kngcl-site .main-menu li.has-submenu ul li a:after { display: none !important; content: none !important; }
a.menu-link { display: none; }

@media screen and (min-width: 951px) {
  body.kngcl-site #menu.main-nav { float: right; max-height: none !important; overflow: visible !important; }
  body.kngcl-site.js #menu.main-nav { max-height: none !important; overflow: visible !important; }
  body.kngcl-site .main-menu { list-style: none; margin: 0; padding: 0; }
  body.kngcl-site .main-menu > li { display: inline-block; position: relative; vertical-align: middle; margin-left: 2px; }
  body.kngcl-site .main-menu li .sub-menu {
    position: absolute; left: 0; top: 100%; z-index: 1002; list-style: none;
    margin: 0; padding: 8px 0; min-width: 220px;
    opacity: 0; visibility: hidden; pointer-events: none;
    transition: opacity 0.2s ease, visibility 0.2s ease;
  }
  body.kngcl-site .main-menu li:hover .sub-menu,
  body.kngcl-site .main-menu li:focus-within .sub-menu { opacity: 1; visibility: visible; pointer-events: auto; }
  body.kngcl-site .main-menu li .sub-menu li {
    display: block; line-height: 1.35; margin: 0; padding: 6px 0;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  }
  body.kngcl-site .main-menu li .sub-menu li:last-child { border-bottom: none !important; }
  body.kngcl-site .main-menu li .sub-menu li a { display: block; padding: 6px 18px !important; white-space: nowrap; }
}

/* ─── HERO ─── */
.kngcl-hero {
  padding: 3rem 0 3.5rem;
  background:
    radial-gradient(ellipse 80% 55% at 70% 0%, rgba(184, 145, 42, 0.14), transparent 55%),
    radial-gradient(ellipse 60% 50% at 0% 100%, rgba(255, 255, 255, 0.06), transparent 50%),
    linear-gradient(155deg, var(--kc-navy-dark) 0%, #0a1830 42%, var(--kc-navy) 100%);
  border-bottom: 1px solid rgba(184, 145, 42, 0.5);
  box-shadow: 0 24px 80px rgba(8, 22, 41, 0.35);
  position: relative; overflow: hidden;
}
.kngcl-hero::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 90% 80% at 50% 0%, black 20%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 90% 80% at 50% 0%, black 20%, transparent 75%);
  pointer-events: none;
  opacity: 0.5;
}
.kngcl-hero .container { position: relative; z-index: 1; }
@media (min-width: 992px) { .kngcl-hero { padding: 4.25rem 0 5.25rem; } }

.kngcl-eyebrow {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-size: 0.72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.16em; color: var(--kc-gold-light); margin-bottom: 0.85rem;
}
.kngcl-eyebrow::before {
  content: "";
  width: 28px; height: 1px;
  background: linear-gradient(90deg, var(--kc-gold-light), transparent);
  opacity: 0.9;
}
.kngcl-hero-title {
  font-family: "EB Garamond", Georgia, serif;
  font-size: clamp(1.95rem, 4.5vw, 3.35rem);
  font-weight: 600; line-height: 1.12; letter-spacing: -0.02em;
  margin: 0; color: #ffffff; font-style: italic;
  text-shadow: 0 2px 48px rgba(0, 0, 0, 0.35);
}
.kngcl-hero-actions {
  display: flex; flex-wrap: wrap; align-items: center; gap: 0.75rem 1rem;
  margin-top: 0.25rem;
}
.kngcl-feature-card {
  display: block;
  background: linear-gradient(145deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0.03) 100%);
  border: 1px solid rgba(184,145,42,0.4);
  border-radius: var(--kc-radius-md);
  overflow: hidden; text-decoration: none; color: inherit;
  box-shadow: var(--kc-shadow-lg);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: transform 0.35s var(--kc-ease), box-shadow 0.35s var(--kc-ease), border-color 0.25s var(--kc-ease);
}
.kngcl-feature-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 32px 72px rgba(0,0,0,0.45), 0 0 0 1px rgba(212, 171, 78, 0.35);
  border-color: var(--kc-gold-light);
  text-decoration: none; color: inherit;
}
.kngcl-feature-card img {
  width: 100%; height: 220px; object-fit: cover; display: block;
  transition: transform 0.5s var(--kc-ease);
}
.kngcl-feature-card:hover img { transform: scale(1.04); }
.kngcl-feature-body { padding: 1.35rem 1.5rem 1.6rem; }
.kngcl-kicker {
  font-size: 0.72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--kc-gold-light);
}
.kngcl-feature-card h2 {
  font-family: "EB Garamond", Georgia, serif;
  font-size: 1.4rem; font-weight: 600; margin: 0.5rem 0; line-height: 1.25; color: #fff;
}
.kngcl-feature-card p { margin: 0; font-size: 0.9rem; color: rgba(255,255,255,0.78); line-height: 1.55; }

/* ─── SECTIONS ─── */
.kngcl-section-title {
  font-family: "EB Garamond", Georgia, serif;
  font-size: clamp(1.65rem, 3vw, 2.15rem); font-weight: 600; letter-spacing: -0.02em;
  margin: 0 0 1.75rem; color: var(--kc-navy);
  padding-bottom: 0.65rem; display: inline-block; position: relative;
}
.kngcl-section-title::after {
  content: "";
  position: absolute; left: 0; bottom: 0; width: 100%; height: 3px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--kc-gold) 0%, var(--kc-gold-light) 45%, rgba(184, 145, 42, 0.2) 100%);
}
.kngcl-news { padding: 3.25rem 0; background: transparent; }
.kngcl-news-item {
  margin-bottom: 1.5rem; padding: 1.35rem 1.35rem 1.35rem;
  border: 1px solid var(--kc-line);
  border-radius: var(--kc-radius-md);
  background: #fff;
  box-shadow: var(--kc-shadow-sm);
  transition: border-color 0.25s var(--kc-ease), box-shadow 0.25s var(--kc-ease), transform 0.25s var(--kc-ease);
}
.kngcl-news-item:hover {
  border-color: rgba(184, 145, 42, 0.45);
  box-shadow: var(--kc-shadow-md);
  transform: translateY(-2px);
}
.kngcl-news-item:last-of-type { margin-bottom: 1.25rem; }
.kngcl-news-item--media { display: flex; gap: 1.25rem; align-items: flex-start; }
.kngcl-news-thumb { flex: 0 0 140px; }
.kngcl-news-thumb img {
  width: 100%; height: 90px; object-fit: cover;
  border-radius: var(--kc-radius-sm); display: block;
  box-shadow: 0 4px 16px rgba(13, 34, 64, 0.12);
}
.kngcl-news-body { flex: 1 1 0; min-width: 0; }
.kngcl-news-meta { font-size: 0.78rem; color: var(--kc-muted); margin-bottom: 0.35rem; }
.kngcl-news-item h3 {
  font-family: "EB Garamond", Georgia, serif;
  font-size: 1.15rem; font-weight: 600; margin: 0 0 0.4rem; line-height: 1.3;
}
.kngcl-news-item h3 a { color: var(--kc-navy); text-decoration: none; }
.kngcl-news-item h3 a:hover { color: var(--kc-gold-dark); text-decoration: underline; } /* darkened for AA on white */
.kngcl-news-item p { margin: 0; font-size: 0.9rem; color: var(--kc-muted); line-height: 1.55; }

.kngcl-band { padding: 3.25rem 0; background: var(--kc-subtle); border-top: 1px solid var(--kc-line); border-bottom: 1px solid var(--kc-line); }
.kngcl-band h2 { font-family: "EB Garamond", Georgia, serif; font-size: 1.85rem; font-weight: 600; color: var(--kc-navy); margin-bottom: 1rem; }
.kngcl-band p { font-size: 0.95rem; color: var(--kc-muted); line-height: 1.65; }
.kngcl-band-media img {
  border-radius: var(--kc-radius-md);
  box-shadow: var(--kc-shadow-md);
  width: 100%;
  border: 1px solid rgba(13, 34, 64, 0.08);
}
@media (min-width: 992px) { .kngcl-band { padding: 3.75rem 0; } }

.kngcl-band-subheading {
  font-family: "EB Garamond", Georgia, serif;
  color: var(--kc-navy);
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.kngcl-pillars { padding: 3.25rem 0; background: transparent; }
.kngcl-pillar-card {
  background: #fff; border: 1px solid var(--kc-line); border-radius: var(--kc-radius-md);
  overflow: hidden; height: 100%;
  box-shadow: var(--kc-shadow-sm);
  transition: box-shadow 0.3s var(--kc-ease), border-color 0.3s var(--kc-ease), transform 0.3s var(--kc-ease);
}
.kngcl-pillar-card:hover {
  box-shadow: var(--kc-shadow-md);
  border-color: rgba(184, 145, 42, 0.55);
  transform: translateY(-4px);
}
.kngcl-pillar-img {
  width: 100%; height: 200px; object-fit: cover; display: block;
  transition: transform 0.5s var(--kc-ease);
}
.kngcl-pillar-card:hover .kngcl-pillar-img { transform: scale(1.05); }
.kngcl-pillar-body { padding: 1.35rem 1.35rem 1.5rem; }
.kngcl-pillar-body h3 { font-family: "EB Garamond", Georgia, serif; font-size: 1.2rem; font-weight: 600; color: var(--kc-navy); margin: 0 0 0.5rem; }
.kngcl-pillar-body p { font-size: 0.9rem; color: var(--kc-muted); line-height: 1.55; margin-bottom: 1rem; }

.kngcl-partnership {
  padding: 3.25rem 0;
  background:
    radial-gradient(ellipse 70% 80% at 100% 0%, rgba(184, 145, 42, 0.12), transparent 50%),
    linear-gradient(180deg, #0e2748 0%, var(--kc-navy) 100%);
  border-top: 1px solid rgba(184, 145, 42, 0.45);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
.kngcl-partnership h2 { font-family: "EB Garamond", Georgia, serif; font-size: 1.85rem; font-weight: 600; color: #fff; margin-bottom: 0.75rem; }
.kngcl-partnership p { font-size: 0.95rem; color: rgba(255,255,255,0.72); line-height: 1.65; }

/* ─── Homepage strips (replaces inline styles) ─── */
.kngcl-stats-band {
  position: relative;
  padding: 3rem 0;
  background:
    radial-gradient(ellipse 100% 120% at 50% 100%, rgba(184, 145, 42, 0.1), transparent 55%),
    linear-gradient(180deg, #0a1830 0%, var(--kc-navy) 50%, #081629 100%);
  border-top: 1px solid rgba(184, 145, 42, 0.45);
  border-bottom: 1px solid rgba(184, 145, 42, 0.45);
  overflow: hidden;
}
.kngcl-stats-band::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(105deg, transparent 40%, rgba(255, 255, 255, 0.03) 50%, transparent 60%);
  pointer-events: none;
}
.kngcl-stat { position: relative; z-index: 1; }
.kngcl-stat__value {
  font-family: "EB Garamond", Georgia, serif;
  font-size: clamp(2.25rem, 5vw, 3.25rem);
  font-weight: 700;
  color: var(--kc-gold-light);
  line-height: 1;
  letter-spacing: -0.02em;
}
.kngcl-stat__label {
  font-size: 0.72rem;
  color: rgba(255, 255, 255, 0.75);
  margin-top: 0.4rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.kngcl-stats-quote {
  text-align: center;
  margin: 2rem auto 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.95rem;
  font-style: italic;
  font-family: "EB Garamond", Georgia, serif;
  max-width: 42rem;
  line-height: 1.55;
}
.kngcl-stats-quote strong { color: var(--kc-gold-light); font-style: normal; font-family: var(--kc-font-body); font-weight: 600; }

.kngcl-events-preview { padding: 3.25rem 0; background: var(--kc-bg); }
.kngcl-events-preview__item {
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--kc-line);
}
.kngcl-events-preview__item:last-of-type { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.kngcl-events-preview__meta {
  font-size: 0.78rem;
  color: var(--kc-muted);
  margin-bottom: 0.35rem;
  font-weight: 500;
  letter-spacing: 0.02em;
}
.kngcl-events-preview__title {
  font-family: "EB Garamond", Georgia, serif;
  font-size: 1.15rem;
  margin: 0 0 0.35rem;
  font-weight: 600;
  line-height: 1.3;
}
.kngcl-events-preview__title a { color: var(--kc-navy); text-decoration: none; transition: color 0.2s var(--kc-ease); }
.kngcl-events-preview__title a:hover { color: var(--kc-gold-dark); }
.kngcl-events-preview__detail { font-size: 0.85rem; color: var(--kc-muted); margin: 0; }

.kngcl-newsletter-band {
  padding: 2.75rem 0;
  background: linear-gradient(180deg, #faf8f4 0%, var(--kc-subtle) 100%);
  border-top: 1px solid var(--kc-line);
  position: relative;
}
.kngcl-newsletter-band::after {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, rgba(184, 145, 42, 0.35), transparent);
  opacity: 0.9;
}
.kngcl-newsletter-band h2 {
  font-family: "EB Garamond", Georgia, serif;
  color: var(--kc-navy);
  font-size: 1.55rem;
  margin: 0 0 0.4rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.kngcl-newsletter-band .kngcl-newsletter-lead { color: var(--kc-muted); margin: 0; font-size: 0.92rem; line-height: 1.6; }
.kngcl-newsletter-band .form-control {
  border-radius: 999px;
  padding-left: 1.1rem;
  min-height: 46px;
  border-color: rgba(13, 34, 64, 0.12);
  box-shadow: inset 0 1px 2px rgba(13, 34, 64, 0.04);
}

.kngcl-contact-strip {
  padding: 2.75rem 0;
  background: linear-gradient(120deg, #0c1f3a 0%, var(--kc-navy) 55%, #071426 100%);
  border-top: 1px solid rgba(184, 145, 42, 0.45);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
.kngcl-contact-strip h2 {
  font-family: "EB Garamond", Georgia, serif;
  color: #fff;
  font-size: 1.55rem;
  margin: 0 0 0.4rem;
  font-weight: 600;
}
.kngcl-contact-strip p { color: rgba(255, 255, 255, 0.82); margin: 0; font-size: 0.92rem; line-height: 1.55; }
.kngcl-contact-strip a {
  color: #ffffff !important;
  text-decoration: none;
  border-bottom: 1px solid rgba(212, 171, 78, 0.5);
  transition: color 0.2s var(--kc-ease), border-color 0.2s var(--kc-ease);
}
.kngcl-contact-strip a:hover { color: var(--kc-gold-light) !important; border-bottom-color: var(--kc-gold-light); }

/* ─── LINKS & BUTTONS ─── */
/* Exclude mobile bottom bar links — they sit on dark navy and must stay light (global navy here made labels nearly invisible). */
body.kngcl-site a:not(.kngcl-mobile-bottom-nav__link) { color: var(--kc-navy); }
body.kngcl-site a:not(.kngcl-mobile-bottom-nav__link):hover { color: var(--kc-gold-dark); } /* darkened from kc-gold: 2.95:1 → 7.7:1 on white */

/* kngcl-link on LIGHT backgrounds (default — navy text, 15.5:1 on ivory) */
.kngcl-link { color: var(--kc-navy); font-weight: 600; text-decoration: none; border-bottom: 2px solid var(--kc-gold); padding-bottom: 1px; transition: color 0.2s var(--kc-ease), border-color 0.2s var(--kc-ease); }
.kngcl-link:hover { color: var(--kc-gold-dark); }

/* kngcl-link on DARK backgrounds (hero/partnership navy sections — white text, 15.9:1) */
.kngcl-hero .kngcl-link,
.kngcl-partnership .kngcl-link {
  color: #ffffff !important;
  border-bottom-color: var(--kc-gold-light);
}
.kngcl-hero .kngcl-link:hover,
.kngcl-partnership .kngcl-link:hover {
  color: var(--kc-gold-light) !important; /* 7.4:1 on navy */
}

/* Primary / ghost CTAs (hero & dark bands) */
.kngcl-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  font-weight: 600;
  font-size: 0.86rem;
  letter-spacing: 0.02em;
  text-decoration: none !important;
  padding: 0.7rem 1.45rem;
  border-radius: 999px;
  border: 2px solid transparent;
  line-height: 1.2;
  transition: transform 0.25s var(--kc-ease), box-shadow 0.25s var(--kc-ease), background 0.25s var(--kc-ease), color 0.25s var(--kc-ease), border-color 0.25s var(--kc-ease);
}
.kngcl-btn:focus-visible { outline: 2px solid var(--kc-gold-light); outline-offset: 3px; }
.kngcl-btn--primary {
  background: linear-gradient(135deg, #e4c56a 0%, var(--kc-gold) 45%, #9a7322 100%);
  color: #0a1830 !important;
  border-color: rgba(255, 255, 255, 0.2);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.28);
}
.kngcl-btn--primary:hover {
  color: #050d18 !important;
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
}
.kngcl-btn--ghost {
  background: rgba(255, 255, 255, 0.07);
  color: #fff !important;
  border-color: rgba(255, 255, 255, 0.38);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.kngcl-btn--ghost:hover {
  border-color: var(--kc-gold-light);
  color: var(--kc-gold-light) !important;
  background: rgba(255, 255, 255, 0.12);
}

body.kngcl-site .button,
body.kngcl-site button.button {
  background: linear-gradient(135deg, var(--kc-navy) 0%, #0a1830 100%);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.85rem;
  cursor: pointer;
  padding: 0.65rem 1.35rem;
  box-shadow: 0 8px 24px rgba(13, 34, 64, 0.2);
  transition: transform 0.2s var(--kc-ease), box-shadow 0.2s var(--kc-ease), background 0.2s var(--kc-ease), border-color 0.2s var(--kc-ease);
}
body.kngcl-site .button:hover,
body.kngcl-site button.button:hover {
  background: linear-gradient(135deg, var(--kc-gold-light) 0%, var(--kc-gold) 100%);
  border-color: rgba(255, 255, 255, 0.2);
  color: #0a1830;
  transform: translateY(-1px);
  box-shadow: 0 12px 32px rgba(184, 145, 42, 0.35);
}

/* ─── FOOTER ─── */
.main-footer {
  background:
    radial-gradient(ellipse 80% 100% at 50% 0%, rgba(184, 145, 42, 0.08), transparent 55%),
    linear-gradient(180deg, #050d18 0%, var(--kc-navy-dark) 100%);
  border-top: 1px solid rgba(184, 145, 42, 0.45);
  color: rgba(255,255,255,0.68); padding: 3rem 0 1.75rem; font-size: 0.85rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}
.main-footer h4 {
  font-family: var(--kc-font-body);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--kc-gold-light);
  margin-bottom: 0.85rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
/* Must beat body.kngcl-site a:not(.kngcl-mobile-bottom-nav__link) { navy } — that was painting footer links navy on a dark bar (unreadable). */
body.kngcl-site .main-footer a,
body.kngcl-site .main-footer a:visited {
  color: rgba(255, 255, 255, 0.88) !important;
  text-decoration: none;
  transition: color 0.2s var(--kc-ease);
}
body.kngcl-site .main-footer a:hover {
  color: var(--kc-gold-light) !important;
}
.main-footer ul { list-style: none; padding: 0; margin: 0; }
.main-footer ul li { margin-bottom: 0.45rem; }
.main-footer .footer-address {
  color: rgba(255, 255, 255, 0.75);
  font-size: 0.82rem;
  margin-top: 0.6rem;
  line-height: 1.7;
}
.main-footer .footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.1); margin-top: 2.25rem;
  padding-top: 1.15rem; font-size: 0.78rem; color: rgba(255,255,255,0.72); /* raised to 0.72 for WCAG AA */
}
.main-footer .footer-bottom p { margin: 0; }
body.kngcl-site .main-footer .footer-bottom a,
body.kngcl-site .main-footer .footer-bottom a:visited {
  color: rgba(255, 255, 255, 0.78) !important;
}
body.kngcl-site .main-footer .footer-bottom a:hover {
  color: var(--kc-gold-light) !important;
}

/* Subpage footer (.kngcl-site-footer): same global anchor navy was overriding kngcl-pages list colours. */
body.kngcl-site .kngcl-site-footer .kngcl-footer-list a,
body.kngcl-site .kngcl-site-footer .kngcl-footer-list a:visited {
  color: rgba(255, 255, 255, 0.88) !important;
}
body.kngcl-site .kngcl-site-footer .kngcl-footer-list a:hover {
  color: var(--kc-gold-light) !important;
}
body.kngcl-site .kngcl-site-footer .kngcl-footer-meta a,
body.kngcl-site .kngcl-site-footer .kngcl-footer-meta a:visited {
  color: var(--kc-gold-light) !important;
}
body.kngcl-site .kngcl-site-footer .kngcl-footer-meta a:hover {
  color: #fff !important;
}

/* ─── PAGE HEADER (SUBPAGES) ─── */
.kngcl-page-header {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(ellipse 70% 90% at 100% 0%, rgba(184, 145, 42, 0.12), transparent 50%),
    linear-gradient(145deg, var(--kc-navy-dark) 0%, var(--kc-navy) 100%);
  border-bottom: 1px solid rgba(184, 145, 42, 0.5);
  padding: 2.75rem 0 2.15rem;
  box-shadow: 0 20px 60px rgba(8, 22, 41, 0.25);
}
.kngcl-page-header::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
  background-size: 40px 40px;
  opacity: 0.4;
  pointer-events: none;
}
.kngcl-page-header .container { position: relative; z-index: 1; }
.kngcl-page-header .kngcl-eyebrow { color: var(--kc-gold-light); }
.kngcl-page-header h1 {
  font-family: "EB Garamond", Georgia, serif;
  font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 600; color: #fff; line-height: 1.2; margin: 0;
}
.kngcl-page-header p { color: rgba(255,255,255,0.7); font-size: 1rem; line-height: 1.65; margin-top: 0.75rem; }
.kngcl-breadcrumb { font-size: 0.78rem; color: rgba(255,255,255,0.60); /* raised from 0.45 → 0.60 for WCAG AA (7.0:1) */ margin-bottom: 0.75rem; }
.kngcl-breadcrumb a { color: rgba(255,255,255,0.70); text-decoration: none; } /* raised from 0.55 → 0.70 */
.kngcl-breadcrumb a:hover { color: var(--kc-gold-light); }

.kngcl-content-section { padding: 2.5rem 0; }
.kngcl-content-section + .kngcl-content-section { border-top: 1px solid var(--kc-line); }

/* ─── PEOPLE ─── */
.kngcl-person-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1.5rem; }
.kngcl-person-card {
  background: var(--kc-subtle); border: 1px solid var(--kc-line); border-radius: var(--kc-radius-sm);
  overflow: hidden; text-decoration: none; color: inherit; display: block;
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
.kngcl-person-card:hover { box-shadow: 0 8px 28px rgba(13,34,64,0.1); border-color: var(--kc-gold); color: inherit; text-decoration: none; }
.kngcl-person-card img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.kngcl-person-body { padding: 1rem 1.1rem 1.2rem; }
.kngcl-person-body h3 { font-family: "EB Garamond", Georgia, serif; font-size: 1rem; font-weight: 600; color: var(--kc-navy); margin: 0 0 0.25rem; }
.kngcl-person-role { font-size: 0.8rem; color: var(--kc-muted); margin: 0; }

/* ─── PROGRAMMES ─── */
.kngcl-programme-card {
  background: var(--kc-bg); border: 1px solid var(--kc-line); border-radius: var(--kc-radius-sm);
  padding: 1.5rem; margin-bottom: 1.25rem;
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
.kngcl-programme-card:hover { box-shadow: 0 6px 20px rgba(13,34,64,0.08); border-color: var(--kc-gold); }
.kngcl-programme-card h3 { font-family: "EB Garamond", Georgia, serif; font-size: 1.2rem; font-weight: 600; color: var(--kc-navy); margin: 0 0 0.4rem; }
.kngcl-programme-meta { font-size: 0.82rem; color: var(--kc-muted); margin-bottom: 0.75rem; }
.kngcl-tag {
  display: inline-block; background: rgba(13,34,64,0.08); color: var(--kc-navy);
  font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em;
  padding: 2px 8px; border-radius: 2px; margin-right: 6px;
}

/* ─── EVENTS ─── */
.kngcl-event-card { background: var(--kc-bg); border: 1px solid var(--kc-line); border-radius: var(--kc-radius-sm); padding: 1.25rem 1.5rem; margin-bottom: 1rem; }
.kngcl-event-card__meta { font-size: 0.8rem; color: var(--kc-muted); margin-bottom: 0.4rem; }
.kngcl-event-card__meta .fa { color: var(--kc-gold); }
.kngcl-event-card__title { font-family: "EB Garamond", Georgia, serif; font-size: 1.1rem; font-weight: 600; color: var(--kc-navy); margin: 0 0 0.5rem; }
.kngcl-event-card__type { background: rgba(184,145,42,0.12); color: #5c4500; /* darkened from kc-gold for WCAG AA (7.9:1) */ font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; padding: 2px 8px; border-radius: 2px; }
.kngcl-event-card__actions { border-top: 1px solid var(--kc-line); margin-top: 0.75rem; padding-top: 0.75rem; }
.kngcl-event-card__loc--online { color: #1565c0; }
body.kngcl-site .kngcl-events-empty { border-color: var(--kc-line); background: var(--kc-subtle); color: var(--kc-muted); }
body.kngcl-site .kngcl-events-empty strong { color: var(--kc-text); }
body.kngcl-site .kngcl-events-count { color: var(--kc-muted); }

/* ─── FORMS ─── */
body.kngcl-site .form-control { border-radius: 2px; border-color: var(--kc-line); background: #fff; }
body.kngcl-site .form-control:focus { border-color: var(--kc-navy); box-shadow: 0 0 0 3px rgba(13,34,64,0.15); }
body.kngcl-site .kngcl-form-status.alert-success { background: #e8f5e9; border: 1px solid #c8e6c9; color: #1b5e20; }
body.kngcl-site .kngcl-form-status.alert-danger { background: #fff3e0; border: 1px solid #ffe0b2; color: #e65100; }
body.kngcl-site .kngcl-events-search label { color: var(--kc-navy); }
body.kngcl-site .kngcl-events-search input[type="search"] { background: #fff; border-color: var(--kc-line); color: var(--kc-text); }
body.kngcl-site .kngcl-events-search input[type="search"]:focus { border-color: var(--kc-gold); box-shadow: 0 0 0 3px rgba(184,145,42,0.2); }
body.kngcl-site .kngcl-filter-chip { border: 1px solid var(--kc-line); background: var(--kc-subtle); color: var(--kc-text); padding: 4px 12px; border-radius: 20px; font-size: 0.82rem; cursor: pointer; }
body.kngcl-site .kngcl-filter-chip.is-active { background: rgba(13,34,64,0.08); border-color: var(--kc-navy); color: var(--kc-navy); }
body.kngcl-site .kngcl-filter-chip:hover { border-color: var(--kc-gold); color: var(--kc-gold); }
body.kngcl-site .kngcl-filter-fieldset legend { color: var(--kc-navy); font-weight: 600; }
body.kngcl-site .kngcl-programme-meta { color: var(--kc-muted); }
body.kngcl-site .kngcl-outline-label { color: #595959; } /* darkened from #888 (3.5:1) to #595959 (7.0:1) for WCAG AA */
body.kngcl-site .kngcl-programme-empty { color: var(--kc-muted); }

/* ─── SUBPAGE HEADINGS ─── */
body.kngcl-subpage.kngcl-site main h2[id],
body.kngcl-subpage.kngcl-site main h3[id] { scroll-margin-top: 5.5rem; }
/* NOTE: h1/h2 colours on subpages are set per-context in kngcl-pages.css (.kngcl-inner for light content well, .kngcl-hero-compact for dark hero) */
/* kngcl-intro-lead: for light bg (kc-bg/white) */
.kngcl-intro-lead { font-size: 1.1rem; line-height: 1.7; color: var(--kc-muted); }
/* kngcl-intro-lead on dark subpage backgrounds (#172238) — must be light */
body.kngcl-subpage .kngcl-intro-lead { color: rgba(255,255,255,0.85); } /* 11.7:1 on #172238 */
/* Content well (.kngcl-inner) is light ivory — override subpage white text */
body.kngcl-subpage .kngcl-inner .kngcl-intro-lead { color: var(--kc-muted); }
.kngcl-research-stat { text-align: center; }
.kngcl-research-stat strong { font-family: "EB Garamond", Georgia, serif; font-size: 2.5rem; font-weight: 700; color: var(--kc-navy); display: block; }
.kngcl-research-stat span { font-size: 0.85rem; color: var(--kc-muted); }

/* 404 */
.kngcl-404 { padding: 5rem 0; text-align: center; }
.kngcl-404 h1 { font-family: "EB Garamond", Georgia, serif; font-size: 5rem; font-weight: 700; color: var(--kc-navy); line-height: 1; margin-bottom: 1rem; }
.kngcl-404 p { color: var(--kc-muted); font-size: 1.1rem; }

/* ─── MOBILE NAV ─── */
@media screen and (max-width: 950px) {
  body.kngcl-site a.menu-link { float: right; display: block; font-size: 28px; color: var(--kc-gold-light) !important; padding: 1rem 1.25rem 1rem 0; line-height: 1; }
  body.kngcl-site .main-header .logo { padding-right: 0; }
  body.kngcl-site nav#menu.main-nav { clear: both; transition: max-height 0.3s ease-out; }
  body.kngcl-site.js nav#menu.main-nav { overflow: hidden; max-height: 0; float: none; }
  body.kngcl-site nav#menu.main-nav.active { max-height: 85vh; overflow-y: auto; height: auto; }
  body.kngcl-site nav#menu.main-nav ul.main-menu { background-color: var(--kc-navy-dark) !important; border-top: 1px solid rgba(184,145,42,0.2); }
  body.kngcl-site .main-menu { float: none; padding: 0 0 1rem; width: 100%; }
  body.kngcl-site .main-menu > li { display: block; line-height: 1.2; margin: 0; border-bottom: 1px solid rgba(255,255,255,0.07); }
  body.kngcl-site .main-menu > li > a { display: block; padding: 14px 1.25rem !important; border: none !important; border-radius: 0; color: rgba(255,255,255,0.82) !important; }
  body.kngcl-site .main-menu > li > a:hover { color: var(--kc-gold-light) !important; }
  body.kngcl-site .main-menu li.has-submenu > a:after { display: none !important; }
  body.kngcl-site .main-menu li .sub-menu { position: static; opacity: 1 !important; visibility: visible !important; width: 100%; box-shadow: none; border: none !important; background: rgba(0,0,0,0.25) !important; display: none; }
  body.kngcl-site .main-menu li.has-submenu:hover .sub-menu,
  body.kngcl-site .main-menu li.has-submenu:focus-within .sub-menu { display: block; }
  body.kngcl-site .main-menu li .sub-menu li { border-bottom: 1px solid rgba(255,255,255,0.05) !important; margin: 0; padding: 0; }
  body.kngcl-site .main-menu li .sub-menu li a { padding: 12px 1.5rem !important; }
  body.kngcl-site nav#menu.main-nav.active ul.main-menu { padding-bottom: calc(4.5rem + env(safe-area-inset-bottom, 0px)); }
}

body.kngcl-site { --kngcl-mobile-nav-h: 3.35rem; }
@media screen and (min-width: 951px) { body.kngcl-site .kngcl-mobile-bottom-nav { display: none !important; } }
@media screen and (max-width: 950px) {
  body.kngcl-site { padding-bottom: calc(var(--kngcl-mobile-nav-h) + env(safe-area-inset-bottom, 0px)); }
  body.kngcl-site .kngcl-mobile-bottom-nav {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 1001;
    display: flex; align-items: stretch; justify-content: space-between; gap: 2px;
    min-height: var(--kngcl-mobile-nav-h);
    padding: 6px 6px calc(6px + env(safe-area-inset-bottom, 0px));
    background: rgba(8,22,41,0.97);
    border-top: 2px solid var(--kc-gold);
    box-shadow: 0 -6px 28px rgba(0,0,0,0.35);
    backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  }
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link {
    flex: 1 1 0; display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 2px; min-width: 0; padding: 6px 4px; border: none; border-radius: 8px;
    background: transparent;
    color: rgba(255, 255, 255, 0.9) !important; /* strong contrast on #081629 bar; beats page-level anchor rules */
    font-size: 0.63rem; font-weight: 600; text-decoration: none; text-align: center;
    transition: color 0.15s, background-color 0.15s;
  }
  body.kngcl-site .kngcl-mobile-bottom-nav a.kngcl-mobile-bottom-nav__link:visited {
    color: rgba(255, 255, 255, 0.9) !important;
  }
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link:hover:not(:disabled):not([aria-disabled="true"]),
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link:focus-visible:not(:disabled):not([aria-disabled="true"]) {
    color: var(--kc-gold-light) !important;
    background: rgba(184,145,42,0.1);
    outline: none;
  }
  /* Current section (aria-disabled): needs strong contrast on bar + blur; 0.55 white failed audits over composited bg. */
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link:disabled,
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link[aria-disabled="true"] {
    color: #f2f4f8 !important; /* solid light text ~11:1 on #081629 (beats rgba white on blurred stack) */
    background: rgba(184, 145, 42, 0.16) !important; /* gold wash separates from enabled without low-contrast grey */
    cursor: default;
    pointer-events: none;
  }
  body.kngcl-site .kngcl-mobile-bottom-nav a.kngcl-mobile-bottom-nav__link[aria-disabled="true"]:visited {
    color: #f2f4f8 !important;
  }
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link:disabled:hover,
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link:disabled:focus-visible,
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link[aria-disabled="true"]:hover,
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link[aria-disabled="true"]:focus-visible {
    color: #f2f4f8 !important;
    background: rgba(184, 145, 42, 0.16) !important;
  }
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__icon {
    display: flex; align-items: center; justify-content: center; font-size: 1.15rem; line-height: 1;
    color: inherit !important;
    transition: color 0.15s, transform 0.15s;
  }
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__icon .fa {
    color: inherit !important;
  }
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link--active .kngcl-mobile-bottom-nav__icon {
    transform: scale(1.06);
  }
  body.kngcl-site .kngcl-mobile-bottom-nav__label {
    max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    color: inherit;
  }
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link--menu.kngcl-mobile-bottom-nav__link--open {
    color: var(--kc-gold-light) !important;
    background: rgba(184,145,42,0.1);
  }
  body.kngcl-site .kngcl-mobile-bottom-nav .kngcl-mobile-bottom-nav__link--menu.kngcl-mobile-bottom-nav__link--open .kngcl-mobile-bottom-nav__icon {
    color: inherit !important;
  }
}
@media print { body.kngcl-site .kngcl-mobile-bottom-nav { display: none !important; } body.kngcl-site { padding-bottom: 0 !important; } }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .kngcl-feature-card,
  .kngcl-feature-card img,
  .kngcl-pillar-card,
  .kngcl-pillar-img,
  .kngcl-news-item,
  .kngcl-btn,
  body.kngcl-site .button,
  body.kngcl-site button.button {
    transition: none !important;
  }
  .kngcl-feature-card:hover,
  .kngcl-pillar-card:hover,
  .kngcl-news-item:hover {
    transform: none !important;
  }
  .kngcl-feature-card:hover img,
  .kngcl-pillar-card:hover .kngcl-pillar-img {
    transform: none !important;
  }
}
