/*
Theme Name: Halton Regional Police Association WP Theme
Theme URI: https://www.hrpa.com
Description: WordPress theme for Halton Regional Police Association
Author: Dion Rodrigues
Author URI: http://www.dionrodrigues.dev
Version: 1.0
Tags: 

*/

/* ===== GLOBAL STYLES ===== */

html {
	margin: 0;
	padding: 0;
}

body {
	background: #fff;
	margin: 0;
	padding: 0;
	font-family: 'Open Sans', sans-serif;
}

.clear {
	clear: both;
}

p {
	
}

a {
	
}

h1 {
	
}

h2 {
	
}

h3 {
	
}

h4 {
	
}

:root {
	--primary: #24246B;      /* HEADERS / NAV */
	--cta: #9f2421;          /* CALL TO ACTIONS */
	--accent: #C9A548;       /* ACCENTS */
	--text: #1A1A1A;
	--muted: #4D4D4F;
	--panel: #FFFFFF;
	--border: rgba(36,36,107,.35);
	--container: 1200px;
}

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	color: var(--text);
	font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
	background: #fff;
}

.wrap {
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 10px;
}

/* ===== HEADER - TOP ROW ===== */

.utility {
	border-bottom: 1px solid rgba(0,0,0,.08);
	background: #fff;
}

.utility .wrap {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 18px;
	height: 40px;
	font-size: 14px;
	color: #111;
}

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

.utility a:hover {
	text-decoration: underline;
}

.icon {
	width: 28px;
	height: 27px;
	color: #111;
	display: inline-block;
}

.utility .tel {
	font-weight: 600;
}

/* ===== HEADER - MAIN ===== */

.header {
	background: var(--primary);
}

.header .wrap {
	display: flex;
	align-items: center;
	height: 92px;
}

.brand {
	display: flex;
	align-items: flex-end;
	gap: 14px;
	min-width: 260px;
}

.logo {
	display: flex;
	flex-direction: column;
	line-height: 1;
	color: #fff;
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 800;
	letter-spacing: .5px;
}

.logo img {
	max-width: 70%;
}

nav {
	flex: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	/*gap: 44px;*/ /*** FOR 5 MENU NAV ***/
	gap: 24px;
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 600;
	letter-spacing: .6px;
}

nav a {
	color: #fff;
	text-decoration: none;
	font-size: 16px;
	opacity: .95;
	padding: 10px 4px;
	transition: all 0.3s ease-in-out;
}

nav a:hover {
	opacity: 1;
	border-bottom: 2px solid var(--accent);
	box-sizing: border-box;
}

.header-cta {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	min-width: 190px;
}

.header-cta.mobile-only {
	display: none;
}

.btn {
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 700;
	letter-spacing: .6px;
	border: 0;
	background: var(--cta);
	color: #fff;
	padding: 12px 18px;
	border-radius: 3px;
	cursor: pointer;
	box-shadow: 0 2px 0 rgba(0,0,0,.18);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	white-space: nowrap;
}

.btn:hover {
	filter: brightness(1.05);
}

.btn:active {
	transform: translateY(1px);
}

.nav-toggle {
	display: none;
}

.nav-toggle {
	position: relative;
	width: 44px;
	height: 44px;
	background: transparent;
	border: 0;
	cursor: pointer;
	padding: 10px;
}

.nav-toggle__bar {
	position: absolute;
	left: 10px;
	right: 10px;
	height: 2px;
	background: #fff;
	transition: transform 0.25s ease,
	opacity 0.2s ease,
	top 0.25s ease;
}

.nav-toggle__bar:nth-child(1) {
	top: 14px;
}

.nav-toggle__bar:nth-child(2) {
	top: 21px;
}

.nav-toggle__bar:nth-child(3) {
	top: 28px;
}

.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) {
	opacity: 0;
}

.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) {
	top: 21px;
	transform: rotate(45deg);
}

.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) {
	top: 21px;
	transform: rotate(-45deg);
}

/* ===== HOMEPAGE BANNER ===== */

.hero {
	position: relative;
	width: 100%;
	min-height: 460px;
	border-bottom: 2px solid var(--border);
	background: none;
}

.hero::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 2;
	pointer-events: none;
	background: linear-gradient(
	to bottom,
	rgba(0,0,0,.45),
	rgba(0,0,0,.10) 50%,
	rgba(0,0,0,0)
	);
}

.hero::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 3;
	pointer-events: none;
	background: radial-gradient(
	1200px 420px at 20% 20%,
	rgba(0,0,0,.35),
	rgba(0,0,0,0) 60%
	);
	opacity: .55;
}

.hero .banner-rotator {
	position: relative;
	width: 100%;
	overflow: hidden;
	z-index: 1;
}

.hero .banner-track {
	display: flex;
	width: 100%;
	will-change: transform;
	transform: translate3d(0,0,0);
	transition: transform 700ms ease;
}

.hero .banner-item {
	flex: 0 0 100%;
	width: 100%;
	position: relative;
	height: clamp(320px, 45vw, 560px);
}

.hero .banner-image {
	width: 100%;
	height: 100%;
}

.hero .banner-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

@media (prefers-reduced-motion: reduce) {
	.hero .banner-track {
		transition: none !important;
	}
}

/* ===== HOME - MISSION STATEMENT ===== */

.mission {
	background: var(--panel);
	border-bottom: 1px solid var(--border);
	padding: 18px 0 26px;
}

.mission .wrap {
	text-align: center;
}

.mission .headline {
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 800;
	letter-spacing: 1px;
	color: var(--primary);
	text-transform: uppercase;
	font-size: 26px;
	margin: 6px 0 14px;
}

.mission-list {
	list-style: none;
	padding: 0;
	margin: 0 auto;
	max-width: 100%;
	display: block;
	font-size: 21px;
	line-height: 1.25;
	font-weight: 700;
	color: #111;
}

.mission-list li {
	display: block;
	text-align: center;
	width: 100%;
	list-style: none;
	list-style-type: none;
	padding: 10px 5px;
	margin-bottom: 0%;
}

.mission-list .leaf {
	width: 2%;
	margin-top: 2px;
	vertical-align: bottom;
	margin-left: 1%;
	margin-right: 1%;
	display: block;
	float: left;
}

.mission-list .leaf img {
	width: auto;
}

.mission-list .text {
	display: block;
	width: 90%;
	float: left;
}

.mission-list li.fullwidth img.inline-leaf {
	margin-top: 2px;
	display: inline-block;
	vertical-align: bottom;
}


/* ===== INNER PAGE STYLES ===== */

.page {
	background: #fff;
}

.wrap {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 24px;
}

.page-hero {
	position: relative;
	background: #24246B;  /* exact match to header */
	color: #fff;
	padding: 64px 0 54px;
	border-bottom: 2px solid var(--border);
	overflow: hidden;
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.07),
	inset 0 -1px 0 rgba(0,0,0,0.18);
}

.page-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: radial-gradient(900px 360px at 20% 18%, rgba(255,255,255,.05), rgba(255,255,255,0) 55%),
	linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.12));
	opacity: 1;
}

.page-hero__inner {
	position: relative;
	z-index: 1;
}

.page-hero__kicker {
	font-family: "Open Sans", system-ui, sans-serif;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	color: rgba(255,255,255,0.75);
	margin: 0 0 12px;
}

.page-hero__title {
	font-family: "Raleway", system-ui, sans-serif;
	font-size: clamp(30px, 3.3vw, 44px);
	font-weight: 800;
	letter-spacing: .4px;
	margin: 0;
	max-width: 900px;
	line-height: 1.15;
}

/* optional accent bar (ties to maple/gold) */

.page-hero__title::after {
	content: "";
	display: block;
	width: 64px;
	height: 3px;
	background: #C9A548; /* gold accent */
	margin-top: 18px;
}

/* =========================
PAGE BODY
========================= */

.page-body {
	padding: 56px 0 88px;
	background: #fff;
}

.page-body__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: 36px;
}

.page-content {
	max-width: 98%;
	margin: 0 auto;
}

.page-feature {
	display: inline-block;
	float: right;
	width: 40%;
	margin: 10px;
	margin-right: 0;
}

.page-feature img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 4px;
}

/* =========================
CONTENT TYPOGRAPHY (Uniform)
========================= */

.content {
	font-family: "Open Sans", system-ui, sans-serif;
	font-size: 16px;
	line-height: 1.75;
	color: #1A1A1A;
}

.content > *:first-child {
	margin-top: 0;
}

.content > *:last-child {
	margin-bottom: 0;
}

.content p {
	margin: 0 0 18px;
}

/* Headings */

.content h2, .content h3, .content h4 {
	font-family: "Raleway", system-ui, sans-serif;
	color: #24246B;
	margin: 34px 0 14px;
	line-height: 1.25;
}

.content h2 {
	font-size: 26px;
	font-weight: 800;
}

.content h3 {
	font-size: 20px;
	font-weight: 800;
}

.content h4 {
	font-size: 18px;
	font-weight: 700;
	color: #1C1D47;
}

/* Lists */

.content ul, .content ol {
	margin: 0 0 18px 22px;
	padding: 0;
}

.content li {
	margin: 8px 0;
}

/* Links */

.content a {
	color: #BB3E22; /* CTA red */
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
}

.content a:hover {
	color: #C9A548; /* gold hover */
}

/* Blockquotes */

.content blockquote {
	margin: 26px 0;
	padding: 18px 22px;
	border-left: 4px solid #C9A548;
	background: #F3F3F6;
	color: #1A1A1A;
}

/* Tables */

.content table {
	width: 100%;
	border-collapse: collapse;
	margin: 24px 0;
	font-size: 15px;
}

.content th, .content td {
	border: 1px solid rgba(0,0,0,.12);
	padding: 12px 14px;
	vertical-align: top;
}

.content th {
	background: #F3F3F6;
	color: #24246B;
	text-align: left;
	font-weight: 700;
}

.content img {
	max-width: 100%;
	height: auto;
}

.content .callout {
	background: #F3F3F6;
	border-left: 4px solid #24246B;
	padding: 18px 22px;
	border-radius: 4px;
	margin: 26px 0;
}

.content .callout strong {
	color: #24246B;
}

/* =========================
   About: Stats (Corrected BG + Divider)
   ========================= */

.about-stats {
	position: relative;
	padding: 64px 0;
	background: transparent;
	border: 0;
	overflow: hidden;
}

.about-stats .wrap {
	position: relative;
	z-index: 1;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 24px;
}

.about-stats__header {
	margin: 0 0 28px;
}

.about-stats__title {
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 800;
	font-size: clamp(24px, 2.6vw, 36px);
	color: #24246B;
	margin: 0 0 10px;
}

.about-stats__sub {
	font-family: "Open Sans", system-ui, sans-serif;
	margin: 0;
	color: rgba(0,0,0,.70);
	max-width: 62ch;
}

.about-stats__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.stat-card {
	position: relative;
	background: #fff;
	border: 1px solid rgba(0,0,0,.07);
	border-radius: 10px;
	padding: 22px 22px;
	box-shadow: 0 12px 26px rgba(0,0,0,.05);
	overflow: hidden;
}

.stat-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	height: 4px;
	width: 100%;
	background: #C9A548;
}

.stat-card::after {
	content: "";
	position: absolute;
	inset: -40px -40px auto auto;
	width: 140px;
	height: 140px;
	background: radial-gradient(circle at 30% 30%, rgba(36,36,107,.12), rgba(36,36,107,0) 65%);
	transform: rotate(8deg);
	pointer-events: none;
}

.stat-card__kicker {
	margin: 0 0 10px;
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 800;
	letter-spacing: 1px;
	text-transform: uppercase;
	font-size: 12px;
	color: rgba(0,0,0,.55);
}

.stat-card__value {
	margin: 0 0 10px;
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 900;
	font-size: clamp(36px, 4vw, 54px);
	line-height: 1;
	color: #24246B;
}

.stat-card__label {
	margin: 0;
	font-family: "Open Sans", system-ui, sans-serif;
	font-size: 16px;
	color: rgba(0,0,0,.75);
}

.about-stats__divider {
	margin-top: 34px;
	height: 1px;
	background: rgba(0,0,0,.10);
}

/* =========================
   DIRECTORS PAGE
   ========================= */

.directors-page-title {
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 800;
	letter-spacing: 0.3px;
	font-size: clamp(34px, 4vw, 54px);
	text-align: center;
	color: #1A1A1A;
	margin: 28px 0 36px;
}

.whoweare-page-title {
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 800;
	letter-spacing: 0.3px;
	font-size: clamp(24px, 4vw, 34px);
	text-align: center;
	color: #1A1A1A;
	margin: 0px 0 36px;
}

/* Group blocks */

.directors-group {
	margin: 44px 0 60px;
}

.directors-group-title {
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 800;
	color: #24246B;
	font-size: clamp(26px, 3vw, 42px);
	margin: 0 0 18px;
	letter-spacing: 0.2px;
	position: relative;
}

/* subtle accent underline like your page hero */

.directors-group-title::after {
	content: "";
	display: block;
	width: 54px;
	height: 3px;
	background: #C9A548;
	margin-top: 14px;
}

/* Table container "card" */

.directors-table-wrap {
	background: #fff;
	border: 1px solid rgba(0,0,0,.07);
	border-radius: 6px;
	overflow: hidden;
	box-shadow: 0 10px 24px rgba(0,0,0,.04);
}

/* Table base */

.directors-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	font-family: "Open Sans", system-ui, sans-serif;
}

/* Header */

.directors-table thead th {
	background: #F3F3F6;
	color: #24246B;
	font-weight: 800;
	font-size: 14px;
	letter-spacing: 1px;
	text-transform: uppercase;
	padding: 18px 18px;
	text-align: left;
	border-bottom: 1px solid rgba(0,0,0,.08);
}

/* Cells */

.directors-table tbody td {
	padding: 18px 18px;
	font-size: 16px;
	color: rgba(0,0,0,.78);
	border-bottom: 1px solid rgba(0,0,0,.06);
	vertical-align: middle;
}

/* Last row border removal */

.directors-table tbody tr:last-child td {
	border-bottom: none;
}

/* Zebra rows (very subtle) */

.directors-table tbody tr:nth-child(even) td {
	background: rgba(36, 36, 107, 0.025);
}

/* Hover effect (modern + subtle) */

.directors-table tbody tr:hover td {
	background: rgba(201, 165, 72, 0.08);
}

/* Column-specific styling */

.directors-name {
	font-weight: 700;
	color: rgba(0,0,0,.85);
}

.directors-position {
	color: rgba(0,0,0,.72);
}

/* Email link styling matches CTA */

.directors-email a {
	color: #BB3E22;
	font-weight: 800;
	text-decoration: none;
}

.directors-email a:hover {
	color: #C9A548;
	text-decoration: underline;
	text-underline-offset: 3px;
}

/* Optional: enforce consistent column widths */

.directors-table th:nth-child(1), .directors-table td:nth-child(1) {
	width: 38%;
}

.directors-table th:nth-child(2), .directors-table td:nth-child(2) {
	width: 32%;
}

.directors-table th:nth-child(3), .directors-table td:nth-child(3) {
	width: 30%;
}


/* =========================
   PAST PRESIDENTS (2-column)
   ========================= */

.directors-table--two-col th, .directors-table--two-col td {
	text-align: center; /* looks best for a name list */
}

.directors-table--two-col td {
	font-weight: 700;
}

/* empty cell if odd count */

.directors-name--empty {
	background: transparent !important;
}

img.center-history-image-block {
	display: block;
	text-align: center;
	margin: 0 auto;
	padding: 15px 0;
}

/* =========================
   HRPA Stories Panels
   ========================= */

.hrpa-stories {
	padding: 56px 0 70px;
	background: #fff;
}

.hrpa-stories .wrap {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 24px;
}

/* Panel layout */

.story-panel {
	display: grid;
	grid-template-columns: 1.15fr 0.85fr;
	gap: 44px;
	align-items: center;
	margin: 0 0 64px;
}

/* Alternate layout */

.story-panel--reverse {
	grid-template-columns: 0.85fr 1.15fr;
}

.story-panel--reverse .story-panel__media {
	order: 2;
}

.story-panel--reverse .story-panel__content {
	order: 1;
}

/* Media (image) */

.story-panel__media {
	position: relative;
	border-radius: 2px;
	overflow: hidden;
	background: #f3f3f6;
	min-height: 320px;
	box-shadow: 0 14px 34px rgba(0, 0, 0, 0.08);
}

.story-panel__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.story-panel__media::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: radial-gradient(900px 360px at 85% 20%, rgba(255,255,255,0.85), rgba(255,255,255,0) 55%);
	opacity: 0.9;
}

.story-panel__content {
	text-align: left;
}

.story-panel__title {
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 800;
	font-size: clamp(26px, 3vw, 40px);
	color: #1a1a1a;
	margin: 0 0 14px;
}

.story-panel__rule {
	width: 62px;
	height: 3px;
	background: #c9a548;
	margin: 0 0 22px;
}

.story-panel__video {
	position: relative;
	border-radius: 8px;
	overflow: hidden;
	background: #000;
	box-shadow: 0 14px 34px rgba(0, 0, 0, 0.10);
}

.story-panel__video::before {
	content: "";
	display: block;
	padding-top: 56.25%;
}

.story-panel__video iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

.story-panel:last-child {
	margin-bottom: 0;
}


/* ===== MEMBER PORTAL - LOGIN PAGE ===== */

.member-login {
	padding: 56px 0 88px;
}

.member-login__wrap {
	display: flex;
	justify-content: center;
}

.member-login__card {
	width: min(560px, 100%);
	background: #fff;
	border: 1px solid rgba(0,0,0,.08);
	border-radius: 10px;
	padding: 26px 26px;
	box-shadow: 0 14px 34px rgba(0,0,0,.06);
}

.login-form .form-row {
	margin-bottom: 16px;
}

.login-form label {
	display: block;
	margin-bottom: 8px;
	font-family: "Raleway", system-ui, sans-serif;
	font-weight: 800;
	font-size: 13px;
	letter-spacing: 0.7px;
	text-transform: uppercase;
	color: #24246B;
}

.login-form input[type="text"], .login-form input[type="password"] {
	width: 100%;
	height: 48px;
	border-radius: 8px;
	border: 1px solid rgba(0,0,0,.14);
	padding: 0 14px;
	font-family: "Open Sans", system-ui, sans-serif;
	font-size: 16px;
	outline: none;
	transition: border-color 200ms ease, box-shadow 200ms ease;
}

.login-form input[type="text"]:focus, .login-form input[type="password"]:focus {
	border-color: rgba(36,36,107,.55);
	box-shadow: 0 0 0 4px rgba(36,36,107,.10);
}

.form-row--inline {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	margin-top: 6px;
}

.check {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-family: "Open Sans", system-ui, sans-serif;
	font-size: 15px;
	color: rgba(0,0,0,.72);
	text-transform: none;
	letter-spacing: 0;
	font-weight: 400;
}

.check input {
	width: 18px;
	height: 18px;
}

.login-form__forgot {
	font-family: "Open Sans", system-ui, sans-serif;
	font-size: 15px;
	color: #BB3E22;
	font-weight: 800;
	text-decoration: none;
}

.login-form__forgot:hover {
	color: #C9A548;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.form-alert {
	border-radius: 8px;
	padding: 12px 14px;
	margin-bottom: 14px;
	font-family: "Open Sans", system-ui, sans-serif;
	font-size: 15px;
}

.form-alert--error {
	background: rgba(187, 62, 34, 0.10);
	border: 1px solid rgba(187, 62, 34, 0.25);
	color: #BB3E22;
}

/* ===== FOOTER ===== */

.site-footer {
	background: #1C1D47;
	color: rgba(255,255,255,0.85);
}

.footer-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 48px 24px 48px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
}

.footer-contact h3 {
	font-family: "Raleway", system-ui, sans-serif;
	font-size: 26px;
	letter-spacing: 1px;
	margin-bottom: 16px;
	color: #fff;
	margin-top: 0;
}

.footer-contact address {
	font-style: normal;
}

.footer-contact p {
	margin: 0 0 14px;
	font-size: 15px;
	line-height: 1.6;
}

.footer-contact a {
	color: #fff;
	text-decoration: none;
}

.footer-contact a:hover {
	text-decoration: underline;
}

.footer-map iframe {
	border-radius: 4px;
}

.footer-bottom {
	border-top: 1px solid rgba(255,255,255,0.15);
	text-align: center;
	padding: 18px 24px;
	font-size: 14px;
}

footer p a.siteby {
	color: inherit;
	font-size: smaller;
	transition: all 0.3s ease-in-out;
	text-decoration: none;
	border-bottom: 1px solid #fff;
}

footer p a.siteby:hover {
	border-bottom: 2px solid var(--accent);
	box-sizing: border-box;
}

/*** FOOTER CONTACT - ACTIVE CLICK EFFECT ***/

#footer-contact-title {
	position: relative;
	padding-bottom: 16px;
	transition: color 600ms ease, text-shadow 600ms ease;
}

#footer-contact-title.is-highlight {
	color: #C9A548;
	text-shadow: 0 0 10px rgba(201,165,72,0.25);
}

#footer-contact-title::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 2px;
	width: 90px;
	height: 3px;
	border-radius: 999px;
	background: #C9A548;
	opacity: 0;
	transform: scaleX(0.2);
	transform-origin: left center;
	transition: opacity 400ms ease, transform 450ms ease;
}

#footer-contact-title.is-highlight::after {
	opacity: 1;
	transform: scaleX(1);
}


/* ===== MOBILE ===== */

@media (max-width: 1024px) {
	nav {
		gap: 26px;
	}
	
	.mission-list {
		font-size: 20px;
		margin: 0;
		padding: 0;
	}
}

@media (max-width: 960px) {
	.header .wrap {
		flex-wrap: nowrap;
	}
	
	header .wrap .brand {
		display: block;
		width: 80%;
		float: left;
	}
	
	.nav-toggle {
		display: inline-block;
		margin-left: auto;
	}
	
	.primary-nav {
		display: none;
		width: 100%;
		flex-direction: column;
		gap: 12px;
		padding: 14px 0 8px;
	}
	
	.primary-nav.is-open {
		display: flex;
	}
	
	.primary-nav.is-open .header-cta.mobile-only {
		display: initial;
		margin-left: auto;
		margin-right: auto;
		align-content: center;
		min-width: auto;
	}
	
	.primary-nav.is-open .header-cta.mobile-only a:hover {
		border-bottom: 0 !important;
	}
	
	nav a {
		font-size: 18px;
		font-weight: 600;
	}
	
	body.nav-open nav {
		right: 0;
	}
	
	.header-cta {
		display: none;
	}
	
	body.nav-open .nav-toggle span:nth-child(1) {
		transform: translateY(7px) rotate(45deg);
	}
	
	body.nav-open .nav-toggle span:nth-child(2) {
		opacity: 0;
	}
	
	body.nav-open .nav-toggle span:nth-child(3) {
		transform: translateY(-7px) rotate(-45deg);
	}
	
	.page-hero {
		padding: 54px 0 44px;
	}
	
	.page-body {
		padding: 42px 0 70px;
	}
	
	.page-content {
		max-width: 100%;
	}
	
	.mission-list li {
		margin: 0;
		padding: 0;
	}
	
	.mission-list .leaf {
		width: 4%;
	}
	
	.mission-list .text {
		width: 88%;
	}
	
	.mission-list .clear {
		clear: both;
		margin-bottom: 10px;
		width: 100%;
	}
	
	.footer-inner {
		grid-template-columns: 1fr;
		padding: 24px;
		gap: 20px
	}
	
	.footer-contact h3 {
		font-size: 21px;
		margin-top: 0;
		padding-top: 0;
	}
	
	.footer-map iframe {
		height: 260px;
	}
	
	.header .wrap {
		height: auto;
		padding: 14px 24px;
		flex-wrap: wrap;
	}
	
	.brand {
		min-width: auto;
	}
	
	nav {
		order: 3;
		width: 100%;
		justify-content: flex-start;
		flex-wrap: wrap;
		gap: 18px;
		padding: 10px 0 0;
	}
	
	.header-cta {
		order: 2;
		margin-left: auto;
	}
	
	.hero {
		min-height: 320px;
	}
	
	.page-feature {
		width: 100%;
		display: block;
		clear: both;
		margin: 0 0 20px 0;
		text-align: center;
		float: none;
	}
	
	.directors-table thead {
		display: none;
	}
	
	.directors-table, .directors-table tbody, .directors-table tr, .directors-table td {
		display: block;
		width: 100%;
	}
	
	.directors-table-wrap {
		overflow: visible;
		background: transparent;
		border: none;
		box-shadow: none;
		border-radius: 0;
	}
	
	.directors-table tr {
		background: #fff;
		border: 1px solid rgba(0,0,0,.08);
		border-radius: 8px;
		padding: 14px 16px;
		margin: 0 0 14px;
		box-shadow: 0 8px 20px rgba(0,0,0,.04);
	}
	
	.directors-table tbody tr:nth-child(even) td, .directors-table tbody tr:hover td {
		background: transparent;
	}
	
	.directors-table td {
		padding: 10px 0;
		border: none;
		border-bottom: 1px solid rgba(0,0,0,.08);
	}
	
	.directors-table td:last-child {
		border-bottom: none;
	}
	
	.directors-table td::before {
		content: attr(data-label);
		display: block;
		font-family: "Raleway", system-ui, sans-serif;
		font-weight: 800;
		font-size: 12px;
		letter-spacing: 1px;
		text-transform: uppercase;
		color: #24246B;
		margin-bottom: 6px;
	}
	
	.directors-name {
		font-size: 18px;
	}
	
	.directors-position, .directors-email {
		font-size: 16px;
	}
	
	.directors-table th:nth-child(1), .directors-table td:nth-child(1), .directors-table th:nth-child(2), .directors-table td:nth-child(2) {
		width: 65%;
	}
	
	.directors-email a {
		display: inline-block;
		padding: 8px 12px;
		border-radius: 999px;
		background: rgba(187, 62, 34, 0.10);
		color: #BB3E22;
		font-weight: 800;
		text-decoration: none;
	}
	
	.directors-email a:hover {
		background: rgba(201, 165, 72, 0.14);
		color: #24246B;
	}
	
	.directors-table--two-col thead {
		display: none;
	}
	
	.directors-table--two-col tr {
		display: block;
		padding: 14px 16px;
	}
	
	.directors-table--two-col td {
		display: block;
		width: 100%;
		text-align: left;
	}
	
	.directors-table--two-col .directors-name--empty {
		display: none;
	}
	
	img.center-history-image-block {
		max-width: 100% !important;
	}
	
	.whoweare-page-title {
		margin-bottom: 10px;
	}
	
	.about-stats {
		padding: 52px 0;
	}
	
	.about-stats__grid {
		grid-template-columns: 1fr;
	}
	
	.stat-card {
		padding: 20px 18px;
	}
	
	.about-stats__divider {
		margin-top: 26px;
	}
	
	.story-panel, .story-panel--reverse {
		grid-template-columns: 1fr;
		gap: 22px;
	}
	
	.story-panel__media, .story-panel__content {
		order: initial !important;
	}
	
	.story-panel__media {
		min-height: 100px;
	}
	
	.story-panel__video {
		margin-bottom: 75px;
	}
}

@media (max-width: 560px) {
	.utility .wrap {
		justify-content: space-between;
	}
	
	.logo .wordmark {
		font-size: 38px;
	}
	
	.mission .headline {
		font-size: 20px;
	}
	
	.mission-list {
		font-size: 17px;
	}
	
	.mission-list li {
		align-items: flex-start;
	}
	
	.hrpa-stories {
		padding: 42px 0 56px;
	}
	
	.story-panel {
		margin-bottom: 44px;
	}
	
	.member-login__card {
		padding: 20px 18px;
	}
	
	.form-row--inline {
		flex-direction: column;
		align-items: flex-start;
	}
}