:root {
  /* Navigation, headings, buttons, links — main brand colour */
  --color-primary: #1a3a6b;
  /* Hover/active states for primary elements */
  --color-primary-dark: #0f2347;
  /* Slightly lighter shade of primary, used for gradients and mid-tone accents */
  --color-primary-mid: #1e4480;
  /* Decorative highlights, card borders, badge backgrounds */
  --color-secondary: #c8a951;
  /* Lighter secondary tint — hover states, subtle fills */
  --color-secondary-light: #d9c07e;
  /* Darker secondary tint — active states, icon fills */
  --color-secondary-dark: #a8893a;
  /* Special visual highlights — Luther Rose ornament, warnings */
  --color-accent: #8b1a1a;
  /* Page background — typically white or very light */
  --color-background: #ffffff;
  /* Section and card backgrounds, blockquotes */
  --color-surface: #f8f6f1;
  /* Alternating row fills, secondary card backgrounds */
  --color-surface-alt: #f0ece3;
  /* Main body text colour */
  --color-text: #1a1a1a;
  /* Secondary text — dates, authors, captions, file sizes */
  --color-text-muted: #5a5a5a;
  /* Input borders, dividers, card outlines */
  --color-border: #d8d0c0;
  --font-heading: 'Playfair Display', Georgia, serif;
  --font-body: 'Source Serif 4', Georgia, serif;
  --font-ui: 'Source Sans 3', system-ui, sans-serif;
  --navbar-height: 72px;
  --sidebar-width: 300px;
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, .10), 0 2px 6px rgba(0, 0, 0, .07);
  --shadow-lg: 0 10px 30px rgba(0, 0, 0, .13), 0 4px 10px rgba(0, 0, 0, .08);
  --shadow-xl: 0 20px 50px rgba(0, 0, 0, .18);
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;
  --transition-fast: 0.15s ease;
  --transition-base: 0.25s ease;
  --transition-slow: 0.4s ease;
  --transition-reveal: 0.6s cubic-bezier(0.22, 1, 0.36, 1);
  --font-display: var(--font-heading);
  --font-serif: var(--font-body);
  --font-sans: var(--font-ui)
}

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

html {
  scroll-behavior: smooth;
  font-size: 16px;
  -webkit-text-size-adjust: 100%
}

body {
  font-family: var(--font-body);
  font-weight: 400;
  color: var(--color-text);
  background: var(--color-background);
  line-height: 1.7;
  overflow-x: hidden;
  min-height: 100vh;
  display: flex;
  flex-direction: column
}

main#main-content {
  flex: 1
}

img {
  max-width: 100%;
  display: block
}

a {
  color: inherit;
  text-decoration: none
}

ul,
ol {
  list-style: none
}

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit
}

input,
textarea,
select {
  font-family: inherit
}

.container {
  max-width: 1200px;
  margin: 0 auto
}

.section-block {
  padding: 6rem 1.5rem
}

@media (max-width:768px) {
  .section-block {
    padding: 4rem 1.25rem
  }
}

.badge {
  display: inline-block;
  font-weight: 600;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.04em
}

.u-label {
  font-family: var(--font-ui);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em
}

.u-flex-center {
  display: flex;
  align-items: center;
  justify-content: center
}

.form-control {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--color-border);
  background: var(--color-background);
  border-radius: var(--radius-sm);
  font-size: 0.95rem;
  transition: border-color var(--transition-base), box-shadow var(--transition-base)
}

.form-control:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(26, 58, 107, 0.12)
}

.empty-state {
  display: none;
  text-align: center;
  padding: 3rem 1.5rem
}

.empty-state.is-visible {
  display: block
}

.empty-state p {
  color: var(--color-text-muted);
  font-size: 0.95rem
}

.empty-state--staff {
  padding: 4rem 2rem
}

[data-hidden] {
  display: none !important
}

.u-gold-border {
  border-left: 4px solid var(--color-secondary);
  padding-left: 1rem
}

.sticky-bar {
  position: sticky;
  top: var(--navbar-height);
  z-index: 50;
  border-bottom: 1px solid var(--color-border)
}

.event-date {
  flex-shrink: 0;
  text-align: center;
  background: var(--color-secondary);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  align-self: flex-start
}

.event-location {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-ui);
  font-size: 0.82rem
}

.skip-link {
  position: absolute;
  top: -100%;
  left: 1rem;
  z-index: 9999;
  padding: 0.75rem 1.5rem;
  background: var(--color-secondary);
  color: var(--color-primary-dark);
  font-family: var(--font-ui);
  font-weight: 600;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  transition: top var(--transition-fast)
}

.skip-link:focus {
  top: 0
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0
}

*:focus-visible {
  outline: 3px solid var(--color-secondary);
  outline-offset: 3px
}

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity var(--transition-reveal), transform var(--transition-reveal)
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0)
}

@media (prefers-reduced-motion:reduce) {
  .reveal {
    opacity: 1;
    transform: none;
    transition: none
  }

  html {
    scroll-behavior: auto
  }
}

.section-title {
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.2;
  margin-bottom: 0.5rem
}

.section-title--light {
  color: var(--color-background)
}

.section-subtitle {
  font-family: var(--font-ui);
  font-size: 1rem;
  color: var(--color-text-muted);
  margin-bottom: 2.5rem
}

.section-subtitle--light {
  color: rgba(255, 255, 255, 0.7)
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.8rem 2rem;
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 0.95rem;
  border-radius: var(--radius-sm);
  transition: all var(--transition-base);
  letter-spacing: 0.02em
}

.btn--primary {
  background: var(--color-secondary);
  color: var(--color-primary-dark)
}

.btn--primary:hover,
.btn--primary:focus-visible {
  background: var(--color-secondary-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(200, 169, 81, 0.4)
}

.btn--outline {
  background: transparent;
  color: var(--color-background);
  border: 2px solid rgba(255, 255, 255, 0.5)
}

.btn--outline:hover,
.btn--outline:focus-visible {
  border-color: var(--color-secondary);
  color: var(--color-secondary);
  transform: translateY(-2px)
}

.sidebar-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(10, 26, 48, 0.6);
  backdrop-filter: blur(4px);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-slow)
}

.sidebar-overlay.is-active {
  opacity: 1;
  pointer-events: auto
}

.sidebar {
  position: fixed;
  left: 0;
  top: 0;
  width: var(--sidebar-width);
  height: 100vh;
  z-index: 300;
  background: var(--color-primary-dark);
  transform: translateX(-100%);
  transition: transform 0.35s ease;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-xl)
}

.sidebar.is-open {
  transform: translateX(0)
}

.sidebar__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem 1.5rem 1.25rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1)
}

.sidebar__logo {
  display: flex;
  align-items: center;
  gap: 1rem
}

.sidebar__logo-img {
  height: 48px;
  width: auto;
  display: block;
  object-fit: contain
}

.sidebar__logo-cross {
  display: block;
  width: 28px;
  height: 28px;
  position: relative;
  flex-shrink: 0
}

.sidebar__logo-cross::before,
.sidebar__logo-cross::after {
  content: '';
  position: absolute;
  background: var(--color-secondary);
  border-radius: 2px
}

.sidebar__logo-cross::before {
  width: 4px;
  height: 28px;
  left: 50%;
  top: 0;
  transform: translateX(-50%)
}

.sidebar__logo-cross::after {
  width: 22px;
  height: 4px;
  left: 50%;
  top: 35%;
  transform: translateX(-50%)
}

.sidebar__logo-text {
  font-family: var(--font-heading);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-background);
  line-height: 1.3
}

.sidebar__close {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background var(--transition-fast);
  position: relative
}

.sidebar__close:hover {
  background: rgba(255, 255, 255, 0.1)
}

.sidebar__close span {
  position: absolute;
  width: 18px;
  height: 2px;
  background: var(--color-background);
  border-radius: 2px
}

.sidebar__close span:first-child {
  transform: rotate(45deg)
}

.sidebar__close span:last-child {
  transform: rotate(-45deg)
}

.sidebar__nav {
  flex: 1;
  padding: 1.5rem 0;
  overflow-y: auto
}

.sidebar__link {
  display: block;
  padding: 0.9rem 1.75rem;
  font-family: var(--font-ui);
  font-size: 1rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.85);
  transition: all var(--transition-base);
  border-left: 3px solid transparent
}

.sidebar__link:hover,
.sidebar__link:focus-visible {
  color: var(--color-secondary);
  border-left-color: var(--color-secondary);
  background: rgba(255, 255, 255, 0.05);
  padding-left: 2.1rem
}

.sidebar__footer {
  padding: 1.25rem 1.75rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  font-family: var(--font-ui);
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.35)
}

/* ── Announcement bar ───────────────────────────────────────────────────── */

.announcement-bar-container {
  position: sticky;
  top: 0;
  z-index: 200;
}

.announcement-bar {
  padding: 0.6rem 0;
  font-family: var(--font-ui);
  font-size: 0.875rem;
  line-height: 1.4;
}

.announcement-bar--info {
  background: var(--color-primary);
  color: var(--color-background);
}

.announcement-bar--warning {
  background: var(--color-secondary);
  color: var(--color-primary-dark);
}

.announcement-bar--urgent {
  background: var(--color-accent);
  color: var(--color-background);
}

.announcement-bar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.announcement-bar__text {
  margin: 0;
  flex: 1;
}

.announcement-bar__dismiss {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: none;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.15);
  color: inherit;
  cursor: pointer;
  transition: background var(--transition-fast);
}

.announcement-bar__dismiss:hover,
.announcement-bar__dismiss:focus-visible {
  background: rgba(255, 255, 255, 0.3);
  outline: none;
}

.announcement-bar--warning .announcement-bar__dismiss {
  background: rgba(0, 0, 0, 0.1);
}

.announcement-bar--warning .announcement-bar__dismiss:hover,
.announcement-bar--warning .announcement-bar__dismiss:focus-visible {
  background: rgba(0, 0, 0, 0.2);
}

/* ── Navbar ─────────────────────────────────────────────────────────────── */

.navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  height: var(--navbar-height);
  transition: background var(--transition-slow), box-shadow var(--transition-slow), backdrop-filter var(--transition-slow);
  background: rgba(10, 26, 48, 0.1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px)
}

.navbar--scrolled {
  background: var(--color-primary-dark);
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.25);
  backdrop-filter: none;
  -webkit-backdrop-filter: none
}

.navbar__inner {
  height: 100%;
  padding: 0 1.5rem;
  display: flex;
  align-items: center;
  gap: 1.5rem
}

.navbar__hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
  transition: background var(--transition-fast)
}

.navbar__hamburger:hover {
  background: rgba(255, 255, 255, 0.1)
}

.navbar__brand {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  text-decoration: none
}

.navbar__brand-img {
  height: 36px;
  width: auto;
  display: block;
  object-fit: contain
}

.navbar__brand-text {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-background);
  letter-spacing: 0.02em
}

.navbar__hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-background);
  border-radius: 2px;
  transition: all 0.3s ease;
  transform-origin: center
}

.navbar__hamburger.is-active span:nth-child(1) {
  transform: translateY(7px) rotate(45deg)
}

.navbar__hamburger.is-active span:nth-child(2) {
  opacity: 0;
  transform: scaleX(0)
}

.navbar__hamburger.is-active span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg)
}

.navbar__nav {
  flex: 1;
  display: flex;
  justify-content: center
}

.navbar__nav > ul {
  display: flex;
  gap: 0.25rem;
  align-items: center
}

.navbar__link {
  display: block;
  padding: 0.5rem 1rem;
  font-family: var(--font-ui);
  font-size: 0.9rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.9);
  letter-spacing: 0.03em;
  position: relative;
  transition: color var(--transition-base)
}

.navbar__link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 1rem;
  right: 1rem;
  height: 2px;
  background: var(--color-secondary);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-base)
}

.navbar__link:hover,
.navbar__link:focus-visible {
  color: var(--color-secondary)
}

.navbar__link:hover::after,
.navbar__link:focus-visible::after {
  transform: scaleX(1)
}

.navbar__nav > ul > li {
  position: relative
}

.navbar__link--parent {
  display: flex;
  align-items: center;
  gap: 0.3rem
}

.navbar__sub-arrow {
  font-size: 0.7em;
  line-height: 1;
  transition: transform var(--transition-fast)
}

.navbar__nav > ul > li.is-open > a > .navbar__sub-arrow {
  transform: rotate(180deg)
}

.navbar__dropdown-sub {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 110;
  min-width: 200px;
  list-style: none;
  padding: 0.4rem 0;
  background: #faf8f5;
  border-top: 2px solid var(--color-secondary);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  box-shadow: var(--shadow-md)
}

.navbar__nav > ul > li.is-open > .navbar__dropdown-sub {
  display: block
}

.navbar__dropdown-sub .navbar__dropdown-link {
  display: block;
  padding: 0.6rem 1.25rem;
  color: var(--color-primary-dark);
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 500;
  white-space: nowrap;
  transition: color var(--transition-fast), background var(--transition-fast)
}

.navbar__dropdown-sub .navbar__dropdown-link:hover,
.navbar__dropdown-sub .navbar__dropdown-link:focus-visible {
  color: var(--color-primary);
  background: var(--color-surface-alt)
}

.navbar__search {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0
}

.navbar__search-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  color: rgba(255, 255, 255, 0.9);
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast)
}

.navbar__search-toggle:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--color-secondary)
}

.navbar__search-field {
  display: flex;
  align-items: center;
  overflow: hidden;
  max-width: 0;
  opacity: 0;
  transition: max-width 0.3s ease, opacity 0.3s ease
}

.navbar__search-field.is-open {
  max-width: 260px;
  opacity: 1
}

.navbar__search-field input {
  width: 220px;
  padding: 0.45rem 0.75rem;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.25);
  border-radius: var(--radius-sm) 0 0 var(--radius-sm);
  color: var(--color-background);
  font-size: 0.875rem;
  outline: none;
  transition: border-color var(--transition-fast)
}

.navbar__search-field input::placeholder {
  color: rgba(255, 255, 255, 0.5)
}

.navbar__search-field input:focus {
  border-color: var(--color-secondary);
  background: rgba(255, 255, 255, 0.18)
}

.navbar__search-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.25);
  border-left: none;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  color: rgba(255, 255, 255, 0.7);
  transition: all var(--transition-fast)
}

.navbar__search-close:hover {
  background: var(--color-accent);
  color: var(--color-background)
}

.navbar__dropdown-toggle {
  display: none
}

.navbar__dropdown {
  display: none
}

.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 45%, var(--color-primary-mid) 70%, var(--color-primary-dark) 100%)
}

.hero__bg {
  position: absolute;
  inset: 0;
  pointer-events: none
}

.hero__cross {
  position: absolute;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 2px
}

.hero__cross--h {
  width: 100%;
  height: 2px;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  background: linear-gradient(to right, transparent, rgba(200, 169, 81, 0.15), transparent)
}

.hero__cross--v {
  width: 2px;
  height: 100%;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  background: linear-gradient(to bottom, transparent, rgba(200, 169, 81, 0.15), transparent)
}

.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 70% at 30% 50%, color-mix(in srgb, var(--color-primary) 60%, transparent) 0%, transparent 70%), radial-gradient(ellipse 40% 50% at 70% 30%, color-mix(in srgb, var(--color-accent) 10%, transparent) 0%, transparent 60%);
  pointer-events: none
}

.hero__content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 2rem 1.5rem;
  max-width: 900px
}

.hero__eyebrow {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-secondary);
  margin-bottom: 1rem
}

.hero__title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 5.5vw, 4rem);
  font-weight: 900;
  color: var(--color-background);
  line-height: 1.4;
  margin-bottom: 1.25rem;
  text-shadow: 0 2px 20px rgba(0, 0, 0, 0.3)
}

.hero__subtitle {
  font-family: var(--font-body);
  font-size: clamp(1rem, 2vw, 1.4rem);
  font-weight: 300;
  color: var(--color-secondary-light);
  font-style: italic;
  margin-bottom: 2.5rem;
  letter-spacing: 0.02em
}

.hero__actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap
}

.hero__scroll {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2
}

.hero__scroll span {
  display: block;
  width: 24px;
  height: 40px;
  border: 2px solid rgba(255, 255, 255, 0.35);
  border-radius: 12px;
  position: relative
}

.hero__scroll span::after {
  content: '';
  position: absolute;
  width: 4px;
  height: 8px;
  background: var(--color-secondary);
  border-radius: 2px;
  top: 6px;
  left: 50%;
  transform: translateX(-50%);
  animation: scrollBounce 2s ease-in-out infinite
}

@keyframes scrollBounce {

  0%,
  100% {
    transform: translateX(-50%) translateY(0);
    opacity: 1
  }

  50% {
    transform: translateX(-50%) translateY(10px);
    opacity: 0.3
  }
}

/* Hero slideshow images */
.hero__bg-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  pointer-events: none
}

.hero__bg-image.is-active {
  opacity: 1
}

/* Hero arrow navigation */
.hero__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  background: rgba(0, 0, 0, 0.3);
  color: #fff;
  border: none;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s, background 0.2s
}

.hero:hover .hero__arrow,
.hero:focus-within .hero__arrow {
  opacity: 1
}

.hero__arrow:hover {
  background: rgba(0, 0, 0, 0.6)
}

.hero__arrow--prev {
  left: 1.5rem
}

.hero__arrow--next {
  right: 1.5rem
}

/* Hero dot indicators */
.hero__dots {
  position: absolute;
  bottom: 5rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  gap: 0.5rem
}

.hero__dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.6);
  background: transparent;
  cursor: pointer;
  transition: background 0.3s, border-color 0.3s;
  padding: 0
}

.hero__dot.is-active {
  background: var(--color-secondary);
  border-color: var(--color-secondary)
}

@media (max-width: 768px) {
  .hero__arrow {
    width: 36px;
    height: 36px
  }

  .hero__arrow--prev {
    left: 0.75rem
  }

  .hero__arrow--next {
    right: 0.75rem
  }

  .hero__dots {
    bottom: 4rem
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero__bg-image {
    transition: none
  }
}

.featured {
  background: var(--color-surface)
}

.featured__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center
}

.featured__image-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-mid) 50%, #3a6ba8 100%);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  position: relative;
  overflow: hidden
}

.featured__image-placeholder::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom right, rgba(200, 169, 81, 0.12) 0%, transparent 50%, rgba(139, 26, 26, 0.08) 100%)
}

.featured__content {
  padding-left: 2.5rem;
  border-left: 4px solid var(--color-secondary)
}

.featured__meta {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 1.25rem;
  font-family: var(--font-ui);
  font-size: 0.83rem
}

.featured__date {
  color: var(--color-text-muted)
}

.featured__category {
  background: var(--color-primary);
  color: var(--color-secondary);
  padding: 0.2rem 0.75rem;
  font-size: 0.78rem
}

.featured__author {
  color: var(--color-text-muted)
}

.featured__author::before {
  content: '— '
}

.featured__title {
  font-family: var(--font-heading);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.3;
  margin-bottom: 1.1rem
}

.featured__excerpt {
  font-size: 1rem;
  color: var(--color-text-muted);
  line-height: 1.75;
  margin-bottom: 1.5rem
}

.featured__link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--color-primary);
  border-bottom: 2px solid var(--color-secondary);
  padding-bottom: 2px;
  transition: color var(--transition-base), gap var(--transition-base)
}

.featured__link:hover,
.featured__link:focus-visible {
  color: var(--color-secondary-dark);
  gap: 0.7rem
}

.articles {
  background: var(--color-background)
}

.articles__header {
  margin-bottom: 2.5rem
}

.articles__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem
}

.card {
  position: relative;
  background: var(--color-background);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: box-shadow var(--transition-base), transform var(--transition-base)
}

.card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px)
}

.card[data-card] {
  display: none
}

.card[data-card].is-active {
  display: block
}

.card__image-link {
  display: block;
  overflow: hidden
}

.card__image {
  width: 100%;
  aspect-ratio: 16 / 9;
  background-size: cover;
  background-position: center;
  transition: transform 0.5s ease
}

.card:hover .card__image {
  transform: scale(1.03)
}

.card__image--1 {
  background: linear-gradient(135deg, #a8c8e8 0%, #7eb8d0 100%)
}

.card__image--2 {
  background: linear-gradient(135deg, #b5d4e8 0%, #8cc0d9 100%)
}

.card__image--3 {
  background: linear-gradient(135deg, #e8d5a0 0%, #d4b87a 100%)
}

.card__image--4 {
  background: linear-gradient(135deg, #d4a89a 0%, #c08070 100%)
}

.card__image--5 {
  background: linear-gradient(135deg, #a0c8b8 0%, #7ab8a0 100%)
}

.card__image--6 {
  background: linear-gradient(135deg, #c8a8d4 0%, #b090c0 100%)
}

.card__image--7 {
  background: linear-gradient(135deg, #8aacc8 0%, #6890b0 100%)
}

.card__image--8 {
  background: linear-gradient(135deg, #a0d0a8 0%, #80b888 100%)
}

.card__image--9 {
  background: linear-gradient(135deg, #c8a0b8 0%, #b080a0 100%)
}

.card__image--10 {
  background: linear-gradient(135deg, #90b8d0 0%, #70a0b8 100%)
}

.card__image--11 {
  background: linear-gradient(135deg, #a8b8c8 0%, #8898a8 100%)
}

.card__image--12 {
  background: linear-gradient(135deg, #d8c8a0 0%, #c0a870 100%)
}

.card__body {
  padding: 1.25rem 1.5rem 2.75rem
}

.card__meta {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  margin-bottom: 0.75rem;
  font-family: var(--font-ui);
  font-size: 0.8rem;
  color: var(--color-text-muted)
}

.card__category {
  position: relative;
  z-index: 1;
  background: var(--color-surface-alt);
  color: var(--color-primary);
  padding: 0.15rem 0.6rem;
  font-size: 0.75rem
}

.card__title {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 0.6rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden
}

.card__title a {
  color: var(--color-primary);
  transition: color var(--transition-base)
}

.card__title a::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0
}

.card__title a:hover,
.card__title a:focus-visible {
  color: var(--color-secondary-dark)
}

.card__excerpt {
  font-size: 0.9rem;
  color: var(--color-text-muted);
  line-height: 1.65;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden
}

.card__read-more {
  position: absolute;
  z-index: 1;
  bottom: 0;
  right: 0;
  padding: 0.45rem 1.1rem;
  background: var(--color-primary);
  color: var(--color-background);
  font-family: var(--font-ui);
  font-size: 0.8rem;
  font-weight: 600;
  border-radius: var(--radius-sm) 0 0 0;
  text-decoration: none;
  transition: background var(--transition-base), color var(--transition-base)
}

.card__read-more:hover,
.card__read-more:focus-visible {
  background: var(--color-secondary);
  color: var(--color-primary)
}

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 3rem
}

.pagination__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm);
  color: var(--color-primary);
  border: 1px solid var(--color-border);
  transition: all var(--transition-base);
  font-family: var(--font-ui)
}

.pagination__btn:hover:not(:disabled) {
  background: var(--color-primary);
  color: var(--color-background);
  border-color: var(--color-primary)
}

.pagination__btn:disabled {
  opacity: 0.35;
  cursor: not-allowed
}

.pagination__pages {
  display: flex;
  gap: 0.25rem
}

.pagination__page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 0.5rem;
  border-radius: var(--radius-sm);
  font-family: var(--font-ui);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-primary);
  border: 1px solid var(--color-border);
  transition: all var(--transition-base);
  cursor: pointer;
  background: none
}

.pagination__page:hover,
.pagination__page:focus-visible,
.pagination__page.is-active {
  background: var(--color-primary);
  color: var(--color-background);
  border-color: var(--color-primary)
}

.events {
  background: var(--color-primary)
}

.events__header {
  margin-bottom: 3rem
}

.events__body {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 3rem;
  align-items: start
}

.calendar {
  background: var(--color-primary-dark);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  box-shadow: var(--shadow-lg)
}

.calendar__nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem
}

.calendar__nav-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  color: rgba(255, 255, 255, 0.7);
  transition: all var(--transition-base)
}

.calendar__nav-btn:hover,
.calendar__nav-btn:focus-visible {
  background: rgba(255, 255, 255, 0.1);
  color: var(--color-secondary)
}

.calendar__month {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-background);
  text-align: center
}

.calendar__weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  margin-bottom: 0.5rem
}

.calendar__weekdays span {
  text-align: center;
  font-family: var(--font-ui);
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.4);
  padding: 0.4rem 0;
  letter-spacing: 0.05em
}

.calendar__days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px
}

.calendar__day {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: rgba(255, 255, 255, 0.65);
  border-radius: 50%;
  cursor: default;
  transition: all var(--transition-fast);
  position: relative
}

.calendar__day--empty {
  pointer-events: none
}

.calendar__day--today {
  color: var(--color-background);
  font-weight: 600;
  border: 2px solid var(--color-primary-mid)
}

.calendar__day--event {
  background: var(--color-secondary);
  color: var(--color-primary-dark);
  font-weight: 700;
  cursor: pointer
}

.calendar__day--event:hover,
.calendar__day--event:focus-visible {
  background: var(--color-secondary-light);
  transform: scale(1.1)
}

/* Home calendar — school calendar entry squares with arrow shapes */
.calendar__day--cal-start,
.calendar__day--cal-middle,
.calendar__day--cal-end {
  border-radius: 0
}

.calendar__day--cal-holiday {
  background-color: rgba(196, 30, 58, 0.65);
  color: #fff
}

.calendar__day--cal-exam_period {
  background-color: rgba(160, 110, 0, 0.72);
  color: #fff
}

/* Start cell: outward ">" notch on left edge */
.calendar__day--cal-start {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 30% 50%)
}

/* End cell: outward ">" arrow on right edge */
.calendar__day--cal-end {
  clip-path: polygon(0 0, 70% 0, 100% 50%, 70% 100%, 0 100%)
}

/* Single-day entry: colored rounded square, no arrow */
.calendar__day--cal-single {
  border-radius: 3px
}

.events__list {
  display: flex;
  flex-direction: column
}

.event-item {
  display: flex;
  gap: 1.5rem;
  padding: 1.5rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  transition: background var(--transition-base)
}

.event-item:first-child {
  padding-top: 0
}

.event-item__date {
  width: 56px;
  padding: 0.5rem 0
}

.event-item__day {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 900;
  color: var(--color-primary-dark);
  line-height: 1
}

.event-item__month {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 2px
}

.event-item__content {
  flex: 1
}

.event-item__title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-background);
  margin-bottom: 0.4rem;
  line-height: 1.3
}

.event-item__desc {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.6;
  margin-bottom: 0.5rem
}

.event-item__location {
  gap: 0.35rem;
  font-size: 0.78rem;
  color: var(--color-secondary);
  font-weight: 600
}


/* Double-wide date badge for multi-day calendar entries */
.events__list .event-date--range {
  width: auto;
  flex-direction: row;
  gap: 0.4rem;
  padding: 0.5rem 0.75rem
}

.events__list .event-date__col {
  display: flex;
  flex-direction: column;
  align-items: center
}

.events__list .event-date__sep {
  align-self: center;
  font-size: 1rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.55);
  line-height: 1
}

/* Period-type colors on date badges */
.events__list .event-date--holiday {
  background: var(--color-accent)
}

.events__list .event-date--exam_period {
  background: var(--color-secondary)
}

/* Calendar tooltip */
.cal-tooltip {
  position: fixed;
  z-index: 9000;
  background: #fff;
  color: var(--color-primary-dark);
  border-radius: 6px;
  padding: 0.6rem 1rem;
  font-size: 1.1rem;
  line-height: 1.45;
  max-width: 300px;
  pointer-events: none;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3)
}

.cal-tooltip[hidden] {
  display: none
}

.cal-tooltip__title {
  font-family: var(--font-heading);
  font-weight: 700;
  margin-bottom: 0.15rem
}

.cal-tooltip__dates {
  font-size: 1.04rem;
  color: #555
}

.cal-tooltip__event {
  font-size: 1.04rem;
  padding: 0.15rem 0;
  border-top: 1px solid #ccc
}

.cal-tooltip__event:first-child {
  border-top: none
}

.cal-tooltip__more {
  font-size: 1rem;
  color: #888;
  margin-top: 0.2rem;
  border-top: 1px solid #ccc;
  padding-top: 0.15rem
}


.gallery {
  background: var(--color-background)
}

.gallery__header {
  margin-bottom: 2.5rem
}

.gallery__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem
}

.gallery-card {
  display: block;
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  transition: box-shadow var(--transition-base)
}

.gallery-card:hover {
  box-shadow: var(--shadow-xl)
}

.gallery-card__image {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 0.5s ease
}

.gallery-card:hover .gallery-card__image {
  transform: scale(1.08)
}

.gallery-card__image--1 {
  background: linear-gradient(135deg, #1a3a6b 0%, #c8a951 100%)
}

.gallery-card__image--2 {
  background: linear-gradient(135deg, #0f2347 0%, #2a5f9e 100%)
}

.gallery-card__image--3 {
  background: linear-gradient(135deg, #6e1e1e 0%, #c8a951 100%)
}

.gallery-card__image--4 {
  background: linear-gradient(135deg, #512e5f 0%, #1a3a6b 100%)
}

.gallery-card__image--5 {
  background: linear-gradient(135deg, #1a5e2a 0%, #a5d6a7 100%)
}

.gallery-card__image--6 {
  background: linear-gradient(135deg, #4a235a 0%, #c8a951 100%)
}

.gallery-card__image--7 {
  background: linear-gradient(135deg, #7e5109 0%, #1a3a6b 100%)
}

.gallery-card__image--8 {
  background: linear-gradient(135deg, #2e4053 0%, #85929e 100%)
}

.gallery-card__image--9 {
  background: linear-gradient(135deg, #1a3a6b 0%, #c8a951 100%)
}

.gallery-card__image--10 {
  background: linear-gradient(135deg, #0f2347 0%, #1a3a6b 100%)
}

.gallery-card__image--11 {
  background: linear-gradient(135deg, #0d2b1a 0%, #2e7d32 100%)
}

.gallery-card__image--12 {
  background: linear-gradient(135deg, #6e1e1e 0%, #c8a951 100%)
}

.gallery-card__image--13 {
  background: linear-gradient(135deg, #512e5f 0%, #1a3a6b 100%)
}

.gallery-card__image--14 {
  background: linear-gradient(135deg, #1a5e2a 0%, #a5d6a7 100%)
}

.gallery-card__image--15 {
  background: linear-gradient(135deg, #4a235a 0%, #c8a951 100%)
}

.gallery-card__image--16 {
  background: linear-gradient(135deg, #7e5109 0%, #1a3a6b 100%)
}

.gallery-card__image--17 {
  background: linear-gradient(135deg, #1a3a6b 0%, #2e86c1 100%)
}

.gallery-card__image--18 {
  background: linear-gradient(135deg, #1a5276 0%, #2980b9 100%)
}

.gallery-card__image--19 {
  background: linear-gradient(135deg, #6e1e1e 0%, #8b1a1a 100%)
}

.gallery-card__image--20 {
  background: linear-gradient(135deg, #7e5109 0%, #c8a951 100%)
}

.gallery-card__image--21 {
  background: linear-gradient(135deg, #2e4053 0%, #1a3a6b 100%)
}

.gallery-card__image--22 {
  background: linear-gradient(135deg, #0f2347 0%, #512e5f 100%)
}

.gallery-card__image--23 {
  background: linear-gradient(135deg, #1c5e20 0%, #2e7d32 100%)
}

.gallery-card__image--24 {
  background: linear-gradient(135deg, #2e4053 0%, #85929e 100%)
}

.gallery-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10, 26, 48, 0.85) 0%, rgba(10, 26, 48, 0.1) 55%, transparent 100%);
  transition: background var(--transition-slow)
}

.gallery-card:hover .gallery-card__overlay {
  background: linear-gradient(to top, rgba(10, 26, 48, 0.92) 0%, rgba(10, 26, 48, 0.25) 55%, rgba(10, 26, 48, 0.05) 100%)
}

.gallery-card__info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1.25rem 1.25rem 1rem
}

.gallery-card__title {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-background);
  margin-bottom: 0.25rem
}

.gallery-card__count {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  color: var(--color-secondary);
  font-weight: 600
}

.documents {
  background: var(--color-surface)
}

.documents__inner {
  max-width: 900px;
  margin: 0 auto
}

.documents__header {
  margin-bottom: 2.5rem
}

.documents__list {
  display: flex;
  flex-direction: column
}

.doc-item {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 1.1rem 1.25rem 1.1rem 1rem;
  background: var(--color-background);
  border: 1px solid var(--color-border);
  border-left: 3px solid transparent;
  border-radius: var(--radius-sm);
  margin-bottom: 0.625rem;
  transition: all var(--transition-base);
  color: var(--color-text);
  position: relative;
  left: 0
}

.doc-item:hover,
.doc-item:focus-visible {
  border-left-color: var(--color-secondary);
  left: 3px;
  box-shadow: var(--shadow-md);
  background: var(--color-background)
}

.doc-item:last-child {
  margin-bottom: 0
}

.doc-item__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0
}

.doc-item__icon svg {
  width: 22px;
  height: 22px
}

.doc-item__icon--pdf {
  background: #fde8e8;
  color: #c0392b
}

.doc-item__icon--doc {
  background: #dbeafe;
  color: #1d4ed8
}

.doc-item__icon--xls {
  background: #dcfce7;
  color: #15803d
}

.doc-item__content {
  flex: 1
}

.doc-item__title {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: 0.15rem
}

.doc-item__size {
  font-family: var(--font-ui);
  font-size: 0.78rem;
  color: var(--color-text-muted)
}

.doc-item__download {
  flex-shrink: 0;
  color: var(--color-text-muted);
  transition: color var(--transition-base), transform var(--transition-base)
}

.doc-item:hover .doc-item__download,
.doc-item:focus-visible .doc-item__download {
  color: var(--color-secondary-dark);
  transform: translateY(2px)
}

.contact-main {
  background: var(--color-surface);
  padding: 5rem 1.5rem
}

.contact-main__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: start
}

.contact-form {
  margin-top: .5rem
}

.contact-form__fieldset {
  border: none;
  padding: 0;
  margin: 0 0 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: .4rem
}

.contact-form__label {
  font-family: var(--font-ui);
  font-size: .875rem;
  font-weight: 600;
  color: var(--color-text);
  letter-spacing: .01em
}

.contact-form__input {
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--color-text);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  appearance: none
}

.contact-form__input::placeholder {
  color: var(--color-text-muted);
  opacity: .7
}

.contact-form__input:hover {
  border-color: var(--color-primary-mid)
}

.contact-form__input:focus-visible {
  outline: 3px solid var(--color-secondary);
  outline-offset: 3px;
  border-color: var(--color-secondary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-secondary) 15%, transparent)
}

.contact-form__textarea {
  min-height: 160px;
  resize: vertical;
  line-height: 1.6
}

.contact-form__submit {
  background: var(--color-primary-dark);
  color: var(--color-secondary);
  border: 2px solid var(--color-primary-dark);
  width: 100%;
  justify-content: center
}

.contact-form__submit:hover,
.contact-form__submit:focus-visible {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-secondary-light);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(15, 35, 71, .35)
}

.contact-info {
  font-style: normal;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: .5rem;
  margin-bottom: 2rem
}

.contact-info__item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  background: var(--color-background);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 1rem 1.25rem;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-fast), transform var(--transition-fast)
}

.contact-info__item:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px)
}

.contact-info__icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  background: var(--color-primary-dark);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-secondary)
}

.contact-info__text {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  min-width: 0
}

.contact-info__label {
  font-size: .78rem;
  color: var(--color-text-muted);
  letter-spacing: .06em
}

.contact-info__value {
  font-family: var(--font-ui);
  font-size: .975rem;
  color: var(--color-text);
  line-height: 1.45;
  font-weight: 400
}

.contact-info__link {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: transparent;
  transition: color var(--transition-fast), text-decoration-color var(--transition-fast)
}

.contact-info__link:hover,
.contact-info__link:focus-visible {
  color: var(--color-primary-dark);
  text-decoration-color: var(--color-secondary)
}

.contact-map {
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-border);
  line-height: 0
}

.contact-map iframe {
  display: block;
  width: 100%;
  height: 260px;
  border: 0;
  border-radius: var(--radius-md)
}

@media (max-width:768px) {
  .contact-main__inner {
    grid-template-columns: 1fr;
    gap: 2.5rem
  }

  .contact-main {
    padding: 3.5rem 1.5rem
  }
}

@media (max-width:480px) {
  .contact-main {
    padding: 2.5rem 1rem
  }

  .contact-info__item {
    padding: .875rem 1rem
  }

  .contact-form__fieldset {
    gap: 1rem
  }
}

.footer {
  background: var(--color-primary-dark);
  padding: 5rem 1.5rem 3rem
}

.footer__inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1.4fr;
  gap: 3rem
}

.footer__title {
  font-family: var(--font-heading);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--color-background);
  margin-bottom: 1.5rem
}

.footer__heading {
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  color: var(--color-secondary);
  margin-bottom: 1.25rem
}

.footer__address p {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 0.75rem;
  font-style: normal
}

.footer__address svg {
  flex-shrink: 0;
  margin-top: 3px;
  color: var(--color-secondary);
  opacity: 0.8
}

.footer__address a {
  color: inherit;
  transition: color var(--transition-base)
}

.footer__address a:hover,
.footer__address a:focus-visible {
  color: var(--color-secondary)
}

.footer__links li {
  margin-bottom: 0.6rem
}

.footer__links a {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.65);
  transition: color var(--transition-base);
  display: flex;
  align-items: center;
  gap: 0.4rem
}

.footer__links a::before {
  content: '';
  display: block;
  width: 8px;
  height: 1px;
  background: var(--color-secondary);
  opacity: 0.5;
  transition: width var(--transition-base), opacity var(--transition-base)
}

.footer__links a:hover,
.footer__links a:focus-visible {
  color: var(--color-secondary)
}

.footer__links a:hover::before,
.footer__links a:focus-visible::before {
  width: 14px;
  opacity: 1
}

.footer__privacy-link {
  margin-top: 1.25rem
}

.footer__privacy-link a {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.5);
  transition: color var(--transition-base)
}

.footer__privacy-link a:hover,
.footer__privacy-link a:focus-visible {
  color: rgba(255, 255, 255, 0.85)
}

.footer__social {
  display: flex;
  gap: 0.75rem;
  margin-bottom: 2rem
}

.footer__social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.65);
  transition: all var(--transition-base)
}

.footer__social-link:hover,
.footer__social-link:focus-visible {
  border-color: var(--color-secondary);
  color: var(--color-secondary);
  background: rgba(200, 169, 81, 0.08);
  transform: translateY(-2px)
}

.footer__newsletter-title {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 0.75rem
}

.footer__newsletter-field {
  display: flex
}

.footer__newsletter-field input {
  flex: 1;
  padding: 0.65rem 1rem;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-right: none;
  border-radius: var(--radius-sm) 0 0 var(--radius-sm);
  color: var(--color-background);
  font-size: 0.875rem;
  outline: none;
  transition: border-color var(--transition-fast), background var(--transition-fast)
}

.footer__newsletter-field input::placeholder {
  color: rgba(255, 255, 255, 0.35)
}

.footer__newsletter-field input:focus {
  border-color: var(--color-secondary);
  background: rgba(255, 255, 255, 0.1)
}

.footer__newsletter-field button {
  padding: 0 1rem;
  background: var(--color-secondary);
  color: var(--color-primary-dark);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  transition: background var(--transition-base);
  display: flex;
  align-items: center
}

.footer__newsletter-field button:hover,
.footer__newsletter-field button:focus-visible {
  background: var(--color-secondary-dark)
}

.page-hero {
  position: relative;
  min-height: 280px;
  display: flex;
  align-items: flex-end;
  padding-top: var(--navbar-height);
  overflow: hidden;
  background-color: var(--color-primary-dark);
  background-image: radial-gradient(ellipse 60% 75% at 88% 8%, color-mix(in srgb, var(--color-secondary) 26%, transparent) 0%, transparent 55%), radial-gradient(ellipse 55% 65% at 4% 92%, color-mix(in srgb, var(--color-primary-dark) 85%, black) 0%, transparent 52%), linear-gradient(148deg, color-mix(in srgb, var(--color-primary-dark) 60%, black) 0%, var(--color-primary-dark) 22%, var(--color-primary) 62%, var(--color-primary-mid) 100%)
}

.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cpath d='M50 33v34M33 50h34' stroke='rgba(200%2C169%2C81%2C.09)' stroke-width='1.5' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0
}

.page-hero::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 55%;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.28) 0%, transparent 100%);
  pointer-events: none;
  z-index: 0
}

.page-hero>* {
  position: relative;
  z-index: 1
}

.page-hero__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2rem 1.5rem 2.5rem;
  width: 100%;
  position: relative;
  z-index: 1
}

.page-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .8rem;
  margin-bottom: 1rem;
  flex-wrap: wrap
}

.page-hero__breadcrumb a {
  color: rgba(255, 255, 255, .75);
  text-decoration: none;
  transition: color .2s
}

.page-hero__breadcrumb a:hover {
  color: var(--color-secondary)
}

.page-hero__breadcrumb span[aria-hidden] {
  color: rgba(255, 255, 255, .4);
  font-size: .75rem
}

.page-hero__breadcrumb [aria-current] {
  color: rgba(255, 255, 255, .55)
}

.page-hero__title {
  font-family: var(--font-display);
  font-size: 2.8rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.15;
  margin: 0 0 .75rem;
  text-shadow: 0 2px 12px rgba(0, 0, 0, .4)
}

.page-hero__subtitle {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.15rem;
  color: rgba(255, 255, 255, .8);
  margin: 0;
  max-width: 640px
}

.page-hero__image {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 0
}

.page-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, .75) 0%, rgba(0, 0, 0, .35) 60%, rgba(0, 0, 0, .15) 100%);
  z-index: 0
}

.page-hero__content {
  position: relative;
  z-index: 1;
  width: 100%;
  display: flex;
  align-items: flex-end
}

.page-hero--post,
.page-hero--event,
.page-hero--page {
  min-height: 520px
}

.page-hero--category {
  min-height: 440px
}

.page-hero__meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: .75rem;
  flex-wrap: wrap
}

.page-hero__date {
  font-size: .85rem;
  color: rgba(255, 255, 255, .75)
}

.page-hero__category {
  font-size: .75rem;
  color: var(--color-background);
  background: var(--color-secondary);
  padding: .2rem .75rem;
  border-radius: 3px;
  text-transform: uppercase;
  text-decoration: none
}

a.page-hero__category {
  transition: opacity .2s
}

a.page-hero__category:hover,
a.page-hero__category:focus-visible {
  opacity: .85;
  color: var(--color-background)
}

.page-hero__author {
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-top: .75rem
}

.page-hero__author-pic {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: .9rem;
  font-weight: 700;
  color: var(--color-background);
  flex-shrink: 0
}

.page-hero__author-name {
  font-size: .85rem;
  color: rgba(255, 255, 255, .85)
}

.page-hero__badge {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .15);
  border: 2px solid rgba(255, 255, 255, .3);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: .75rem
}

.page-hero__badge svg {
  width: 24px;
  height: 24px;
  stroke: #fff
}

.page-hero__stats {
  display: flex;
  gap: 1.5rem;
  margin-top: 1rem;
  flex-wrap: wrap
}

.page-hero__stat {
  display: flex;
  flex-direction: column;
  gap: .2rem
}

.page-hero__stat strong {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-secondary);
  font-family: var(--font-display)
}

.page-hero__stat span {
  font-size: .8rem;
  color: rgba(255, 255, 255, .7);
  text-transform: uppercase;
  letter-spacing: .05em
}

.page-hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .75rem
}

.page-hero__chip {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .8rem;
  color: rgba(255, 255, 255, .85);
  background: rgba(255, 255, 255, .12);
  border: 1px solid rgba(255, 255, 255, .2);
  border-radius: 20px;
  padding: .3rem .75rem
}

.page-hero__chip svg {
  flex-shrink: 0;
  opacity: .75
}

.page-hero__gallery-meta {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  margin-top: .5rem;
  flex-wrap: wrap
}

.page-hero__gallery-meta-item {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .9rem;
  color: rgba(255, 255, 255, .75)
}

.page-hero__gallery-meta-item svg {
  opacity: .7;
  flex-shrink: 0
}

.page-hero__back {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  margin-top: 1rem;
  font-size: .85rem;
  color: rgba(255, 255, 255, .75);
  text-decoration: none;
  transition: color .2s
}

.page-hero__back:hover,
.page-hero__back:focus-visible {
  color: var(--color-secondary)
}

.page-hero__subtitle #staffCount {
  display: inline-block;
  background: var(--color-secondary);
  color: var(--color-background);
  font-size: .75rem;
  font-weight: 700;
  padding: .1rem .5rem;
  border-radius: 20px;
  font-style: normal;
  font-family: var(--font-sans);
  margin-left: .35rem;
  vertical-align: middle
}

@media (max-width:768px) {
  .page-hero__title {
    font-size: 2rem
  }

  .page-hero__subtitle {
    font-size: 1rem
  }

  .page-hero__stats {
    gap: 1rem
  }

  .page-hero__stat strong {
    font-size: 1.25rem
  }
}

@media (max-width:480px) {
  .page-hero__title {
    font-size: 1.6rem
  }

  .page-hero__chips {
    gap: .35rem
  }

  .page-hero__chip {
    font-size: .75rem;
    padding: .25rem .6rem
  }
}


.post-nav {
  background: var(--color-surface);
  padding: 0 1.5rem
}

.post-nav__inner {
  max-width: 860px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr
}

.post-nav__link {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding: 2rem 1.5rem;
  transition: background var(--transition-base);
  text-decoration: none
}

.post-nav__link--prev {
  border-right: 1px solid var(--color-border)
}

.post-nav__link--next {
  text-align: right;
  align-items: flex-end
}

.post-nav__link:hover,
.post-nav__link:focus-visible {
  background: var(--color-surface-alt)
}

.post-nav__label {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-ui);
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-secondary-dark)
}

.post-nav__title {
  font-family: var(--font-heading);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden
}

.related {
  padding: 5rem 1.5rem;
  background: var(--color-background)
}

.related__inner {
  max-width: 1200px;
  margin: 0 auto
}

.related__inner .section-title {
  margin-bottom: 2rem
}

.related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem
}

.related .card {
  display: block
}

.cat-subs {
  background: var(--color-surface)
}

.cat-subs__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
  display: flex;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none
}

.cat-subs__inner::-webkit-scrollbar {
  display: none
}

.cat-subs__chip {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.9rem 1.1rem;
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-muted);
  white-space: nowrap;
  border-bottom: 3px solid transparent;
  background: none;
  cursor: pointer;
  transition: color var(--transition-base), border-color var(--transition-base);
  position: relative;
  bottom: -1px
}

.cat-subs__chip:hover,
.cat-subs__chip:focus-visible {
  color: var(--color-primary)
}

.cat-subs__chip.is-active {
  color: var(--color-primary);
  border-bottom-color: var(--color-secondary)
}

.cat-subs__chip-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  background: var(--color-surface-alt);
  border-radius: 20px;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-text-muted);
  transition: background var(--transition-base), color var(--transition-base)
}

.cat-subs__chip.is-active .cat-subs__chip-count,
.cat-subs__chip:hover .cat-subs__chip-count {
  background: var(--color-primary);
  color: var(--color-background)
}

.page-category .articles {
  padding-top: 4rem
}

#catResultCount {
  font-variant-numeric: tabular-nums
}

a.card__category,
a.featured__category {
  text-decoration: none;
  transition: opacity var(--transition-base)
}

a.card__category:hover,
a.card__category:focus-visible,
a.featured__category:hover,
a.featured__category:focus-visible {
  opacity: 0.8
}

@media (max-width:768px) {
  .cat-subs__chip {
    padding: 0.8rem 0.85rem;
    font-size: 0.82rem
  }
}

.copyright-bar {
  background: color-mix(in srgb, var(--color-primary-dark) 70%, black);
  padding: 1.1rem 1.5rem;
  text-align: center
}

.copyright-bar p {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  color: color-mix(in srgb, var(--color-background) 35%, transparent);
  letter-spacing: 0.03em
}

@media (max-width:768px) {
  .post-nav__inner {
    grid-template-columns: 1fr
  }

  .post-nav__link--prev {
    border-right: none;
    border-bottom: 1px solid var(--color-border)
  }

  .post-nav__link--next {
    text-align: left;
    align-items: flex-start
  }

  .related__grid {
    grid-template-columns: 1fr
  }
}

@media (max-width:480px) {
  .post-body {
    padding: 2.5rem 1.25rem 2rem
  }

  .post-body__inner h2 {
    font-size: 1.25rem
  }

  .post-body__inner blockquote {
    padding: 1.25rem 1.25rem
  }
}

@media (max-width:1024px) {
  .related__grid {
    grid-template-columns: repeat(2, 1fr)
  }

  .articles__grid {
    grid-template-columns: 1fr
  }

  .events__body {
    grid-template-columns: 1fr
  }

  .calendar {
    max-width: 400px;
    margin: 0 auto
  }

  .gallery__grid {
    grid-template-columns: repeat(2, 1fr)
  }

  .footer__inner {
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem
  }

  .footer__col--social {
    grid-column: 1 / -1
  }
}

@media (max-width:768px) {
  :root {
    --navbar-height: 60px
  }

  .navbar__nav {
    display: none
  }

  .navbar__hamburger {
    order: 1
  }

  .navbar__search {
    order: 3;
    margin-left: auto
  }

  .navbar__dropdown-toggle {
    order: 4;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    width: 40px;
    height: 40px;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
    transition: background var(--transition-fast)
  }

  .navbar__dropdown-toggle:hover {
    background: rgba(255, 255, 255, 0.1)
  }

  .navbar__dropdown-toggle span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--color-background);
    border-radius: 2px;
    transition: all 0.3s ease;
    transform-origin: center
  }

  .navbar__dropdown-toggle.is-active span:nth-child(1) {
    transform: translateY(7px) rotate(45deg)
  }

  .navbar__dropdown-toggle.is-active span:nth-child(2) {
    opacity: 0;
    transform: scaleX(0)
  }

  .navbar__dropdown-toggle.is-active span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg)
  }

  .navbar__dropdown {
    display: block;
    position: absolute;
    top: var(--navbar-height);
    left: 0;
    right: 0;
    background: var(--color-primary-dark);
    z-index: 99;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 0.35s ease, opacity 0.25s ease
  }

  .navbar__dropdown.is-open {
    max-height: 500px;
    opacity: 1
  }

  .navbar__dropdown ul {
    list-style: none;
    padding: 0.5rem 0
  }

  .navbar__dropdown-link {
    display: block;
    padding: 0.85rem 1.5rem;
    color: rgba(255, 255, 255, 0.85);
    font-family: var(--font-ui);
    font-size: 0.95rem;
    font-weight: 500;
    border-left: 3px solid transparent;
    transition: color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast)
  }

  .navbar__dropdown-link:hover,
  .navbar__dropdown-link:focus-visible {
    color: var(--color-secondary);
    border-left-color: var(--color-secondary);
    background: rgba(255, 255, 255, 0.05)
  }

  .navbar__dropdown .navbar__dropdown-link--parent {
    display: flex;
    justify-content: space-between;
    align-items: center
  }

  .navbar__dropdown li.is-open > .navbar__dropdown-link--parent .navbar__sub-arrow {
    transform: rotate(180deg)
  }

  .navbar__mobile-sub {
    list-style: none;
    padding: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease
  }

  .navbar__mobile-sub.is-open {
    max-height: 600px
  }

  .navbar__mobile-sub-link {
    padding-left: 2.5rem;
    font-size: 0.875rem;
    opacity: 0.8
  }

  .navbar__mobile-sub-link:hover,
  .navbar__mobile-sub-link:focus-visible {
    opacity: 1
  }

  .hero {
    min-height: 85vh
  }

  .hero__title {
    font-size: clamp(1.75rem, 7vw, 2.75rem)
  }

  .featured__inner {
    grid-template-columns: 1fr;
    gap: 2rem
  }

  .featured__content {
    padding-left: 1.5rem
  }

  .footer {
    padding: 3.5rem 1.25rem 2.5rem
  }

  .footer__inner {
    grid-template-columns: 1fr;
    gap: 2rem
  }

  .footer__col--social {
    grid-column: auto
  }
}

@media (max-width:480px) {
  .hero {
    min-height: 80vh
  }

  .hero__actions {
    flex-direction: column;
    align-items: center
  }

  .btn {
    width: 100%;
    max-width: 280px;
    justify-content: center
  }

  .gallery__grid {
    grid-template-columns: 1fr
  }

  .event-item {
    gap: 1rem
  }

  .event-item__date {
    width: 48px
  }

  .event-item__day {
    font-size: 1.3rem
  }

  .section-title {
    font-size: 1.6rem
  }

  .featured__title {
    font-size: 1.3rem
  }
}

.contact-main {
  background: var(--color-surface);
  padding: 5rem 1.5rem
}

.contact-main__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: start
}

.contact-form {
  margin-top: 0.5rem
}

.contact-form__fieldset {
  border: none;
  padding: 0;
  margin: 0 0 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem
}

.contact-form__label {
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text);
  letter-spacing: 0.01em
}

.contact-form__input {
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--color-text);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  appearance: none
}

.contact-form__input::placeholder {
  color: var(--color-text-muted);
  opacity: 0.7
}

.contact-form__input:hover {
  border-color: var(--color-primary-mid)
}

.contact-form__input:focus-visible {
  outline: 3px solid var(--color-secondary);
  outline-offset: 3px;
  border-color: var(--color-secondary);
  box-shadow: 0 0 0 3px rgba(200, 169, 81, 0.15)
}

.contact-form__textarea {
  min-height: 160px;
  resize: vertical;
  line-height: 1.6
}

.contact-form__submit {
  background: var(--color-primary-dark);
  color: var(--color-secondary);
  border: 2px solid var(--color-primary-dark);
  width: 100%;
  justify-content: center
}

.contact-form__submit:hover,
.contact-form__submit:focus-visible {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-secondary-light);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(15, 35, 71, 0.35)
}

.contact-info {
  font-style: normal;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 0.5rem;
  margin-bottom: 2rem
}

.contact-info__item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  background: var(--color-background);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 1rem 1.25rem;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-fast), transform var(--transition-fast)
}

.contact-info__item:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px)
}

.contact-info__icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  background: var(--color-primary-dark);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-secondary)
}

.contact-info__text {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0
}

.contact-info__label {
  font-size: 0.78rem;
  color: var(--color-text-muted);
  letter-spacing: 0.06em
}

.contact-info__value {
  font-family: var(--font-ui);
  font-size: 0.975rem;
  color: var(--color-text);
  line-height: 1.45;
  font-weight: 400
}

.contact-info__link {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: transparent;
  transition: color var(--transition-fast), text-decoration-color var(--transition-fast)
}

.contact-info__link:hover,
.contact-info__link:focus-visible {
  color: var(--color-primary-dark);
  text-decoration-color: var(--color-secondary)
}

.contact-map {
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-border);
  line-height: 0
}

.contact-map iframe {
  display: block;
  width: 100%;
  height: 260px;
  border: 0;
  border-radius: var(--radius-md)
}

@media (max-width:768px) {
  .contact-main__inner {
    grid-template-columns: 1fr;
    gap: 2.5rem
  }

  .contact-main {
    padding: 3.5rem 1.5rem
  }
}

@media (max-width:480px) {
  .contact-main {
    padding: 2.5rem 1rem
  }

  .contact-info__item {
    padding: 0.875rem 1rem
  }

  .contact-form__fieldset {
    gap: 1rem
  }
}

.docs-page {
  background: var(--color-surface);
  padding: 0 1.5rem 5rem
}

.docs-page__inner {
  max-width: 900px;
  margin: 0 auto;
  padding-top: 2.5rem
}

.docs-filter {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 2.5rem
}

.docs-filter .cat-subs__inner {
  max-width: 900px;
  padding: 0
}

#docCount {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  color: var(--color-text-muted);
  margin-bottom: 1.25rem;
  font-variant-numeric: tabular-nums
}

.doc-item.is-hidden {
  display: none
}

@media (max-width:768px) {
  .docs-page {
    padding: 0 1.25rem 3.5rem
  }

  .docs-page__inner {
    padding-top: 2rem
  }
}

@media (max-width:480px) {
  .docs-page {
    padding: 0 1rem 3rem
  }
}

.event-info {
  background: var(--color-background);
  padding: 3.5rem 1.5rem 4rem
}

.event-info__inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 3rem;
  align-items: start
}

.event-info__body {}

.event-info__body h2 {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-top: 2.5rem;
  margin-bottom: 1.25rem;
  line-height: 1.3;
  padding-left: 1rem;
  border-left: 3px solid var(--color-secondary)
}

.event-info__body h2:first-child {
  margin-top: 0
}

.event-info__body p {
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--color-text);
  margin-bottom: 1.5rem
}

.event-timeline {
  position: relative;
  padding-left: 2.5rem;
  margin-top: 1rem
}

.event-timeline::before {
  content: '';
  position: absolute;
  left: 9px;
  top: 10px;
  bottom: 10px;
  width: 2px;
  background: rgba(200, 169, 81, 0.2);
  border-radius: 2px
}

.event-timeline__item {
  position: relative;
  display: flex;
  gap: 1.25rem;
  padding-bottom: 1.75rem;
  align-items: flex-start
}

.event-timeline__item:last-child {
  padding-bottom: 0
}

.event-timeline__dot {
  position: absolute;
  left: -2.5rem;
  top: 5px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-secondary);
  flex-shrink: 0
}

.event-timeline__time {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--color-secondary-dark);
  letter-spacing: 0.03em;
  white-space: nowrap;
  min-width: 60px;
  padding-top: 1px
}

.event-timeline__title {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-primary);
  line-height: 1.4
}

.event-timeline__desc {
  font-family: var(--font-body);
  font-size: 0.875rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  margin-top: 0.2rem
}

.event-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1.5rem
}

.event-sidebar__card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 1.75rem
}

.event-sidebar__heading {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  font-variant: small-caps;
  color: var(--color-secondary-dark);
  margin-bottom: 1.35rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--color-border)
}

.event-data-row {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--color-border)
}

.event-data-row:last-child {
  border-bottom: none;
  padding-bottom: 0
}

.event-data-row:first-of-type {
  padding-top: 0
}

.event-data-row__icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-sm);
  background: rgba(200, 169, 81, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-secondary-dark);
  margin-top: 1px
}

.event-data-row__content {
  flex: 1
}

.event-data-row__label {
  display: block;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  margin-bottom: 0.2rem
}

.event-data-row__value {
  display: block;
  font-family: var(--font-ui);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-primary);
  line-height: 1.4
}

.event-form {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 1.75rem
}

.event-form__heading {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 1.35rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--color-border)
}

.event-form__field {
  margin-bottom: 1rem
}

.event-form__field label {
  display: block;
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 0.4rem;
  letter-spacing: 0.01em
}

.event-form__field input,
.event-form__field select,
.event-form__field textarea {
  padding: 0.6rem 0.85rem;
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: var(--color-text);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  outline: none;
  appearance: none;
  -webkit-appearance: none
}

.event-form__field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235a5a5a' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  padding-right: 2.25rem
}

.event-form__field textarea {
  resize: vertical;
  min-height: 80px;
  line-height: 1.55
}

.event-form__field input:focus,
.event-form__field select:focus,
.event-form__field textarea:focus {
  border-color: var(--color-secondary);
  box-shadow: 0 0 0 3px rgba(200, 169, 81, 0.15)
}

.event-form__field input::placeholder,
.event-form__field textarea::placeholder {
  color: rgba(90, 90, 90, 0.45)
}

.event-form__submit {
  width: 100%;
  justify-content: center;
  margin-top: 0.5rem
}

.event-form__note {
  display: block;
  font-family: var(--font-ui);
  font-size: 0.78rem;
  color: var(--color-text-muted);
  text-align: center;
  margin-top: 0.85rem;
  line-height: 1.5
}

.event-status-card {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 1rem 1.25rem;
  border-radius: 8px;
  font-family: var(--font-ui);
  font-size: 0.95rem;
  font-weight: 600
}

.event-status-card--ended {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text-muted)
}

.event-status-card--full {
  background: color-mix(in srgb, var(--color-accent) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--color-accent) 30%, transparent);
  color: var(--color-accent)
}

@media (max-width:1024px) {
  .event-info__inner {
    grid-template-columns: 1fr;
    gap: 2rem
  }

  .event-sidebar {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem
  }
}

@media (max-width:768px) {
  .event-info {
    padding: 2.5rem 1.25rem 3rem
  }

  .event-sidebar {
    grid-template-columns: 1fr
  }
}

@media (max-width:480px) {
  .event-timeline {
    padding-left: 2rem
  }

  .event-timeline__item {
    flex-direction: column;
    gap: 0.25rem
  }

  .event-timeline__time {
    min-width: auto
  }
}

.events-controls {
  background: var(--color-background);
  box-shadow: var(--shadow-sm)
}

.events-controls__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0.9rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap
}

.events-view-toggle {
  display: flex;
  background: var(--color-surface-alt);
  border-radius: 100px;
  padding: 3px;
  gap: 2px
}

.events-view-toggle__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 1.1rem;
  border-radius: 100px;
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-muted);
  background: transparent;
  transition: all var(--transition-fast);
  white-space: nowrap
}

.events-view-toggle__btn:hover {
  color: var(--color-primary)
}

.events-view-toggle__btn--active {
  background: var(--color-secondary);
  color: var(--color-primary-dark);
  box-shadow: var(--shadow-sm)
}

.events-view-toggle__btn--active:hover {
  background: var(--color-secondary-dark);
  color: var(--color-primary-dark)
}

.events-month-nav {
  display: flex;
  align-items: center;
  gap: 0.75rem
}

.events-month-nav__prev,
.events-month-nav__next {
  background: var(--color-surface-alt);
  color: var(--color-primary);
  border-radius: 50%;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast)
}

.events-month-nav__prev:hover,
.events-month-nav__prev:focus-visible,
.events-month-nav__next:hover,
.events-month-nav__next:focus-visible {
  background: var(--color-primary);
  color: var(--color-secondary)
}

.events-month-nav__label {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-primary);
  min-width: 160px;
  text-align: center
}

.events-category-filter {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  align-items: center
}

.events-category-filter__btn {
  padding: 0.35rem 0.9rem;
  border-radius: 100px;
  font-family: var(--font-ui);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-text-muted);
  background: var(--color-surface-alt);
  cursor: pointer;
  transition: all var(--transition-fast)
}

.events-category-filter__btn:hover {
  color: var(--color-primary)
}

.events-category-filter__btn--active {
  background: var(--color-primary);
  color: var(--color-background)
}

.events-calendar-view {
  background: var(--color-surface);
  padding: 2.5rem 1.5rem 4rem
}

.events-calendar-view__inner {
  max-width: 1200px;
  margin: 0 auto
}

.events-big-calendar {
  background: var(--color-background);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden
}

.events-big-calendar__weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  background: var(--color-primary)
}

.events-big-calendar__weekdays span {
  padding: 0.75rem 0.5rem;
  text-align: center;
  font-family: var(--font-ui);
  font-size: 0.78rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.75);
  letter-spacing: 0.04em;
  text-transform: uppercase
}

.events-big-calendar__days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border-left: 1px solid var(--color-border);
  border-top: 1px solid var(--color-border)
}

.ev-cal-cell {
  min-height: 100px;
  border-right: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  padding: 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  background: var(--color-background);
  transition: background var(--transition-fast);
  position: relative;
  overflow: hidden
}

.ev-cal-cell--other-month {
  background: var(--color-surface);
  opacity: 0.55
}

.ev-cal-cell--other-month .ev-cal-cell__day-num {
  color: var(--color-text-muted)
}

.ev-cal-cell--has-events {
  cursor: pointer
}

.ev-cal-cell--has-events:hover,
.ev-cal-cell--has-events:focus-visible {
  background: var(--color-surface);
  outline: none
}

.ev-cal-cell--has-events:focus-visible {
  outline: 3px solid var(--color-secondary);
  outline-offset: -3px
}

.ev-cal-cell__day-num {
  font-family: var(--font-ui);
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--color-text);
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  flex-shrink: 0
}

.ev-cal-cell--today .ev-cal-cell__day-num {
  background: var(--color-secondary);
  color: var(--color-primary-dark);
  font-weight: 700;
  box-shadow: 0 0 0 2px var(--color-secondary-dark)
}

.ev-cal-cell__events {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  overflow: hidden
}

.ev-cal-pill {
  display: block;
  padding: 2px 6px;
  border-radius: 3px;
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.5
}

.ev-cal-pill--school {
  background: rgba(200, 169, 81, 0.18);
  color: var(--color-secondary-dark);
  border-left: 2px solid var(--color-secondary)
}

.ev-cal-pill--deadline {
  background: rgba(139, 26, 26, 0.12);
  color: var(--color-accent);
  border-left: 2px solid var(--color-accent)
}

.ev-cal-pill--info {
  background: rgba(26, 58, 107, 0.1);
  color: var(--color-primary);
  border-left: 2px solid var(--color-primary-mid)
}

.ev-cal-pill--holiday {
  background: rgba(196, 30, 58, 0.12);
  color: var(--color-accent);
  border-left: 2px solid var(--color-accent)
}

.ev-cal-pill--exam_period {
  background: rgba(212, 160, 23, 0.15);
  color: #7a5a00;
  border-left: 2px solid var(--color-secondary)
}

.ev-cal-more {
  font-family: var(--font-ui);
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--color-text-muted);
  padding: 1px 4px;
  align-self: flex-start
}

.events-list-view {
  background: var(--color-surface);
  padding: 2.5rem 1.5rem 4rem
}

.events-list-view__inner {
  max-width: 1200px;
  margin: 0 auto
}

.ev-month-group {
  margin-bottom: 3rem
}

.ev-month-group__heading {
  font-family: var(--font-heading);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--color-primary);
  padding: 0 0 0.6rem 1rem;
  border-left: 4px solid var(--color-secondary);
  margin-bottom: 1.25rem;
  line-height: 1.2
}

.ev-month-group__list {
  display: flex;
  flex-direction: column;
  gap: 1rem
}

.ev-card {
  display: grid;
  grid-template-columns: 72px 1fr auto;
  gap: 1.5rem;
  align-items: start;
  background: var(--color-background);
  border-radius: var(--radius-md);
  padding: 1.25rem 1.5rem;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base)
}

.ev-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px)
}

.ev-card__date {
  width: 72px;
  padding: 0.6rem 0
}

.ev-card__day {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  font-weight: 900;
  color: var(--color-primary-dark);
  line-height: 1
}

.ev-card__month-abbr {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 3px
}

.ev-card__body {
  flex: 1;
  min-width: 0
}

.ev-card__category {
  padding: 2px 10px;
  border-radius: 100px;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  margin-bottom: 0.5rem
}

.ev-card__category--school {
  background: rgba(200, 169, 81, 0.18);
  color: var(--color-secondary-dark)
}

.ev-card__category--deadline {
  background: rgba(139, 26, 26, 0.1);
  color: var(--color-accent)
}

.ev-card__category--info {
  background: rgba(26, 58, 107, 0.1);
  color: var(--color-primary)
}

.ev-card__title {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 0.35rem;
  line-height: 1.3
}

.ev-card__desc {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  margin-bottom: 0.5rem
}

.ev-card__location {
  gap: 0.35rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--color-primary)
}

.ev-card__actions {
  display: flex;
  align-items: flex-start;
  padding-top: 0.25rem
}

.ev-card__link {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.5rem 1.1rem;
  background: var(--color-primary);
  color: var(--color-background);
  border-radius: var(--radius-sm);
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 600;
  white-space: nowrap;
  transition: all var(--transition-base)
}

.ev-card__link:hover,
.ev-card__link:focus-visible {
  background: var(--color-secondary);
  color: var(--color-primary-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(200, 169, 81, 0.35)
}

.ev-card__category--holiday {
  background: rgba(196, 30, 58, 0.1);
  color: var(--color-accent)
}

.ev-card__category--exam_period {
  background: rgba(212, 160, 23, 0.15);
  color: #7a5a00
}

.ev-card__date-range {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  margin: 0.15rem 0 0.35rem
}

.ev-card--holiday .ev-card__date {
  background: var(--color-accent)
}

.ev-card--exam_period .ev-card__date {
  background: var(--color-secondary)
}

.ev-card--exam_period .ev-card__day,
.ev-card--exam_period .ev-card__month-abbr {
  color: var(--color-primary-dark)
}

.ev-empty {
  text-align: center;
  padding: 4rem 1.5rem;
  color: var(--color-text-muted);
  font-family: var(--font-ui)
}

.ev-empty__icon {
  font-size: 3rem;
  margin-bottom: 1rem;
  opacity: 0.4;
  display: block
}

.ev-empty__text {
  font-size: 1rem
}

.sidebar__link--active {
  color: var(--color-secondary);
  border-left-color: var(--color-secondary)
}

.navbar__link--active {
  color: var(--color-secondary)
}

.navbar__link--active::after {
  transform: scaleX(1)
}

@media (max-width:1024px) {
  .ev-cal-cell {
    min-height: 80px
  }

  .ev-card {
    grid-template-columns: 64px 1fr;
    grid-template-rows: auto auto
  }

  .ev-card__actions {
    grid-column: 2;
    grid-row: 2;
    padding-top: 0.5rem
  }
}

@media (max-width:768px) {
  .events-controls__inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.75rem 1rem
  }

  .events-month-nav__label {
    min-width: 130px;
    font-size: 0.95rem
  }

  .ev-cal-cell {
    min-height: 60px;
    padding: 0.3rem
  }

  .ev-cal-pill {
    font-size: 0.62rem;
    padding: 1px 4px
  }

  .ev-cal-pill~.ev-cal-pill {
    display: none
  }

  .ev-cal-cell__day-num {
    width: 22px;
    height: 22px;
    font-size: 0.78rem
  }

  .events-big-calendar__weekdays span {
    font-size: 0.62rem;
    padding: 0.5rem 0.2rem;
    letter-spacing: 0
  }

  .ev-card {
    grid-template-columns: 60px 1fr;
    gap: 1rem;
    padding: 1rem
  }

  .ev-card__date {
    width: 60px
  }

  .ev-card__day {
    font-size: 1.5rem
  }

  .ev-card__actions {
    grid-column: 1 / -1;
    grid-row: auto;
    padding-top: 0
  }

  .ev-card__link {
    width: 100%;
    justify-content: center
  }
}

@media (max-width:480px) {
  .events-calendar-view {
    display: none !important
  }

  #btnCalView {
    display: none
  }

  .events-controls__inner {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between
  }

  .events-month-nav__label {
    min-width: 110px;
    font-size: 0.88rem
  }
}

.gallery-index {
  padding: 4rem 1.5rem 6rem;
  background: var(--color-background)
}

.gallery-index__inner {
  max-width: 1200px;
  margin: 0 auto
}

@media (max-width:768px) {
  .gallery-index {
    padding: 3rem 1.25rem 4rem
  }
}

@media (max-width:480px) {
  .gallery-index .gallery__grid {
    grid-template-columns: minmax(240px, 1fr)
  }
}

.gallery-grid-section {
  background: var(--color-surface);
  padding: 3rem 0 4rem
}

.gallery-grid-section__inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 1.5rem
}

.masonry {
  columns: 4;
  column-gap: 0.75rem
}

.masonry__item {
  break-inside: avoid;
  margin-bottom: 0.75rem;
  display: block;
  cursor: pointer;
  border-radius: var(--radius-sm);
  overflow: hidden;
  position: relative
}

.masonry__image {
  display: block;
  width: 100%;
  transition: transform var(--transition-base)
}

.masonry__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition-base)
}

.masonry__zoom-icon {
  color: var(--color-background);
  opacity: 0;
  transform: scale(0.7);
  transition: opacity var(--transition-base), transform var(--transition-base);
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.6))
}

.masonry__item:hover .masonry__image,
.masonry__item:focus-visible .masonry__image {
  transform: scale(1.02)
}

.masonry__item:hover .masonry__overlay,
.masonry__item:focus-visible .masonry__overlay {
  background: rgba(0, 0, 0, 0.38)
}

.masonry__item:hover .masonry__zoom-icon,
.masonry__item:focus-visible .masonry__zoom-icon {
  opacity: 1;
  transform: scale(1)
}

.masonry__item:focus-visible {
  outline: 3px solid var(--color-secondary);
  outline-offset: 2px
}

.lightbox {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(0, 0, 0, 0.93);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base)
}

.lightbox.is-open {
  opacity: 1;
  visibility: visible
}

.lightbox__top-bar {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.5rem;
  z-index: 10;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0) 100%)
}

.lightbox__counter {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.85);
  letter-spacing: 0.05em
}

.lightbox__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  color: var(--color-background);
  border-radius: var(--radius-sm);
  transition: background var(--transition-fast)
}

.lightbox__close:hover {
  background: rgba(255, 255, 255, 0.15)
}

.lightbox__close:focus-visible {
  outline: 3px solid var(--color-secondary);
  outline-offset: 2px
}

.lightbox__stage {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5rem 5.5rem 4.5rem
}

.lightbox__image-wrapper {
  position: relative;
  display: inline-flex;
  max-width: 100%;
  max-height: 100%;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-xl);
  overflow: hidden
}

.lightbox__image {
  display: block;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto
}

.lightbox__info-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1.25rem 1.5rem 1.25rem;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px)
}

.lightbox__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  color: var(--color-background);
  background: rgba(255, 255, 255, 0.12);
  border-radius: 50%;
  transition: background var(--transition-fast), transform var(--transition-fast);
  z-index: 10
}

.lightbox__nav:hover {
  background: rgba(255, 255, 255, 0.25)
}

.lightbox__nav:focus-visible {
  outline: 3px solid var(--color-secondary);
  outline-offset: 2px
}

.lightbox__nav--prev {
  left: 1.25rem
}

.lightbox__nav--next {
  right: 1.25rem
}

.lightbox__caption {
  font-family: var(--font-ui);
  font-size: 1.1rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.4
}

.lightbox__description {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.75);
  margin-top: 0.35rem;
  line-height: 1.5
}

@media (max-width:1024px) {
  .masonry {
    columns: 3
  }
}

@media (max-width:768px) {
  .masonry {
    columns: 2
  }

  .lightbox__stage {
    padding: 4.5rem 4rem 4rem
  }
}

@media (max-width:480px) {
  .masonry {
    columns: 1
  }

  .gallery-grid-section {
    padding: 2rem 0 3rem
  }

  .gallery-grid-section__inner {
    padding: 0 1rem
  }

  .lightbox__nav {
    display: none
  }

  .lightbox__stage {
    padding: 4rem 1rem 3.5rem
  }

  .lightbox__image {
    width: 100%;
    border-radius: var(--radius-sm)
  }
}

.schedule-content {
  max-width: 1100px;
  margin: 0 auto;
  padding: 5rem 1.5rem
}

.schedule-sections-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 3rem;
  align-items: start
}

.schedule-section {
  margin-bottom: 3rem
}

.schedule-section__title {
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin-bottom: 0.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--color-secondary)
}

.schedule-section__desc {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: var(--color-text-muted);
  margin-bottom: 1.25rem
}

.schedule-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 2rem
}

.schedule-card {
  background: var(--color-background);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm)
}

.schedule-card--full {
  grid-column: 1 / -1
}

.schedule-card__header {
  background: var(--color-primary-dark);
  color: var(--color-background);
  padding: 1rem 1.5rem
}

.schedule-card__header-title {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase
}

.schedule-card__body {
  padding: 0
}

.period-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.7rem 1.5rem;
  border-bottom: 1px solid var(--color-surface-alt);
  transition: background var(--transition-fast)
}

.period-row:last-child {
  border-bottom: none
}

.period-row:hover {
  background: var(--color-surface)
}

.period-row--now {
  background: rgba(212, 160, 23, 0.07)
}

.period-row--now .period-row__badge {
  box-shadow: 0 0 0 3px rgba(212, 160, 23, 0.45)
}

.period-row__badge {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-secondary);
  color: var(--color-primary-dark);
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  justify-content: center
}

.period-row__label {
  font-family: var(--font-ui);
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-text);
  flex: 1
}

.period-row__time {
  font-family: var(--font-ui);
  font-size: 1rem;
  color: var(--color-text);
  font-weight: 600;
  flex-shrink: 0;
  white-space: nowrap
}

.period-row__duration {
  font-family: var(--font-ui);
  font-size: 0.78rem;
  color: var(--color-text-muted);
  background: var(--color-surface-alt);
  border-radius: 999px;
  padding: 0.15rem 0.6rem;
  white-space: nowrap;
  flex-shrink: 0
}

.schedule-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.65rem 1.5rem;
  border-bottom: 1px solid var(--color-surface-alt);
  font-family: var(--font-ui)
}

.schedule-row:last-child {
  border-bottom: none
}

.schedule-row__label {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  min-width: 90px;
  flex-shrink: 0
}

.schedule-row__value {
  font-size: 0.95rem;
  color: var(--color-text);
  font-weight: 600;
  flex: 1
}

.schedule-row__note {
  font-size: 0.8rem;
  color: var(--color-text-muted)
}

.schedule-info {
  padding: 1.5rem;
  font-family: var(--font-ui);
  display: flex;
  align-items: center;
  gap: 1rem
}

.schedule-info__label {
  font-size: 0.9rem;
  color: var(--color-text-muted);
  min-width: 100px
}

.schedule-info__value {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-primary-dark)
}

.schedule-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-ui);
  font-size: 0.88rem
}

.schedule-table th {
  background: var(--color-surface);
  color: var(--color-text-muted);
  font-weight: 600;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.6rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--color-border)
}

.schedule-table td {
  padding: 0.65rem 1rem;
  color: var(--color-text);
  border-bottom: 1px solid var(--color-surface-alt);
  vertical-align: middle
}

.schedule-table tr:last-child td {
  border-bottom: none
}

.schedule-table tr:hover td {
  background: var(--color-surface)
}

.schedule-table .table-label {
  font-weight: 600;
  color: var(--color-primary-dark);
  white-space: nowrap
}

.schedule-table .time-cell {
  font-weight: 500;
  white-space: nowrap
}

.schedule-table .time-pill {
  display: inline-block;
  background: var(--color-surface-alt);
  border-radius: 999px;
  padding: 0.15rem 0.65rem;
  font-size: 0.82rem;
  color: var(--color-text)
}

.schedule-table .closed-cell {
  color: var(--color-text-muted);
  font-style: italic
}

.schedule-table .time-pill--now {
  background: rgba(212, 160, 23, 0.15);
  color: var(--color-primary-dark);
  font-weight: 600
}

@media (max-width:768px) {
  .schedule-sections-grid {
    grid-template-columns: 1fr
  }

  .schedule-grid {
    grid-template-columns: 1fr
  }

  .schedule-content {
    padding: 3rem 1.25rem
  }

  .period-row {
    padding: 0.65rem 1rem;
    gap: 0.75rem
  }

  .schedule-row {
    padding: 0.6rem 1rem
  }

  .schedule-table th,
  .schedule-table td {
    padding: 0.55rem 0.75rem
  }

}

@media (max-width:480px) {
  .schedule-table {
    font-size: 0.8rem
  }

  .schedule-table th,
  .schedule-table td {
    padding: 0.5rem 0.5rem
  }
}

.staff-filter {
  background: var(--color-surface)
}

.staff-filter__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0.75rem 1.5rem 0;
  display: flex;
  align-items: flex-end;
  gap: 2rem;
  flex-wrap: wrap
}

.staff-filter__search {
  position: relative;
  flex-shrink: 0;
  padding-bottom: 0.75rem
}

.staff-filter__search-icon {
  position: absolute;
  left: 0.85rem;
  top: 50%;
  transform: translateY(-60%);
  color: var(--color-text-muted);
  pointer-events: none
}

.staff-filter__input {
  width: 280px;
  padding: 0.6rem 0.9rem 0.6rem 2.5rem;
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: var(--color-text);
  outline: none;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast)
}

.staff-filter__input::placeholder {
  color: var(--color-text-muted)
}

.staff-filter__input:focus {
  border-color: var(--color-secondary);
  box-shadow: 0 0 0 3px rgba(200, 169, 81, 0.15)
}

.staff-filter .cat-subs {
  flex: 1;
  background: none;
  border-bottom: none;
  position: static;
  z-index: auto
}

.staff-filter .cat-subs__inner {
  padding: 0
}

.staff-directory {
  background: var(--color-background);
  padding: 4rem 1.5rem 5rem
}

.staff-directory__inner {
  max-width: 1200px;
  margin: 0 auto
}

.staff-dept {
  margin-bottom: 4rem
}

.staff-dept:last-of-type {
  margin-bottom: 0
}

.staff-dept__header {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  margin-bottom: 1.75rem
}

.staff-dept__title {
  font-family: var(--font-heading);
  font-size: clamp(1.2rem, 2.5vw, 1.55rem);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.2
}

.staff-dept__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 24px;
  padding: 0 7px;
  background: var(--color-surface-alt);
  border-radius: 20px;
  font-family: var(--font-ui);
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--color-text-muted);
  flex-shrink: 0
}

.staff-dept__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem
}

.staff-card {
  background: var(--color-background);
  border: 1px solid var(--color-border);
  border-left: 3px solid transparent;
  border-radius: var(--radius-md);
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  transition: box-shadow var(--transition-base), transform var(--transition-base), border-left-color var(--transition-base)
}

.staff-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
  border-left-color: var(--color-secondary)
}

.staff-card__top {
  display: flex;
  align-items: center;
  gap: 0.9rem
}

.staff-card__avatar {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--color-primary-mid);
  color: var(--color-secondary-light);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border: 2px solid rgba(200, 169, 81, 0.3);
  letter-spacing: 0.02em
}

.staff-card__identity {
  flex: 1;
  min-width: 0
}

.staff-card__name {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.3;
  margin-bottom: 0.2rem
}

.staff-card__position {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--color-text-muted);
  line-height: 1.4
}

.staff-card__subjects {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.staff-card__subject {
  padding: .2rem .5rem .1rem .5rem;
  background: var(--color-surface-alt);
  color: var(--color-primary);
  font-family: var(--font-ui);
  font-size: 0.75rem;
  white-space: nowrap
}

.staff-card__intro {
  font-family: var(--font-body);
  font-size: 0.875rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1
}

.staff-card__email,
.staff-card__phone {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--color-text-muted);
  transition: color var(--transition-base);
  word-break: break-all
}

.staff-card__email {
  margin-top: auto
}

.staff-card__email:hover,
.staff-card__email:focus-visible,
.staff-card__phone:hover,
.staff-card__phone:focus-visible {
  color: var(--color-primary)
}

.staff-card__email svg,
.staff-card__phone svg {
  flex-shrink: 0;
  color: var(--color-secondary-dark)
}

.staff-card__avatar--photo {
  overflow: hidden;
  padding: 0;
  cursor: pointer;
  border: none;
  background: transparent;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  flex-shrink: 0
}

.staff-card__avatar--photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%
}

.staff-card[role="button"] {
  cursor: pointer
}

.staff-card__footer {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--color-border);
  margin-top: auto
}

.badge-staff-dept {
  background: var(--color-surface-alt);
  color: var(--color-text-muted);
  font-size: 0.72rem;
  border: 1px solid var(--color-border);
  padding: .2rem .5rem .1rem .5rem;
}

.badge-staff-category {
  background: var(--color-surface-alt);
  color: var(--color-primary);
  font-size: 0.72rem;
  padding: .2rem .5rem .1rem .5rem;
}

.staff-filter__suggestions {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--color-background);
  border: 1px solid var(--color-border);
  border-top: none;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  box-shadow: var(--shadow-md);
  max-height: 240px;
  overflow-y: auto;
  z-index: 60
}

.staff-filter__suggestion {
  padding: 0.55rem 0.85rem;
  font-family: var(--font-ui);
  font-size: 0.85rem;
  color: var(--color-text);
  cursor: pointer;
  transition: background var(--transition-fast)
}

.staff-filter__suggestion:hover,
.staff-filter__suggestion.is-highlighted {
  background: var(--color-surface-alt)
}

.staff-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1.5rem
}

.staff-modal.is-open {
  display: flex
}

.staff-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55)
}

.staff-modal__panel {
  position: relative;
  background: var(--color-background);
  border-radius: var(--radius-md);
  max-width: 700px;
  width: 100%;
  max-height: 85vh;
  overflow-y: auto;
  padding: 2rem;
  box-shadow: var(--shadow-lg)
}

.staff-modal__close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-text-muted);
  padding: 0.25rem;
  border-radius: var(--radius-sm);
  transition: color var(--transition-base)
}

.staff-modal__close:hover,
.staff-modal__close:focus-visible {
  color: var(--color-primary)
}

.staff-modal__body {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 1.5rem;
  align-items: start
}

.staff-modal__left {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem
}

.staff-modal__avatar {
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: var(--color-primary-mid);
  color: var(--color-secondary-light);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 3px solid rgba(200, 169, 81, 0.3);
  letter-spacing: 0.02em;
  flex-shrink: 0
}

.staff-modal__avatar--photo {
  overflow: hidden;
  background: transparent;
  border: none;
  padding: 0
}

.staff-modal__avatar--photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%
}

.staff-modal__contact {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  align-items: center;
  text-align: center
}

.staff-modal__right {
  display: flex;
  flex-direction: column;
  gap: 0.6rem
}

.staff-modal__name {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.3
}

.staff-modal__position {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: var(--color-text-muted)
}

.staff-modal__badges {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-top: 0.75rem
}

.staff-modal__badges-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem
}

.staff-modal__subjects {
  display: flex;
  flex-direction: column;
  gap: 0.35rem
}

.staff-modal__subjects-heading {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  margin: 0;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid var(--color-border)
}

.staff-modal__subjects-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem
}

.staff-modal__bio-heading {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  margin: 0 0 0.25rem 0;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid var(--color-border)
}

.staff-modal__bio {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--color-text);
  line-height: 1.7;
  margin-top: 1rem;
}

.staff-photo-lightbox {
  position: fixed;
  inset: 0;
  z-index: 1100;
  background: rgba(0, 0, 0, 0.8);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 2rem
}

.staff-photo-lightbox.is-open {
  display: flex
}

.staff-photo-lightbox__close {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  background: rgba(255, 255, 255, 0.15);
  border: none;
  cursor: pointer;
  color: var(--color-background);
  padding: 0.5rem;
  border-radius: 50%;
  transition: background var(--transition-base)
}

.staff-photo-lightbox__close:hover {
  background: rgba(255, 255, 255, 0.3)
}

.staff-photo-lightbox__img {
  max-width: 90vw;
  max-height: 85vh;
  object-fit: contain;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg)
}

.staff-empty__reset {
  display: inline-flex;
  align-items: center;
  padding: 0.6rem 1.5rem;
  background: var(--color-primary);
  color: var(--color-background);
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--transition-base), transform var(--transition-base)
}

.staff-empty__reset:hover,
.staff-empty__reset:focus-visible {
  background: var(--color-primary-dark);
  transform: translateY(-1px)
}

@media (max-width:1024px) {
  .staff-dept__grid {
    grid-template-columns: repeat(2, 1fr)
  }
}

@media (max-width:768px) {
  .staff-filter__inner {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding-bottom: 0
  }

  .staff-filter__search {
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--color-border)
  }

  .staff-filter__input {
    width: 100%
  }

  .staff-filter .cat-subs {
    border-top: none
  }

  .staff-directory {
    padding: 2.5rem 1rem 4rem
  }

  .staff-dept__grid {
    grid-template-columns: repeat(2, 1fr)
  }

  .staff-modal__body {
    grid-template-columns: 1fr;
    text-align: center
  }

  .staff-modal__left {
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap
  }

  .staff-modal__avatar {
    width: 100px;
    height: 100px;
    font-size: 1.8rem
  }

  .staff-modal__right {
    align-items: center
  }

  .staff-modal__badges-row,
  .staff-modal__subjects-row {
    justify-content: center
  }

  .staff-modal__subjects-heading,
  .staff-modal__bio-heading {
    text-align: center
  }
}

@media (max-width:480px) {
  .staff-dept__grid {
    grid-template-columns: 1fr
  }

  .staff-card__avatar,
  .staff-card__avatar--photo {
    width: 48px;
    height: 48px;
    font-size: 0.95rem
  }
}

.error-page {
  position: relative;
  min-height: calc(100vh - var(--navbar-height) - 72px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5rem 1.5rem;
  background-color: var(--color-surface);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cpath d='M50 33v34M33 50h34' stroke='rgba(200%2C169%2C81%2C.09)' stroke-width='1.5' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");
  text-align: center
}

.error-page__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
  max-width: 560px;
  width: 100%
}

.error-page__code {
  display: block;
  font-family: var(--font-heading);
  font-size: clamp(6rem, 20vw, 10rem);
  font-weight: 900;
  line-height: 1;
  color: var(--color-secondary);
  opacity: 0.18;
  letter-spacing: -0.04em;
  user-select: none;
  margin-bottom: -1rem
}

.error-page__title {
  font-family: var(--font-heading);
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.2;
  margin: 0
}

.error-page__description {
  font-family: var(--font-body);
  font-size: 1.05rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  margin: 0
}

@media (max-width:768px) {
  .error-page {
    padding: 4rem 1.25rem;
    min-height: calc(100vh - var(--navbar-height) - 60px)
  }
}

@media (max-width:480px) {
  .error-page__description {
    font-size: 0.95rem
  }
}

.auth-page {
  min-height: 100vh;
  background: var(--color-primary-dark);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem 1.5rem;
  position: relative;
  overflow: hidden
}

.auth-page::before,
.auth-page::after {
  content: '';
  position: absolute;
  background: rgba(255, 255, 255, 0.03);
  pointer-events: none;
  border-radius: 4px
}

.auth-page::before {
  width: 400px;
  height: 80px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%)
}

.auth-page::after {
  width: 80px;
  height: 400px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%)
}

.auth-card {
  background: var(--color-background);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  width: 100%;
  max-width: 440px;
  padding: 2.5rem 2rem;
  position: relative;
  z-index: 1
}

.auth-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-bottom: 2rem;
  text-decoration: none;
  color: var(--color-primary)
}

.auth-logo__img {
  width: 8rem;
}

.auth-logo__cross {
  display: block;
  width: 28px;
  height: 28px;
  position: relative;
  flex-shrink: 0
}

.auth-logo__cross::before,
.auth-logo__cross::after {
  content: '';
  position: absolute;
  background: var(--color-secondary);
  border-radius: 2px
}

.auth-logo__cross::before {
  width: 4px;
  height: 100%;
  left: 50%;
  transform: translateX(-50%)
}

.auth-logo__cross::after {
  width: 100%;
  height: 4px;
  top: 38%;
  transform: translateY(-50%)
}

.auth-logo__text {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.3;
  color: var(--color-primary)
}

.auth-card__title {
  font-family: var(--font-heading);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--color-primary);
  text-align: center;
  margin-bottom: 0.4rem
}

.auth-card__subtitle {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: var(--color-text-muted);
  text-align: center;
  margin-bottom: 2rem;
  line-height: 1.6
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem
}

.auth-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem
}

.auth-form__label {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted)
}

.auth-form__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem
}

.auth-form__remember {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-ui);
  font-size: 0.875rem;
  color: var(--color-text-muted);
  cursor: pointer
}

.auth-form__remember input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--color-primary);
  cursor: pointer;
  flex-shrink: 0
}

.auth-form__forgot {
  font-family: var(--font-ui);
  font-size: 0.875rem;
  color: var(--color-primary);
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--transition-fast)
}

.auth-form__forgot:hover,
.auth-form__forgot:focus-visible {
  color: var(--color-secondary-dark);
  text-decoration: underline
}

.auth-form__submit {
  margin-top: 0.5rem;
  width: 100%;
  justify-content: center
}

.auth-card__divider {
  border: none;
  border-top: 1px solid var(--color-border);
  margin: 1.75rem 0 1.25rem
}

.auth-card__back {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  font-family: var(--font-ui);
  font-size: 0.875rem;
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color var(--transition-fast)
}

.auth-card__back:hover,
.auth-card__back:focus-visible {
  color: var(--color-primary)
}

.auth-card__back svg {
  flex-shrink: 0
}

.auth-card__note {
  font-family: var(--font-ui);
  font-size: 0.875rem;
  color: var(--color-text-muted);
  text-align: center;
  line-height: 1.6
}

.auth-card__note a {
  color: var(--color-primary);
  text-decoration: none
}

.auth-card__note a:hover,
.auth-card__note a:focus-visible {
  text-decoration: underline
}

.auth-success {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  text-align: center;
  padding: 1rem 0
}

.auth-success__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(26, 58, 107, 0.07);
  color: var(--color-primary)
}

.auth-success__text {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: var(--color-text-muted);
  line-height: 1.65
}

@media (max-width:480px) {
  .auth-card {
    padding: 2rem 1.5rem
  }

  .auth-card__title {
    font-size: 1.35rem
  }

  .auth-form__row {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem
  }
}

.search-input-group {
  max-width: 640px;
}

.search-results {
  padding: 3rem 1.5rem 5rem
}

.search-results__inner {
  max-width: 860px;
  margin: 0 auto
}

.search-results__form {
  display: flex;
  gap: 0.75rem;
  margin-bottom: 2rem
}

.search-results__input {
  flex: 1
}

.search-results__btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  white-space: nowrap
}

.search-results__meta {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: var(--color-text-muted);
  margin-bottom: 0;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--color-border)
}

.search-results__meta strong {
  color: var(--color-primary);
  font-weight: 600
}

.search-results__list {
  display: flex;
  flex-direction: column
}

.search-result-item {
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--color-border)
}

.search-result-item__meta {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.5rem
}

.search-result-item__type {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-background);
  background: var(--color-primary);
  padding: 0.15rem 0.6rem;
  border-radius: 20px
}

.search-result-item__date {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  color: var(--color-text-muted)
}

.search-result-item__title {
  font-family: var(--font-heading);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 0.5rem;
  line-height: 1.35
}

.search-result-item__title a {
  text-decoration: none;
  transition: color var(--transition-fast)
}

.search-result-item__title a:hover,
.search-result-item__title a:focus-visible {
  color: var(--color-secondary-dark)
}

.search-result-item__excerpt {
  font-size: 0.95rem;
  color: var(--color-text-muted);
  line-height: 1.65
}

.search-result-item__excerpt mark {
  background: rgba(200, 169, 81, 0.25);
  color: inherit;
  border-radius: 2px;
  padding: 0 0.1em
}

.search-results__empty {
  text-align: center;
  padding: 4rem 1.5rem
}

.search-results__empty-icon {
  display: block;
  margin: 0 auto 1.5rem;
  color: var(--color-border)
}

.search-results__empty-title {
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 0.5rem
}

.search-results__empty-text {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  color: var(--color-text-muted);
  line-height: 1.6
}

@media (max-width:768px) {
  .search-results__form {
    flex-direction: column
  }

  .search-results__btn {
    justify-content: center
  }
}
/* =========================================================
   Empty state
   ========================================================= */

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 5rem 1.5rem;
  gap: 1.5rem;
  background-color: var(--color-surface);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cpath d='M50 33v34M33 50h34' stroke='rgba(200%2C169%2C81%2C.07)' stroke-width='1.5' stroke-linecap='round' fill='none'/%3E%3C/svg%3E")
}

.empty-state__icon {
  width: 72px;
  height: 72px;
  color: var(--color-secondary);
  opacity: 0.35
}

.empty-state__icon svg {
  width: 100%;
  height: 100%
}

.empty-state__text {
  font-family: var(--font-body);
  font-size: 1.05rem;
  color: var(--color-text-muted);
  max-width: 420px;
  margin: 0;
  line-height: 1.6
}

.cat-empty {
  display: none
}

.cat-empty.is-visible {
  display: block
}

.empty-state--staff {
  display: none
}

.empty-state--staff.is-visible {
  display: flex
}

/* =========================================================
   Cookie consent banner
   ========================================================= */

.cookie-consent-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 490;
  background: var(--color-primary-dark);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding: 1rem 0;
  box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.3)
}

.cookie-consent-banner__inner {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap
}

.cookie-consent-banner__text {
  flex: 1;
  font-family: var(--font-body);
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.8);
  margin: 0;
  line-height: 1.5
}

.cookie-consent-banner__link {
  color: var(--color-secondary);
  text-decoration: underline;
  text-underline-offset: 2px
}

.cookie-consent-banner__link:hover {
  color: var(--color-secondary-dark)
}

.cookie-consent-banner__actions {
  display: flex;
  gap: 0.625rem;
  flex-shrink: 0
}

.btn-cookie-accept {
  background: var(--color-secondary);
  color: var(--color-primary-dark);
  border: none;
  padding: 0.5rem 1.25rem;
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 0.85rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--transition-fast), transform var(--transition-fast)
}

.btn-cookie-accept:hover,
.btn-cookie-accept:focus-visible {
  background: var(--color-secondary-dark);
  transform: translateY(-1px)
}

.btn-cookie-decline {
  background: transparent;
  color: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.3);
  padding: 0.5rem 1.25rem;
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 0.85rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: border-color var(--transition-fast), color var(--transition-fast)
}

.btn-cookie-decline:hover,
.btn-cookie-decline:focus-visible {
  border-color: rgba(255, 255, 255, 0.6);
  color: rgba(255, 255, 255, 1)
}

@media (max-width: 640px) {
  .cookie-consent-banner__inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.875rem
  }

  .cookie-consent-banner__actions {
    width: 100%
  }

  .btn-cookie-accept,
  .btn-cookie-decline {
    flex: 1;
    justify-content: center
  }
}

/* =====================================================================
   POST / PAGE BODY TYPOGRAPHY
   ===================================================================== */

.post-body {
  background: #fff;
  padding: 3rem 0 4rem
}

.post-body__inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.post-body__title {
  font-family: var(--font-heading);
  color: var(--color-primary);
  font-size: clamp(1.6rem, 4vw, 2.2rem);
  line-height: 1.25;
  margin-bottom: 0.5rem
}

.post-body__featured-image {
  margin-bottom: 1.75rem
}

.post-body__featured-image img {
  width: 100%;
  height: auto;
  display: block
}

.post-body__content p {
  font-size: 1.05rem;
  line-height: 1.85;
  margin-bottom: 1.5rem;
  color: var(--color-text)
}

.post-body__content h2 {
  font-family: var(--font-heading);
  color: var(--color-primary);
  font-size: 1.45rem;
  margin-top: 2.5rem;
  margin-bottom: 0.875rem;
  padding-left: 0.875rem;
  border-left: 3px solid var(--color-secondary);
  line-height: 1.3
}

.post-body__content h3 {
  font-family: var(--font-heading);
  color: var(--color-primary);
  font-size: 1.2rem;
  margin-top: 2rem;
  margin-bottom: 0.75rem;
  line-height: 1.3
}

.post-body__content h4,
.post-body__content h5,
.post-body__content h6 {
  font-family: var(--font-heading);
  color: var(--color-primary);
  margin-top: 1.5rem;
  margin-bottom: 0.625rem
}

.post-body__content blockquote {
  background: var(--color-background-light, #f8f7f4);
  border-left: 4px solid var(--color-secondary);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin: 2rem 0;
  padding: 1.25rem 1.5rem;
  font-style: italic;
  color: var(--color-text-muted, #555)
}

.post-body__content blockquote p:last-child {
  margin-bottom: 0
}

.post-body__content ul,
.post-body__content ol {
  margin-bottom: 1.5rem;
  padding-left: 1.75rem
}

.post-body__content li {
  font-size: 1.05rem;
  line-height: 1.8;
  margin-bottom: 0.375rem
}

.post-body__content a:not([class]) {
  color: var(--color-primary);
  text-decoration: underline;
  text-decoration-color: var(--color-secondary);
  text-underline-offset: 3px;
  transition: color var(--transition-fast)
}

.post-body__content a:not([class]):hover {
  color: var(--color-secondary-dark, #b8880f)
}

.post-body__content figure {
  margin: 2rem 0;
  text-align: center;
  display: block;
  cursor: pointer
}

.post-body__content figure img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-sm)
}

.post-body__content figcaption {
  font-size: 0.875rem;
  color: var(--color-text-muted, #666);
  margin-top: 0.5rem;
  font-style: italic
}

.post-body__content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-sm)
}

/* Image alignment — block modes (text above/below only) */
.post-body__content .align-left,
.event-info__body .align-left {
  display: block;
  margin-left: 0;
  margin-right: auto;
  text-align: left
}

.post-body__content .align-center,
.event-info__body .align-center {
  display: block;
  margin-left: auto;
  margin-right: auto;
  text-align: center
}

.post-body__content .align-right,
.event-info__body .align-right {
  display: block;
  margin-left: auto;
  margin-right: 0;
  text-align: right
}

/* Image alignment — float/wrap modes (text wraps around image) */
.post-body__content .float-left,
.event-info__body .float-left {
  float: left;
  margin: 0 1.5rem 1rem 0;
  text-align: left
}

.post-body__content .float-right,
.event-info__body .float-right {
  float: right;
  margin: 0 0 1rem 1.5rem;
  text-align: right
}

/* Clearfix for floated images */
.post-body__content::after,
.event-info__body::after {
  content: '';
  display: table;
  clear: both
}

.post-body__content hr {
  border: none;
  border-top: 1px solid var(--color-border, #e5e2d9);
  margin: 2.5rem 0
}

.post-body__content table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 1.5rem;
  font-size: 0.95rem
}

.post-body__content th,
.post-body__content td {
  padding: 0.625rem 0.875rem;
  border: 1px solid var(--color-border, #e5e2d9);
  text-align: left
}

.post-body__content th {
  background: var(--color-primary);
  color: #fff;
  font-family: var(--font-ui);
  font-weight: 600
}

.post-body__content tr:nth-child(even) td {
  background: var(--color-background-light, #f8f7f4)
}

/* Attachments section */
.post-attachments {
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--color-border)
}

.post-attachments__heading {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  color: var(--color-primary);
  margin-bottom: 1rem
}

.attachment-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .5rem
}

.attachment-list__item {
  margin: 0
}

.attachment-item {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .75rem 1rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: background var(--transition-base), border-color var(--transition-base)
}

.attachment-item:hover,
.attachment-item:focus-visible {
  background: var(--color-surface-alt);
  border-color: var(--color-secondary)
}

.attachment-item__icon {
  flex-shrink: 0;
  color: var(--color-secondary-dark)
}

.attachment-item__name {
  flex: 1;
  font-size: .95rem;
  color: var(--color-primary);
  font-weight: 500;
  line-height: 1.4
}

.attachment-item__size {
  flex-shrink: 0;
  font-size: .75rem
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .post-body {
    padding: 2rem 0 3rem
  }

  .post-body__inner {
    padding: 0 1rem
  }

  .post-body__content h2 {
    font-size: 1.25rem
  }

  .post-body__content h3 {
    font-size: 1.1rem
  }
}

@media (max-width: 480px) {
  .post-body {
    padding: 1.5rem 0 2.5rem
  }

  .post-body__inner {
    padding: 0 0.875rem
  }

  .post-body__title {
    font-size: 1.4rem
  }

  .post-body__content p,
  .post-body__content li {
    font-size: 1rem
  }
}

/* ==========================================================================
   Embedded Gallery (shortcode rendered in post/page content)
   ========================================================================== */

.embedded-gallery {
    margin: 2rem 0;
}

.embedded-gallery__grid {
    columns: 3;
    column-gap: 0.625rem;
}

@media (max-width: 768px) {
    .embedded-gallery__grid {
        columns: 2;
    }
}

@media (max-width: 480px) {
    .embedded-gallery__grid {
        columns: 1;
    }
}

.embedded-gallery__item {
    break-inside: avoid;
    margin-bottom: 0.625rem;
    border-radius: 0.375rem;
    overflow: hidden;
}

.embedded-gallery__link {
    display: block;
    width: 100%;
    padding: 0;
    border: none;
    background: none;
    cursor: pointer;
}

.embedded-gallery__link img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.25s ease;
}

.embedded-gallery__link:hover img,
.embedded-gallery__link:focus img {
    transform: scale(1.03);
}

/* ============================================================
   Opening hours
   ============================================================ */
.opening-hours-list {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  max-width: 640px
}

.opening-hours-row {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .6rem 1rem;
  background: var(--color-surface);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border)
}

.opening-hours-row--open {
  background: rgba(16, 185, 129, 0.12);
  border-color: rgba(16, 185, 129, 0.5)
}

.opening-hours-row__label {
  font-weight: 600;
  flex: 1
}

.opening-hours-row__time {
  font-variant-numeric: tabular-nums;
  font-size: .9rem;
  color: var(--color-text)
}

/* ============================================================
   Timetable
   ============================================================ */
.timetable-grid {
  min-width: 480px
}

.timetable-cell--today {
  background: rgba(30, 58, 143, 0.06) !important;
  font-weight: 600
}

.timetable-entry {
  padding: .25rem 0;
  font-size: .875rem;
  border-bottom: 1px solid var(--color-surface-alt)
}

.timetable-entry:last-child {
  border-bottom: none
}

/* ============================================================
   Custom entries
   ============================================================ */
.custom-entries {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 720px
}

.custom-entry {
  background: var(--color-background);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 1rem 1.25rem
}

.custom-entry__label {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: .25rem
}

.custom-entry__time {
  font-size: .875rem;
  margin-bottom: .25rem
}

/* ============================================================
   Validity badge + calendar notice
   ============================================================ */
.schedule-validity-badge {
  font-size: .75rem;
  padding: .2em .5em
}

.schedule-calendar-notice {
  margin-bottom: 1.5rem
}

/* ============================================================
   Featured variants — dual & carousel
   ============================================================ */
.featured__section-header {
  margin-bottom: 1.5rem
}

.featured--single .featured__section-header {
  grid-column: 1 / -1
}

.featured--dual .featured__dual-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem
}

.featured__card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--color-background);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  transition: box-shadow var(--transition-base), transform var(--transition-base)
}

.featured__card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px)
}

.featured__card-image-link {
  display: block;
  aspect-ratio: 16/9;
  overflow: hidden
}

.featured__card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow)
}

.featured__card:hover .featured__card-img {
  transform: scale(1.04)
}

.featured__card-image-placeholder {
  aspect-ratio: 16/9;
  background: var(--color-primary-mid);
  opacity: .15
}

.featured__card-body {
  padding: 1.5rem 1.5rem 2.75rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
  flex: 1
}

.featured__card-meta {
  display: flex;
  align-items: center;
  gap: .75rem;
  flex-wrap: wrap;
  font-size: .8rem;
  color: var(--color-text-muted)
}

.featured__card-title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
  margin: 0
}

.featured__card-title a {
  color: var(--color-primary);
  text-decoration: none
}

.featured__card-title a:hover {
  color: var(--color-secondary)
}

.featured__card-excerpt {
  font-size: .9rem;
  color: var(--color-text-secondary);
  line-height: 1.6;
  flex: 1
}

.featured__card:not(.featured__card--overlay) .featured__link {
  position: absolute;
  bottom: 0;
  right: 0;
  padding: 0.45rem 1.1rem;
  background: var(--color-primary);
  color: var(--color-background);
  font-family: var(--font-ui);
  font-size: 0.8rem;
  font-weight: 600;
  border-radius: var(--radius-sm) 0 0 0;
  text-decoration: none;
  gap: 0;
  transition: background var(--transition-base), color var(--transition-base)
}

.featured__card:not(.featured__card--overlay) .featured__link:hover,
.featured__card:not(.featured__card--overlay) .featured__link:focus-visible {
  background: var(--color-secondary);
  color: var(--color-primary)
}

/* Grid layout (3+) */
.featured--grid .featured__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  align-items: stretch
}

.featured__grid-main {
  display: flex;
  flex-direction: column;
  background: var(--color-background);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  transition: box-shadow var(--transition-base), transform var(--transition-base)
}

.featured__grid-main:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px)
}

.featured__grid-main-image-link {
  display: block;
  overflow: hidden;
  flex: 1;
  min-height: 200px
}

.featured__grid-main-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow)
}

.featured__grid-main:hover .featured__grid-main-img {
  transform: scale(1.04)
}

.featured__grid-main-placeholder {
  flex: 1;
  min-height: 200px;
  background: var(--color-primary-mid);
  opacity: .15
}

.featured__grid-main-body {
  padding: 1.5rem 1.5rem 2.75rem;
  display: flex;
  flex-direction: column;
  gap: .75rem
}

.featured__grid-main-title {
  font-family: var(--font-heading);
  font-size: clamp(1.1rem, 1.8vw, 1.5rem);
  font-weight: 700;
  line-height: 1.3;
  margin: 0
}

.featured__grid-main-title a {
  color: var(--color-primary);
  text-decoration: none
}

.featured__grid-main-title a:hover {
  color: var(--color-secondary)
}

.featured__grid-main-excerpt {
  font-size: .95rem;
  color: var(--color-text-muted);
  line-height: 1.7
}

.featured__grid-main-body .featured__link {
  position: absolute;
  bottom: 0;
  right: 0;
  padding: 0.45rem 1.1rem;
  background: var(--color-primary);
  color: var(--color-background);
  font-family: var(--font-ui);
  font-size: 0.8rem;
  font-weight: 600;
  border-radius: var(--radius-sm) 0 0 0;
  text-decoration: none;
  gap: 0;
  transition: background var(--transition-base), color var(--transition-base)
}

.featured__grid-main-body .featured__link:hover,
.featured__grid-main-body .featured__link:focus-visible {
  background: var(--color-secondary);
  color: var(--color-primary)
}

.featured__grid-side {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 1fr;
  gap: 1rem
}

.featured__grid-side .featured__card-image-link {
  aspect-ratio: 4 / 3
}

.featured__grid-side .featured__card-image-placeholder {
  aspect-ratio: 4 / 3
}

.featured__grid-side .featured__card-body {
  padding: 0.75rem 1rem;
  gap: 0.4rem
}

.featured__grid-side .featured__card-title {
  font-size: 0.95rem
}

.featured__grid-side .featured__card-meta {
  font-size: 0.75rem
}

/* Overlay card (4-5 featured posts) */
.featured__card--overlay {
  position: relative;
  overflow: hidden;
  text-decoration: none;
  display: block
}

.featured__card--overlay-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow)
}

.featured__card--overlay-placeholder {
  position: absolute;
  inset: 0;
  background: var(--color-primary-mid);
  opacity: .3
}

.featured__card--overlay:hover .featured__card--overlay-img {
  transform: scale(1.06)
}

.featured__card--overlay-body {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 0.9rem 1rem;
  background: linear-gradient(to top, rgba(0,0,0,.8) 0%, rgba(0,0,0,.25) 55%, transparent 100%)
}

.featured__card--overlay-meta {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  font-size: 0.72rem;
  color: rgba(255,255,255,.7);
  margin-bottom: 0.3rem
}

.featured__card--overlay-title {
  font-family: var(--font-heading);
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.3;
  margin: 0 0 0.5rem
}

.featured__card--overlay .featured__link {
  color: var(--color-secondary);
  font-size: 0.8rem
}

.featured__card--overlay:hover .featured__link {
  color: #fff;
  gap: 0.6rem
}

/* ============================================================
   Homepage events section subtitle
   ============================================================ */
.section-subtitle {
  font-size: 1rem;
  color: var(--color-text-secondary);
  margin-top: .5rem
}

.section-subtitle--light {
  color: rgba(255,255,255,.7)
}

/* Events section — event item description */
.event-item__desc {
  font-size: .82rem;
  color: rgba(255,255,255,.55);
  margin: .25rem 0 0;
  line-height: 1.5
}

/* ============================================================
   Homepage gallery section
   ============================================================ */
.home-gallery {
  background: var(--color-background)
}

.home-gallery__header {
  margin-bottom: 2.5rem;
  text-align: center
}

.home-gallery__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  margin-bottom: 2.5rem
}

.home-gallery__more {
  margin-top: .5rem
}

/* ============================================================
   Homepage documents section
   ============================================================ */
.home-documents {
  background: var(--color-surface, #f8f7f4)
}

.home-documents__header {
  margin-bottom: 2rem;
  text-align: center
}

.home-documents__categories {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1.75rem;
  padding-bottom: .25rem;
  overflow-x: auto;
  justify-content: center;
}

.home-documents__chip {
  display: inline-flex;
  align-items: center;
  padding: .35rem .9rem;
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 600;
  font-family: var(--font-ui);
  background: var(--color-background);
  color: var(--color-primary);
  border: 1.5px solid var(--color-primary-mid);
  transition: all var(--transition-base);
  white-space: nowrap;
  cursor: pointer
}

.home-documents__chip:hover,
.home-documents__chip:focus-visible {
  background: var(--color-primary);
  color: var(--color-background);
  border-color: var(--color-primary)
}

.home-documents__chip.is-active {
  background: var(--color-primary);
  color: var(--color-background);
  border-color: var(--color-primary)
}

.home-documents__list {
  max-width: 900px;
  margin: 0 auto 2rem
}

.home-documents__more {
  margin-top: .5rem
}


/* ============================================================
   Responsive overrides
   ============================================================ */
@media (max-width: 1200px) {
  .home-gallery__grid {
    grid-template-columns: repeat(3, 1fr)
  }
}

@media (max-width: 1024px) {
  .events__body {
    grid-template-columns: 1fr
  }

  .home-gallery__grid {
    grid-template-columns: repeat(2, 1fr)
  }
}

@media (max-width: 768px) {
  .featured--dual .featured__dual-grid,
  .featured--grid .featured__grid {
    grid-template-columns: 1fr
  }

  /* Side cards: single column of horizontal strips */
  .featured__grid-side {
    grid-template-columns: 1fr;
    grid-auto-rows: auto
  }

  .featured__grid-side .featured__card,
  .featured__grid-side .featured__card--overlay {
    flex-direction: row;
    min-height: 100px;
    border-radius: var(--radius-md)
  }

  /* Normal card strip — image */
  .featured__grid-side .featured__card-image-link {
    width: 110px;
    flex-shrink: 0;
    aspect-ratio: unset;
    height: 100%
  }

  .featured__grid-side .featured__card-image-placeholder {
    width: 110px;
    flex-shrink: 0;
    aspect-ratio: unset;
    height: 100%
  }

  /* Normal card strip — body */
  .featured__grid-side .featured__card-body {
    padding: 0.55rem 0.75rem;
    gap: 0.2rem;
    justify-content: center
  }

  .featured__grid-side .featured__card-meta {
    font-size: 0.7rem
  }

  .featured__grid-side .featured__card-title {
    font-size: 0.875rem;
    -webkit-line-clamp: 2
  }

  /* Overlay card strip — reset absolute positioning, become horizontal */
  .featured__grid-side .featured__card--overlay {
    position: relative;
    display: flex
  }

  .featured__grid-side .featured__card--overlay-img {
    position: static;
    width: 110px;
    height: 100%;
    flex-shrink: 0;
    object-fit: cover
  }

  .featured__grid-side .featured__card--overlay-placeholder {
    position: static;
    width: 110px;
    height: 100%;
    flex-shrink: 0;
    opacity: .2
  }

  .featured__grid-side .featured__card--overlay-body {
    position: static;
    background: none;
    padding: 0.55rem 0.75rem;
    gap: 0.2rem;
    justify-content: center;
    flex: 1
  }

  .featured__grid-side .featured__card--overlay-meta {
    color: var(--color-text-muted)
  }

  .featured__grid-side .featured__card--overlay-title {
    color: var(--color-primary);
    font-size: 0.875rem;
    margin: 0.15rem 0 0.3rem
  }

  .featured__grid-side .featured__card--overlay .featured__link {
    color: var(--color-primary);
    font-size: 0.78rem
  }

  /* Reset absolute link to inline on mobile strips */
  .featured__grid-side .featured__card:not(.featured__card--overlay) .featured__link {
    position: static;
    background: none;
    color: var(--color-primary);
    font-size: 0.78rem;
    font-weight: 600;
    padding: 0;
    border-radius: 0
  }

  .home-gallery__grid {
    grid-template-columns: repeat(2, 1fr)
  }
}

@media (max-width: 480px) {
  .home-gallery__grid {
    grid-template-columns: 1fr
  }
}
