:root {
  --blue-dark: #12385c;
  --blue: #1f4e79;
  --blue-bright: #2f6fa7;
  --blue-light: #e7f0f8;
  --red: #7a2f2f;
  --gold: #f2c14e;
  --ink: #1f2933;
  --muted: #586575;
  --line: #d7dee8;
  --surface: #ffffff;
  --surface-alt: #f5f8fb;
  --max: 1160px;
}

* {
  box-sizing: border-box;
}

html {
  font-family: Arial, Helvetica, sans-serif;
  color: var(--ink);
  background: var(--surface);
  line-height: 1.5;
}

body {
  margin: 0;
}

a {
  color: var(--blue);
  font-weight: 700;
}

a:hover {
  color: var(--red);
}

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

.wrap {
  width: min(calc(100% - 32px), var(--max));
  margin-inline: auto;
}

.skip-link {
  position: absolute;
  left: 1rem;
  top: 1rem;
  z-index: 10;
  transform: translateY(-150%);
  background: var(--gold);
  color: #111;
  padding: .6rem .9rem;
}

.skip-link:focus {
  transform: translateY(0);
}

.ownership-banner {
  background: #f0f2f5;
  border-bottom: 1px solid var(--line);
  color: #293847;
  font-size: .9rem;
}

.ownership-banner__inner {
  display: flex;
  align-items: center;
  gap: .6rem;
  min-height: 38px;
}

.ownership-banner__flag {
  width: 24px;
  height: 16px;
  border: 1px solid #b8c0ca;
  background:
    linear-gradient(#7a2f2f 0 14%, #fff 14% 28%, #7a2f2f 28% 42%, #fff 42% 56%, #7a2f2f 56% 70%, #fff 70% 84%, #7a2f2f 84%),
    linear-gradient(90deg, var(--blue) 0 45%, transparent 45%);
}

.brand-bar {
  background: var(--surface);
}

.brand-bar__inner,
.primary-nav__inner {
  display: flex;
  align-items: center;
}

.brand-bar__inner {
  justify-content: space-between;
  gap: 1rem;
  min-height: 112px;
  padding-block: 1rem;
}

.brand,
.footer-brand {
  display: inline-flex;
  align-items: center;
  gap: .85rem;
  color: var(--blue-dark);
  text-decoration: none;
}

.brand img,
.footer-brand img {
  border-radius: 50%;
  object-fit: contain;
}

.brand strong {
  display: block;
  font-size: 2.35rem;
  line-height: 1;
}

.brand span span {
  display: block;
  color: var(--red);
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: 0;
}

.brand-bar__cta,
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: .75rem 1rem;
  border: 2px solid transparent;
  text-decoration: none;
  font-weight: 700;
}

.brand-bar__cta,
.button--primary {
  background: var(--red);
  color: #fff;
}

.button--secondary {
  border-color: #fff;
  color: #fff;
}

.menu-toggle {
  display: none;
  align-items: center;
  gap: .55rem;
  min-height: 44px;
  border: 0;
  background: transparent;
  color: var(--blue-dark);
  cursor: pointer;
  font: inherit;
  font-weight: 800;
  letter-spacing: .02em;
  padding: .6rem 0;
}

.menu-toggle__icon,
.menu-toggle__icon::before,
.menu-toggle__icon::after {
  display: block;
  width: 22px;
  height: 3px;
  background: currentColor;
  border-radius: 3px;
}

.menu-toggle__icon {
  position: relative;
}

.menu-toggle__icon::before,
.menu-toggle__icon::after {
  content: "";
  position: absolute;
  left: 0;
}

.menu-toggle__icon::before {
  top: -7px;
}

.menu-toggle__icon::after {
  top: 7px;
}

.site-header[data-menu-open="true"] .menu-toggle__label {
  font-size: 0;
}

.site-header[data-menu-open="true"] .menu-toggle__label::after {
  content: "CLOSE";
  font-size: 1rem;
}

.site-header[data-menu-open="true"] .menu-toggle__icon {
  background: transparent;
}

.site-header[data-menu-open="true"] .menu-toggle__icon::before {
  top: 0;
  transform: rotate(45deg);
}

.site-header[data-menu-open="true"] .menu-toggle__icon::after {
  top: 0;
  transform: rotate(-45deg);
}

.primary-nav {
  background: var(--blue-dark);
  border-top: 5px solid var(--gold);
}

.primary-nav__inner {
  flex-wrap: wrap;
}

.primary-nav a {
  color: #fff;
  padding: 1rem .9rem;
  text-decoration: none;
}

.primary-nav a:hover,
.primary-nav a[aria-current="page"] {
  background: var(--blue-bright);
}

.hero {
  background:
    linear-gradient(90deg, rgba(18, 56, 92, .95), rgba(31, 78, 121, .86)),
    repeating-linear-gradient(135deg, rgba(255,255,255,.08) 0 2px, transparent 2px 18px);
  color: #fff;
  border-bottom: 8px solid var(--gold);
}

.hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(280px, .7fr);
  gap: 2rem;
  align-items: center;
  min-height: 520px;
  padding-block: 4rem;
}

.eyebrow {
  color: var(--red);
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .08em;
  margin: 0 0 .6rem;
  text-transform: uppercase;
}

.hero .eyebrow {
  color: var(--gold);
}

.hero h1,
.page-title h1 {
  font-size: 4.25rem;
  line-height: 1.02;
  margin: 0;
  max-width: 850px;
}

.hero__copy > p:not(.eyebrow),
.page-title p:not(.eyebrow) {
  font-size: 1.3rem;
  max-width: 720px;
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  margin-top: 1.5rem;
}

.hero-panel {
  background: #fff;
  color: var(--ink);
  border-top: 6px solid var(--gold);
  box-shadow: 0 18px 40px rgba(0, 0, 0, .25);
}

.hero-panel div,
.hero-panel article {
  padding: .85rem 1.25rem;
  border-bottom: 1px solid var(--line);
}

.hero-panel div:last-child,
.hero-panel article:last-child {
  border-bottom: 0;
}

.hero-panel span {
  color: var(--red);
  font-weight: 800;
}

.hero-panel strong {
  display: block;
  color: var(--blue-dark);
  font-size: 1.35rem;
}

.hero-panel__heading {
  background: var(--blue-dark);
}

.hero-panel__heading span,
.hero-panel__heading strong {
  color: #fff;
}

.hero-panel__heading span {
  color: var(--gold);
  display: block;
  font-size: .78rem;
  letter-spacing: .08em;
  margin-bottom: .2rem;
  text-transform: uppercase;
}

.announcement-item {
  align-items: start;
  display: grid;
  gap: 1rem;
  grid-template-columns: minmax(0, 1fr) auto;
}

.announcement-item span {
  display: inline-flex;
  width: max-content;
  margin-bottom: .28rem;
  background: var(--blue-light);
  color: var(--blue-dark);
  font-size: .72rem;
  letter-spacing: .04em;
  padding: .18rem .4rem;
  text-transform: uppercase;
}

.announcement-item strong {
  font-size: 1.08rem;
}

.announcement-item p {
  color: var(--muted);
  display: -webkit-box;
  font-size: .95rem;
  line-height: 1.3;
  margin: .14rem 0 0;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}

.announcement-item a,
.hero-panel__footer a {
  align-items: center;
  color: var(--blue-dark);
  display: inline-flex;
  min-height: 30px;
  white-space: nowrap;
}

.hero-panel__footer {
  background: var(--surface-alt);
  padding-block: .6rem;
}

.content-section,
.feature-band,
.news-band {
  padding-block: 3.5rem;
}

.content-section--intro {
  padding-block: 2.5rem;
}

.feature-band,
.page-title {
  background: var(--surface-alt);
}

.page-title {
  border-bottom: 1px solid var(--line);
  padding-block: 3.5rem;
}

.section-heading {
  margin-bottom: 1.5rem;
}

.section-heading h2 {
  color: var(--blue-dark);
  font-size: 2.4rem;
  margin: 0;
}

.card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.info-card {
  background: #fff;
  border: 1px solid var(--line);
  border-top: 6px solid var(--blue);
  padding: 1.25rem;
}

.info-card__icon {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin-bottom: .8rem;
  background: var(--gold);
  color: #111;
  font-weight: 800;
}

.info-card h2,
.info-card h3 {
  color: var(--blue-dark);
  margin: 0 0 .5rem;
}

.news-band__grid {
  display: grid;
  grid-template-columns: minmax(220px, .35fr) 1fr;
  gap: 2rem;
}

.notice-list {
  display: grid;
  gap: 1rem;
}

.notice-list article {
  border-left: 6px solid var(--gold);
  padding: 1rem 1.25rem;
  background: var(--surface-alt);
}

.notice-list h3 {
  margin: 0 0 .35rem;
  color: var(--blue-dark);
}

.prose {
  max-width: 850px;
}

.prose h2 {
  color: var(--blue-dark);
  margin-top: 2rem;
}

.prose li + li {
  margin-top: .35rem;
}

.prose table {
  width: 100%;
  border-collapse: collapse;
  margin-block: 1.5rem;
}

.prose th,
.prose td {
  border: 1px solid var(--line);
  padding: .75rem;
  text-align: left;
}

.prose th {
  background: var(--blue-light);
}

.event-calendar {
  margin-top: 2.5rem;
}

.event-calendar__header,
.event-calendar__layout,
.event-calendar__controls {
  display: flex;
  gap: 1rem;
}

.event-calendar__header {
  align-items: end;
  justify-content: space-between;
  margin-bottom: 1.25rem;
}

.event-calendar__header h2,
.event-calendar__month h3,
.event-calendar__details h3 {
  color: var(--blue-dark);
  margin: 0;
}

.event-calendar__header h2 {
  font-size: 2.4rem;
}

.event-calendar__controls {
  flex-wrap: wrap;
}

.event-calendar__controls button {
  min-height: 42px;
  border: 2px solid var(--blue);
  background: #fff;
  color: var(--blue-dark);
  cursor: pointer;
  font: inherit;
  font-weight: 800;
  padding: .55rem .85rem;
}

.event-calendar__controls button:hover {
  background: var(--blue-light);
}

.event-calendar__layout {
  align-items: start;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .42fr);
}

.event-calendar__month,
.event-calendar__details {
  background: #fff;
  border: 1px solid var(--line);
}

.event-calendar__month {
  padding: 1rem;
}

.event-calendar__month h3 {
  font-size: 1.35rem;
  margin-bottom: 1rem;
}

.event-calendar__weekdays,
.event-calendar__grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.event-calendar__weekdays {
  border-bottom: 2px solid var(--blue-dark);
  color: var(--blue-dark);
  font-size: .82rem;
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
}

.event-calendar__weekdays span {
  padding: .5rem .25rem;
}

.event-calendar__grid {
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-top: 0;
}

.event-calendar__blank,
.event-calendar__day {
  min-height: 88px;
  background: #fff;
}

.event-calendar__day {
  border: 0;
  color: var(--ink);
  cursor: pointer;
  font: inherit;
  padding: .5rem;
  text-align: left;
}

.event-calendar__day span {
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  color: var(--blue-dark);
  font-weight: 800;
}

.event-calendar__day em {
  display: block;
  width: max-content;
  margin-top: .65rem;
  background: var(--gold);
  color: #111;
  font-size: .72rem;
  font-style: normal;
  font-weight: 800;
  padding: .15rem .35rem;
  text-transform: uppercase;
}

.event-calendar__day:hover,
.event-calendar__day:focus {
  outline: 3px solid var(--blue-bright);
  outline-offset: -3px;
}

.event-calendar__day.has-events {
  box-shadow: inset 0 -5px 0 var(--gold);
}

.event-calendar__day.is-today span {
  background: var(--blue-light);
  border-radius: 50%;
}

.event-calendar__day.is-selected {
  background: var(--blue-dark);
  color: #fff;
}

.event-calendar__day.is-selected span {
  color: #fff;
}

.event-calendar__details {
  border-top: 6px solid var(--gold);
  padding: 1.25rem;
}

.event-calendar__details h3 {
  font-size: 1.35rem;
  margin-bottom: 1rem;
}

.event-calendar__event {
  border-top: 1px solid var(--line);
  padding-top: 1rem;
}

.event-calendar__event + .event-calendar__event {
  margin-top: 1rem;
}

.event-calendar__event h4 {
  color: var(--blue-dark);
  font-size: 1.05rem;
  margin: 0 0 .5rem;
}

.event-calendar__event p {
  margin: .35rem 0;
}

.site-footer {
  background: var(--blue-dark);
  color: #fff;
  padding-block: 2.5rem;
  border-top: 6px solid var(--gold);
}

.site-footer__grid {
  display: grid;
  grid-template-columns: 1.2fr .7fr .7fr;
  gap: 2rem;
}

.site-footer a {
  color: #fff;
}

.site-footer h2 {
  font-size: 1rem;
  margin: 0 0 .75rem;
}

.site-footer a:not(.footer-brand) {
  display: block;
  margin-bottom: .45rem;
}

.footer-brand {
  color: #fff;
  font-weight: 800;
}

@media (max-width: 820px) {
  .wrap {
    width: min(calc(100% - 28px), var(--max));
  }

  .ownership-banner {
    font-size: .82rem;
  }

  .brand-bar__inner {
    align-items: center;
    flex-direction: row;
    min-height: 84px;
    padding-block: .75rem;
  }

  .brand {
    min-width: 0;
  }

  .brand img {
    width: 64px;
    height: 64px;
    flex: 0 0 auto;
  }

  .brand strong {
    font-size: 1.42rem;
  }

  .brand span span {
    font-size: .94rem;
  }

  .brand-bar__cta {
    display: none;
  }

  .menu-toggle {
    display: inline-flex;
    flex: 0 0 auto;
    margin-left: auto;
  }

  .primary-nav {
    display: none;
    border-top: 4px solid var(--gold);
  }

  .site-header[data-menu-open="true"] .primary-nav {
    display: block;
  }

  .primary-nav__inner {
    align-items: stretch;
    flex-direction: column;
    gap: 0;
    padding-block: .35rem;
  }

  .primary-nav a {
    border-bottom: 1px solid rgba(255, 255, 255, .18);
    flex: none;
    padding: .95rem .25rem;
    text-align: left;
  }

  .hero__grid,
  .news-band__grid,
  .event-calendar__layout,
  .site-footer__grid {
    grid-template-columns: 1fr;
  }

  .hero__grid {
    min-height: auto;
    padding-block: 2.75rem;
  }

  .hero h1,
  .page-title h1 {
    font-size: 2.45rem;
  }

  .hero__copy > p:not(.eyebrow),
  .page-title p:not(.eyebrow) {
    font-size: 1.1rem;
  }

  .card-grid {
    grid-template-columns: 1fr;
  }

  .section-heading h2 {
    font-size: 2rem;
  }

  .event-calendar__header {
    align-items: stretch;
    flex-direction: column;
  }

  .event-calendar__header h2 {
    font-size: 2rem;
  }

  .event-calendar__controls button {
    flex: 1 1 auto;
  }

  .event-calendar__blank,
  .event-calendar__day {
    min-height: 72px;
  }
}

@media (max-width: 520px) {
  .brand {
    gap: .55rem;
  }

  .brand img {
    width: 52px;
    height: 52px;
  }

  .brand strong {
    font-size: 1.12rem;
  }

  .brand span span {
    font-size: .82rem;
  }

  .hero h1,
  .page-title h1 {
    font-size: 2rem;
  }

  .content-section,
  .feature-band,
  .news-band,
  .page-title {
    padding-block: 2.25rem;
  }

  .event-calendar__month {
    padding: .7rem;
  }

  .event-calendar__weekdays {
    font-size: .68rem;
  }

  .event-calendar__blank,
  .event-calendar__day {
    min-height: 56px;
  }

  .event-calendar__day {
    padding: .3rem;
  }

  .event-calendar__day span {
    width: 26px;
    height: 26px;
  }

  .event-calendar__day em {
    font-size: 0;
    width: 8px;
    height: 8px;
    margin-top: .35rem;
    border-radius: 50%;
    padding: 0;
  }

  .announcement-item {
    grid-template-columns: 1fr;
    gap: .35rem;
  }

  .announcement-item a {
    width: max-content;
  }

  .hero,
  .page-title {
    overflow-wrap: anywhere;
  }
}
