@charset "UTF-8";
/*
 * Theme Name: Great Lakes Boat Building School
 * Author: Central States Marketing
 * Author URI: https://www.centralstatesmarketing.com/
 * Description: This site was built by Central States Marketing. For more information about the site or this custom WordPress theme, you can contact Central States Marketing at: info@csm.marketing or call us at: 309-693-2345.
 * Version: 1.0.0
 *
 * @package age-central
 * @charset "UTF-8"
 */
/* || import normalize.css */
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
	line-height: 1.15; /* 1 */
	-webkit-text-size-adjust: 100%; /* 2 */
	box-sizing: border-box;
	scroll-behavior: smooth;
}

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

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
	display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
	box-sizing: content-box; /* 1 */
	height: 0; /* 1 */
	overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
	font-family: monospace, monospace; /* 1 */
	font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
	background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
	border-bottom: none; /* 1 */
	text-decoration: underline; /* 2 */
	text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
	font-family: monospace, monospace; /* 1 */
	font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
figure {
	padding: 0;
	margin: 0;
}

img {
	border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
	font-family: inherit; /* 1 */
	font-size: 100%; /* 1 */
	line-height: 1.15; /* 1 */
	margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
	/* 1 */
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
	/* 1 */
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type='button'],
[type='reset'],
[type='submit'] {
	-webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type='button']::-moz-focus-inner,
[type='reset']::-moz-focus-inner,
[type='submit']::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type='button']:-moz-focusring,
[type='reset']:-moz-focusring,
[type='submit']:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
	box-sizing: border-box; /* 1 */
	color: inherit; /* 2 */
	display: table; /* 1 */
	max-width: 100%; /* 1 */
	padding: 0; /* 3 */
	white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
	overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type='checkbox'],
[type='radio'] {
	box-sizing: border-box; /* 1 */
	padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type='number']::-webkit-inner-spin-button,
[type='number']::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type='search'] {
	-webkit-appearance: textfield; /* 1 */
	outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type='search']::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
	-webkit-appearance: button; /* 1 */
	font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
	display: list-item;
}

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
	display: none;
}

/* NO TRANSITION FOR REDUCED MOTION */
@media (prefers-reduced-motion: reduce) {
	*,
	*::after,
	*::before {
		transition: none !important;
	}
}
/* || import variables */
:root {
	--font: 'Overpass', -apple-system, Roboto, Oxygen-Sans, Ubuntu, Cantarell, 'Helvetica Neue',
		sans-serif;
	--color-gray-100: #eaedee;
	--color-gray-500: #505050;
	--color-primary-200: #3e7471; /* Fallback */
	--color-primary-200: oklch(0.577 0.122 235.591);
	--color-primary-250: #b6c4c3; /* Fallback */
	--color-primary-250: oklch(0.712 0.018 219.73);
	--color-primary-300: #071f2b; /* Fallback */
	--color-primary-300: oklch(0.231 0.038 232.52);
	--color-secondary-300: #f26822; /* Fallback */
	--color-secondary-300: oklch(0.679 0.187 42.758);
	--color-black: black;
	--color-white: white;
	--color-white-80: rgba(255, 255, 255, 0.8);
	--color-error-100: #fee2e2;
	--color-error-200: #fecaca;
	--color-error-500: #dc2626;
	--color-warning-100: #fef9c3;
	--color-warning-200: #fef08a;
	--color-warning-500: #eab308;
	--color-success-100: #dcfce2;
	--color-success-200: #bbf7cd;
	--color-success-500: #16a34a;
	--box-shadow: 0px 4px 6.7px 0px rgba(0, 0, 0, 0.25);
	--transition-duration: 250ms;
	--transition-timing-function: cubic-bezier(0.25, 0, 0.75, 1);
	--transition: var(--transition-duration) var(--transition-timing-function);
	--gutter: 2rem;
	--container-width: 1248px;
	--container-padding: max(calc(50vw - var(--container-width) / 2 + var(--gutter)), var(--gutter));
	--header-height: 8rem;
	--header-height-desktop: 10rem;
	--header-height-top: 3rem;
}

.color-white {
	color: var(--color-white);
}

.color-black {
	color: var(--color-black);
}

.color-gray-100 {
	color: var(--color-gray-100);
}

.color-primary-200 {
	color: var(--color-primary-200);
}

.color-primary-250 {
	color: var(--color-primary-250);
}

.color-primary-300 {
	color: var(--color-primary-300);
}

.color-secondary-300 {
	color: var(--color-secondary-300);
}

.bg-gray-100 {
	background-color: var(--color-gray-100);
}

.bg-primary-200 {
	background-color: var(--color-primary-200);
	color: var(--color-white);
}

.bg-primary-250 {
	background-color: var(--color-primary-250);
	color: var(--color-white);
}

.bg-primary-300 {
	background-color: var(--color-primary-300);
	color: var(--color-white);
}

.bg-secondary-300 {
	background-color: var(--color-secondary-300);
	color: var(--color-white);
}

/* || import header/nav css */
/* --- HAMBURGER MENU */
.hamburger__checkbox {
	display: none;
}

.hamburger__icon {
	z-index: 10;
	width: 2rem;
	height: 2rem;
	cursor: pointer;
	display: flex;
	align-items: center;
	margin-left: auto;
	position: absolute;
	left: 2.5rem;
	top: 4rem;
}

.hamburger__icon span {
	width: 100%;
	position: relative;
}

.hamburger__icon span::before,
.hamburger__icon span,
.hamburger__icon span::after {
	background: var(--color-white);
	height: 3px;
	content: '';
	transition: all var(--transition);
	border-radius: 5px;
}

.hamburger__icon span::before,
.hamburger__icon span::after {
	position: absolute;
	width: 100%;
}

.hamburger__icon span::before {
	top: -10px;
}

.hamburger__icon span::after {
	top: 10px;
}

.hamburger__checkbox:checked ~ .hamburger__icon span {
	transform: scale(0.8);
	background: transparent;
}

.hamburger__checkbox:checked ~ .hamburger__icon span::before,
.hamburger__checkbox:checked ~ .hamburger__icon span::after {
	top: 0;
	width: 100%;
}

.hamburger__checkbox:checked ~ .hamburger__icon span::before {
	transform: rotate(45deg);
}

.hamburger__checkbox:checked ~ .hamburger__icon span::after {
	transform: rotate(-45deg);
}

/* --- END HAMBURGER --- */
/* container for top bar */
.nav__top {
	display: flex;
	padding: 1rem;
	justify-content: flex-end;
	align-items: center;
	z-index: 11;
	height: var(--header-height-top);
	position: relative;
}
@media (width < 600px) {
	.nav__top {
	flex-direction: column;
	justify-content: center;
	--header-height-top: 100%;
	padding: .5rem 1rem;
}
}
.nav__top ul {
	margin: 0;
	padding: 0;
	display: flex;
	list-style: none;
	gap: 2rem;
	margin-inline-end: 2rem;
}
.nav__top a {
	color: white;
	text-transform: uppercase;
	font-size: 0.75rem;
}
.nav__top .social_button-container {
	display: flex;
	gap: 0.5rem;
	margin-inline-end: 0.5rem;
}
.nav__top :is(button#toggle_search, .social_button) {
	background: white;
	border: none;
	border-radius: 100%;
	height: 30px;
	width: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}
/* .nav__top :is(button#toggle_search, .social_button) svg {
	fill: var(--color-secondary-300);
} */
.nav__top :is(button#toggle_search, .social_button) svg,
.nav__top :is(button#toggle_search, .social_button) svg use {
    fill: var(--color-secondary-300);
    color: var(--color-secondary-300); /* Add this for Firefox */
}
.nav__top .top-search-form {
	transform-origin: top;
	transform: scaleY(0);
	transition: transform var(--transition);
	position: absolute;
	padding: 1rem;
	background-color: var(--color-secondary-300);
	top: var(--header-height-top);
	z-index: 2;
	border-top: 1px solid white;
	width: calc(100% - var(--gutter));
	box-shadow: var(--box-shadow);
}
.nav__top .top-search-form.open {
	transform: scaleY(1);
}

.search-form {
	position: relative;
}
.search-form button {
	position: absolute;
	right: 0.5rem;
	height: 2rem;
	width: 2rem;
	border-radius: 100%;
	border: none;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-secondary-300);
}
.search-form button svg {
	fill: var(--color-white);
}
.search-form input {
	padding: 0.75rem;
	width: 100%;
}

.nav__header,
.logo {
	height: var(--header-height);
}

.nav__header-container {
	position: relative;
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), transparent);
	z-index: 10;
	transition: background var(--transition);
}

.nav__container-right,
.nav__container-left {
	display: none;
}

/* container for entire navigation */
body:has(.hamburger__checkbox:checked) {
	overflow: hidden;
}
.nav__mobile {
	border-top: 1px solid var(--color-primary-100);
	background: linear-gradient(to top right, var(--color-primary-200), var(--color-primary-300));
	position: fixed;
	top: var(--header-height-top);
	--header-height-top: 4.5rem;
	padding-top: 5rem;
	left: 0;
	width: 100%;
	height: calc(100svh - 4.5rem);
	overflow-y: auto;
	opacity: 0;
	transform: translateX(-100%);
	transition: transform var(--transition), opacity var(--transition);
	z-index: 1000;
}

.nav__header {
	width: 100%;
	display: grid;
	grid-template-columns: 1fr;
	justify-items: center;
	align-items: center;
	justify-content: center;
	gap: 2rem;
	top: 0;
	padding: 1.5rem 0;
	max-width: 1440px;
	margin-inline: auto;
	z-index: 1000;
	/* list of text links */
	/* text links */
}
.nav__header .logo {
	display: flex;
	align-items: center;
	padding: 1.5rem 0;
	z-index: 1;
}
.nav__header .logo img {
	width: auto;
	height: calc(var(--header-height) - 3rem);
	max-height: 7rem;
}
.nav__header .hamburger__checkbox:checked ~ .hamburger__icon {
	position: fixed;
	top: 7rem;
    z-index: 10000000;
}
.nav__header .hamburger__checkbox:checked ~ .nav__mobile {
	opacity: 1;
	transform: translate(0px);
}
.nav__header .hamburger__checkbox:checked ~ .logo {
	position: fixed;
}
.nav__header ul.menu {
	padding: 0;
	margin: 0;
	list-style-type: none;
	display: flex;
	flex-direction: column;
	width: 100%;
	justify-content: space-between;
}
.nav__header ul.menu a {
	display: block;
	color: var(--color-white);
	font-weight: bold;
	width: 100%;
	font-size: 1.25rem;
	padding: 1rem 2.5rem;
}
.nav__header ul.menu a:hover {
	background-color: var(--color-secondary-300);
}
.nav__header ul.menu .sub-menu {
	list-style: none;
	padding: 0;
	display: none;
}
.nav__header ul.menu .sub-menu a {
	font-size: 1rem;
	font-weight: normal;
}
.nav__header ul.menu .sub-menu:hover {
	display: block;
}
.nav__header ul.menu .sub-menu .sub-menu a {
	padding: 0.5rem 3rem;
	font-size: 0.75rem;
}
.nav__header ul.menu li.menu-item-has-children {
	position: relative;
}
.nav__header ul.menu li.menu-item-has-children:hover > .sub-menu {
	display: block;
}
.nav__header ul.menu li.menu-item-has-children > a {
	display: flex;
	gap: 0.5rem;
}

@media only screen and (min-width: 1024px) {
	:root {
		--header-height: var(--header-height-desktop);
		--header-height-top: 4rem;
	}
	.nav__top {
		padding: 1rem 3rem;
	}
	.nav__top .top-search-form {
		width: 30%;
		min-width: 400px;
	}
	.hamburger__icon {
		display: none;
	}
	.nav__mobile {
		display: none;
	}
	.nav__header {
		grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
	}
	.nav__container-left,
	.nav__container-right {
		display: flex;
	}
	.nav__header-container {
		position: sticky;
		top: 0;
	}
	.nav__header-container.scrolled {
		background: var(--color-primary-300);
	}
	.nav__header .hamburger__checkbox:checked ~ .logo {
		position: relative;
	}
	.nav__header ul.menu a,
	.nav__header ul.menu li.menu-item-has-children a {
		padding: 1rem 0;
		font-size: 1rem;
		text-align: center;
	}
	.nav__header ul.menu a:hover,
	.nav__header ul.menu li.menu-item-has-children a:hover {
		background: none;
	}
	.nav__header ul.menu ul.sub-menu {
		position: absolute;
		top: 100%;
		padding: 0;
		margin-inline-start: -1rem;
		background-color: var(--color-gray-100);
		opacity: 0;
		pointer-events: none;
		transition: opacity 0.1s;
		display: block;
		border-radius: 1rem;
		z-index: 3;
	}
	.nav__header ul.menu ul.sub-menu a {
		font-size: 1rem !important;
		padding: 0.5rem 1rem !important;
		width: max-content;
		max-width: 20vw;
		color: var(--color-primary-300);
	}
	.nav__header ul.menu ul.sub-menu a:hover {
		background-color: var(--color-primary-50);
		color: var(--color-primary-200);
	}
	.nav__header ul.menu ul.sub-menu .sub-menu {
		top: 0;
		left: 100%;
		margin-inline-start: unset;
		background-color: var(--color-white);
		box-shadow: none;
	}
	.nav__header ul.menu li.menu-item-has-children:hover > .sub-menu {
		opacity: 1;
		pointer-events: all;
	}
	.nav__header ul.menu {
		display: flex;
		list-style-type: none;
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
		gap: 2rem;
	}
}
/* || import utilities */
/* ---------------------------------------------
--------------- UTILITY CLASSES ----------------
--------------------------------------------- */
.home .wrapper > section,
.banner,
footer.wrapper {
	padding-inline: var(--gutter);
}
.max-w {
	max-width: 1248px;
	margin-inline: auto;
}
.wrapper .narrow {
	max-width: 800px;
	margin-inline: auto;
}
/* .wrapper,
.full-width,
.narrow {
  grid-column: content;
  display: grid;
  grid-template-columns: [full-width-start] minmax(var(--gutter), 2rem) [content-start] minmax(0, var(--container-width)) [content-end] minmax(var(--gutter), 2rem) [full-width-end];
}
.wrapper > *,
.narrow > * {
  grid-column: content;
}

.wrapper .full-width {
  grid-column: full-width;
}
.full-width > * {
	grid-column: full-width;
}

.wrapper .narrow {
  --container-width: 800px;
  grid-column: full-width;
}
 */
.wrapper-left {
	padding-left: var(--container-padding);
}

.wrapper-right {
	padding-left: var(--container-padding);
}

figure.img-round {
	width: 100%;
	position: relative;
}
figure.img-round img {
	width: 100%;
	object-fit: cover;
	aspect-ratio: 1/1;
}

figure.img-round img {
	clip-path: circle(50% at 50% 50%);
}

.uppercase {
	text-transform: uppercase;
}

.font-sm {
	font-size: 1rem;
}

.font-md {
	font-size: 1.25rem;
}

.font-lg {
	font-size: 1.5rem;
}

.font-xl {
	font-size: 2rem;
}

.opacity-0 {
	opacity: 0;
}

.opacity-10 {
	opacity: 0.1;
}

.opacity-25 {
	opacity: 0.25;
}

.opacity-50 {
	opacity: 0.5;
}

.opacity-75 {
	opacity: 0.75;
}

.cursor-pointer {
	cursor: pointer;
}

.flex {
	display: flex;
	gap: 1rem;
}
.flex.flex-wrap {
	flex-wrap: wrap;
}
.flex.flex-center {
	align-items: center;
}
.flex.flex-top,
.flex.flex-start {
	align-items: flex-start;
}
.flex.flex-bottom {
	align-items: flex-end;
}
.flex.flex-column {
	flex-direction: column;
}
.flex.flex-center-hz {
	justify-content: center;
}
.flex.flex-end {
	justify-content: flex-end;
}
.flex .flex-grow {
	flex-grow: 1;
}
.flex .flex-shrink-0 {
	flex-shrink: 0;
}
.flex.space-between {
	justify-content: space-between;
}
.grid {
	display: grid;
	gap: 1rem;
}
.grid > * {
	min-width: 0;
}
.grid.grid-2 {
	grid-template-columns: 100%;
}
.grid.grid-row-2 {
	grid-template-rows: 1fr;
}
.grid.grid-3 {
	grid-template-columns: 1fr;
}
.grid.grid-4 {
	grid-template-columns: repeat(2, 1fr);
}
.grid.grid-4-sm {
	grid-template-columns: 1fr;
}

.gap-0 {
	gap: 0;
}

.gap-xs {
	gap: 0.25rem;
}

.gap-sm {
	gap: 0.5rem;
}

.gap-lg {
	gap: 2rem;
}

.gap-xl {
	gap: 4rem;
}

.position-relative {
	position: relative;
}

.list-style-none {
	list-style: none;
	padding: 0;
}

.line-height-1 {
	line-height: 1;
}
.lh-1-4 {
	line-height: 1.4;
}
.sticky {
	position: sticky;
	top: var(--header-height);
}

.br {
	border-radius: 1rem;
}

.br-xl {
	border-radius: 100px;
}

.br-100 {
	border-radius: 100%;
}

.bold {
	font-weight: bold;
}

.not-bold {
	font-weight: normal;
}

.float-right {
	float: right;
}

.padded-sm {
	padding: 0.5rem;
}

.padded {
	padding: 1rem;
}

.padded-lg {
	padding: 2rem;
}

.pr-0 {
	padding-right: 0 !important;
}

.pl-0 {
	padding-left: 0 !important;
}

.padded-y-xs {
	padding-top: 0.25rem;
	padding-bottom: 0.25rem;
}

.padded-y-sm {
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
}

.padded-y {
	padding-top: 1rem;
	padding-bottom: 1rem;
}

.padded-y-xl {
	padding-top: 4rem;
	padding-bottom: 4rem;
}

.padded-x-sm {
	padding-left: 0.5rem;
	padding-right: 0.5rem;
}

.padded-x {
	padding-left: 1rem;
	padding-right: 1rem;
}

.padded-x-xl {
	padding-left: 4rem;
	padding-right: 4rem;
}

.padding-top {
	padding-top: 1rem;
}

.p-0 {
	padding: 0;
}

.pt-0 {
	padding-top: 0;
}

.pt-sm {
	padding-top: 0.5rem;
}

.pt-lg {
	padding-top: 2rem;
}

.pb-lg {
	padding-bottom: 2rem;
}

.pr-lg {
	padding-right: 2rem;
}

.pl-lg {
	padding-left: 2rem;
}

.pb-sm {
	padding-bottom: 0.5rem;
}

.padding-bottom {
	padding-bottom: 1rem;
}

.padding-left {
	padding-left: 1rem;
}

.padding-right {
	padding-right: 1rem;
}

.margin-top {
	margin-top: 1rem;
}

.margin-bottom {
	margin-bottom: 1rem;
}

.margin-left {
	margin-left: 1rem;
}

.margin-right {
	margin-right: 1rem;
}

.m-auto {
	margin: auto;
}

.m-0 {
	margin: 0;
}

.mt-xs {
	margin-top: 0.25rem;
}

.mt-sm {
	margin-top: 0.5rem;
}

.mt-lg {
	margin-top: 2rem;
}

.mt-xl {
	margin-top: 4rem;
}

.ml-sm {
	margin-left: 0.5rem;
}

.mb-sm {
	margin-bottom: 0.5rem;
}

.mb-lg {
	margin-bottom: 2rem;
}

.mr-sm {
	margin-right: 0.5rem;
}

.mr-lg {
	margin-right: 2rem;
}

.mb-xl {
	margin-bottom: 4rem;
}

.mt-0 {
	margin-top: 0;
}

.mb-0 {
	margin-bottom: 0;
}

.mt-auto {
	margin-top: auto;
}

.ml-auto {
	margin-left: auto;
}

.mr-auto {
	margin-right: auto;
}

.mb-auto {
	margin-bottom: auto;
}

.clear-both {
	clear: both;
}

.fit-content {
	min-width: fit-content;
}

.first-on-mobile {
	order: -1;
}

.overflow-ellipsis {
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
}

.overflow-hidden {
	overflow: hidden;
}

.overflow-x-hidden {
	overflow-x: hidden;
}

.overflow-y-hidden {
	overflow-x: hidden;
}

.center {
	text-align: center;
}

.left {
	text-align: left;
}

.right {
	text-align: right;
}

.hide {
	display: none;
}

.hide-on-mobile,
.hide-on-tablet {
	display: none;
}

.visually-hidden {
	opacity: 0;
}

.user-select-none {
	user-select: none;
	pointer-events: none;
}

.disabled {
	opacity: 25%;
	user-select: none;
	pointer-events: none;
}

.w-50 {
	width: 50%;
}

.w-100 {
	width: 100%;
}

.h-100 {
	height: 100%;
}

.max-width-100 {
	max-width: 100%;
}

@media screen and (min-width: 792px) {
	.grid.grid-2 {
		grid-template-columns: repeat(2, 1fr);
	}
	.grid.grid-2.grid-2-sm {
		grid-template-columns: 1fr;
	}
	.grid.grid-3 {
		grid-template-columns: repeat(3, 1fr);
	}
	.grid.grid-4 {
		grid-template-columns: repeat(4, 1fr);
	}
	.grid.grid-4-sm {
		grid-template-columns: repeat(2, 1fr);
	}
	.grid.grid-row-2 {
		grid-template-rows: 1fr 1fr;
	}
	.grid .grid-wide {
		grid-column: span 2;
	}
	.grid .grid-tall {
		grid-row: span 2;
	}
	.grid .grid-wide-3 {
		grid-column: span 3;
	}
	.wrapper-sm {
		padding: 0;
	}
	.wrapper-left {
		padding-left: var(--container-padding);
	}
	.wrapper-right {
		padding-right: var(--container-padding);
	}
	.hide-on-mobile {
		display: inherit;
	}
	.first-on-mobile {
		order: initial;
	}
}
@media screen and (min-width: 1024px) {
	.font-lg {
		font-size: 2rem;
	}
	.font-xl {
		font-size: 3rem;
	}
	.font-xxl {
		font-size: 4rem;
	}
	.hide-on-tablet {
		display: inherit;
	}
	.grid.grid-2.grid-2-sm {
		grid-template-columns: repeat(2, 1fr);
	}
	.grid.grid-4-sm {
		grid-template-columns: repeat(4, 1fr);
	}
	.sticky {
		top: 5rem;
	}
}
/* || import animations */
/* ---------------------------------------------
-------------- ANIMATION CLASSES ---------------
--------------------------------------------- */
@keyframes floatUp {
	from {
		opacity: 0;
		transform: translateY(25%);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
@keyframes floatDown {
	from {
		opacity: 0;
		transform: translateY(-25%);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
@keyframes spin {
	from {
		opacity: 0;
		transform: rotate(-360deg) scale(0);
	}
	to {
		opacity: 1;
		transform: rotate(0deg) scale(1);
	}
}
@media (prefers-reduced-motion: no-preference) {
	.float-up,
	.float-down,
	.spin {
		opacity: 0;
		animation-duration: var(--transition-duration);
		animation-timing-function: var(--transition-timing-function);
		animation-fill-mode: forwards;
	}
	.float-up.animation-run {
		animation-name: floatUp;
	}
	.float-down.animation-run {
		animation-name: floatDown;
	}
	.spin.animation-run {
		animation-name: spin;
	}
}
@media screen and (prefers-reduced-motion: no-preference) and (min-width: 792px) {
	.delay--100 {
		animation-delay: 100ms;
	}
	.delay--200 {
		animation-delay: 200ms;
	}
	.delay--300 {
		animation-delay: 300ms;
	}
	.delay--400 {
		animation-delay: 400ms;
	}
	.delay--500 {
		animation-delay: 500ms;
	}
	.delay--600 {
		animation-delay: 600ms;
	}
	.delay--700 {
		animation-delay: 700ms;
	}
	.delay--800 {
		animation-delay: 800ms;
	}
	.delay--1000 {
		animation-delay: 1s;
	}
}
/* ---------------------------------------------
---------------- BASIC STYLES ------------------
--------------------------------------------- */
#readme {
	font-family: 'SF Mono', Inconsolata, 'Fira Mono', 'Droid Sans Mono', monospace, monospace;
	border: none;
	box-shadow: 0 0 2rem rgba(0, 0, 0, 0.25);
	width: 90vw;
	max-width: 800px;
	border-radius: 0.25rem;
}
#readme * {
	line-height: 1.5;
}
#readme h1 {
	margin-top: 0;
	font-size: 1.5rem;
}
#readme h2 {
	font-size: 1.25rem;
}
#readme h3 {
	font-size: 1.2rem;
}
#readme pre {
	background: rgb(234, 236, 238);
	display: inline;
	border-radius: 0.25rem;
	padding: 0 0.25rem;
}

#edit_post {
	position: fixed;
	bottom: 1rem;
	left: 1rem;
	z-index: 1000;
}
#edit_post a,
#edit_post button {
	outline: none;
	border: none;
	font-weight: normal;
	font-size: 1rem;
	padding: 1rem 2rem;
	box-shadow: 2px 2px 8px rgba(0, 0, 0, 0.3);
	display: flex;
	align-items: center;
	gap: 1rem;
}
#edit_post a {
	color: var(--color-white) !important;
	background: var(--color-secondary-300);
}
#edit_post button {
	color: var(--color-secondary-300);
	background: var(--color-white);
	cursor: pointer;
}
#edit_post a::before {
	content: '✎';
	transform: scale(-1.5, 1.5);
}
#edit_post button::before {
	content: '⚙';
	transform: scale(-1.5, 1.5);
}

::selection {
	background-color: var(--color-primary-200);
	color: white;
}

body {
	margin: 0;
	font-family: var(--font);
}

main {
	min-height: 50vh;
}

section {
	clear: both;
	margin-top: 2rem;
}

h1 {
	font-size: 3rem;
	font-family: var(--font);
	text-transform: uppercase;
}

h2 {
	font-size: 1.5rem;
	text-transform: uppercase;
}

h3 {
	text-transform: uppercase;
}

a {
	color: var(--color-secondary-300);
	text-decoration: none;
}

p {
	color: var(--color-text);
	font-size: 1rem;
}

p,
li,
address {
	line-height: 1.7;
}

section {
	padding-top: 2rem;
	padding-bottom: 2rem;
}

#edit_post {
	position: fixed;
	bottom: 1rem;
	left: 1rem;
	z-index: 1000;
	width: fit-content;
}
#edit_post a {
	color: var(--color-white) !important;
	background: var(--color-secondary-300);
	padding: 1rem 2rem;
	box-shadow: 2px 2px 8px rgba(0, 0, 0, 0.3);
	display: flex;
	align-items: center;
	gap: 1rem;
}
#edit_post a::before {
	content: '✎';
	transform: scale(-1.5, 1.5);
}

footer .footer__main {
	padding-block: 2rem;
	display: grid;
	gap: 1rem;
}
footer .footer__main p,
footer .footer__main h3,
footer .footer__main a,
footer .footer__main address {
	color: var(--color-primary-300);
}
footer .footer__main address {
	font-style: normal;
	font-size: 1rem;
}
footer .footer__logo img {
	width: 100%;
	height: auto;
	max-width: 360px;
}
footer .footer__nav-container ul {
	list-style-type: none;
	padding: 0;
}
footer .footer__nav-container li,
footer .footer__contact p {
	margin-block: 0.75rem;
}
footer .footer__socials .social-link {
	background: var(--color-primary-300);
	display: flex;
	height: 30px;
	width: 30px;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
}
footer .footer__socials svg {
	fill: var(--color-white);
}
footer .footer__socials .flex {
	margin-block-end: 1rem;
}
footer .footer__socials .footer__logo {
	margin-inline-start: -0.5rem;
}
footer .footer__socials .footer__logo img {
	max-width: 185px;
}
.footer__copyright p {
	margin: 0;
}

.button-white,
.button-blue,
.button-white-trans,
.gform_button {
	display: inline-block;
	padding: 0.75rem 3rem;
	border-radius: 0.5rem;
	text-transform: uppercase;
	font-weight: 700;
}

.button-white-trans {
	background: var(--color-white-80);
	color: var(--color-primary-300);
	backdrop-filter: blur(2px);
}

.button-white {
	background: var(--color-white);
	color: var(--color-primary-300);
}

.button-blue,
.gform_button {
	background: var(--color-primary-300);
	color: var(--color-white);
}

p a:not(footer a) {
	background-image: linear-gradient(currentColor, currentColor);
	background-position: left 100%;
	background-repeat: no-repeat;
	background-size: 100% 1px;
	transition: background-size var(--transition);
}
p a:not(footer a):hover {
	background-size: 0 1px;
	background-position: right 100%;
	transition: background-size var(--transition);
}

/* ---------------------------------------------
------------------ HOME PAGE -------------------
--------------------------------------------- */
.hero {
	position: relative;
	overflow: hidden;
	min-height: 500px;
	padding-top: var(--header-height);
	text-align: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	z-index: 0;
	background: linear-gradient(to bottom, var(--color-primary-300), var(--color-primary-200));
	margin-top: calc(var(--header-height) * -1);
}
.hero::after {
	content: '';
	height: 100%;
	width: 100%;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	background-color: var(--color-gray-500);
	opacity: 60%;
	z-index: 1;
}
.hero.home-hero {
	height: calc(100vh - 3rem);
	height: calc(100svh - var(--header-height-top));
}
.hero h1 {
	color: var(--color-white);
	margin-top: -2rem;
	text-shadow: 0px 5.101px 6.376px rgba(0, 0, 0, 0.49);
}
.hero > div,
.hero > h1 {
	z-index: 2;
}
.hero > img,
.hero video,
.hero #slider {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: bottom center;
	z-index: -1;
	opacity: 1;
}

.hero__content {
	border-radius: 0 100px 0 0;
	background: linear-gradient(-148deg, rgba(62, 116, 113, 0) -67.5%, #3e7471 83.62%);
	color: white;
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 1.5rem;
}

#slider {
	height: auto;
	position: relative;
	/*   height: calc(100svh - var(--header-height-top)); */
	height: 80vh;
	min-height: 400px;
	overflow: hidden;
	margin-top: calc(var(--header-height) * -1);
}

#slider li {
	display: grid !important;
	grid-template-columns: 1fr;
	position: relative;
}
#slider li::before {
	content: '';
	display: block !important;
	height: 100%;
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background-color: rgba(80, 80, 80, 0.6);
	z-index: 1;
}
#slider li:not(:has(.emoji)) img {
	grid-column: 1 / -1;
	grid-row: 1;
	object-fit: cover;
	height: 80vh;
	min-height: 400px;
	width: 100%;
}
#slider li .caption-wrap {
	display: grid;
	grid-template-columns: 1fr;
	place-items: center;
	position: absolute;
	inset: 0;
	background: none;
	opacity: 1;
	width: 100%;
	line-height: unset;
	z-index: 100;
}
#slider li .caption-wrap .caption {
	display: flex;
	flex-direction: column;
	align-items: center;
}
#slider li .caption-wrap .caption h1 {
	font-weight: 700;
	font-style: normal;
	text-align: center;
	text-wrap: balance;
	text-shadow: 0px 5.101px 6.376px rgba(0, 0, 0, 0.49);
	margin: 1rem;
}
#slider li .caption-wrap .caption a.button-white {
	opacity: 0.8;
}

@media (width < 1000px) {
	#slider li .caption-wrap .caption h1 {
		margin-top: -1rem;
		font-size: 2.1rem;
	}
}

/* ---------------------------------------------
----------------- COMPONENTS -------------------
--------------------------------------------- */
.bg-waves {
	background: url('images/waves-blue.svg') no-repeat center top;
	background-size: cover;
	margin-top: 9rem;
}

.bg-wood {
	background: var(--color-secondary-300);
	background-size: auto 100%;
	position: relative;
}
.bg-wood::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url('images/wood-grain.svg') no-repeat center top;
	background-size: auto 100%;
	mix-blend-mode: overlay; /* Choose your preferred blend mode */
	opacity: 0.5; /* Adjust opacity if needed */
}

.bg-blue-gradient {
	color: var(--color-white);
	background: linear-gradient(to right, var(--color-primary-300), var(--color-primary-200));
}

.home-icon-cards {
	margin-top: -9rem;
}
.inner-section {
	max-width: 1248px;
	margin-inline: auto;
	padding-inline: var(--gutter);
}

.vid-grid {
	align-items: center;
	padding-block: 1rem;
}
.vid-grid iframe {
	aspect-ratio: 16/9;
	width: 100%;
	display: block;
}

.inline-video {
	min-height: 400px;
	overflow: hidden;
	border-radius: 2rem;
}

.vid-grid .inline-video {
	min-height: unset;
}

.icon-card {
	background: var(--color-gray-100);
	border-radius: 2rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
	position: relative;
	padding: calc(65px + 2rem) 2rem 2rem;
	margin-top: 2rem;
	border: 2px solid transparent;
	transition: border var(--transition);
}
.icon-card:hover {
	border-color: var(--color-secondary-300);
}
.icon-card:hover .icon {
	transform: scale(1.1) translateY(-4px);
}
.icon-card * {
	margin: 0;
}
.icon-card p {
	font-size: 0.875rem;
	color: var(--color-primary-300);
}
.icon-card .icon {
	transition: transform var(--transition);
	position: absolute;
	top: -65px; /* Adjusts it to sit halfway above the card */
	width: 50%; /* Relative to the card width */
	max-width: 130px;
	aspect-ratio: 1/1;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--color-secondary-300);
	border-radius: 100%;
}
.icon-card .icon svg,
.icon-card .icon img {
	width: 60%; /* Adjust to fit within the circle */
	height: auto;
}
.icon-card h3 {
	font-size: 1.5rem;
	color: var(--color-primary-300);
}

.image-card {
	position: relative;
	overflow: hidden;
	border-radius: 2rem;
}
.image-card a {
	display: block;
	color: var(--color-white);
	text-decoration: none;
	height: 100%;
}
.image-card a:hover img {
	transform: scale(1.1);
}
.image-card a:hover svg {
	transform: translateX(8px);
}
.image-card a::before {
	position: absolute;
	bottom: 0;
	left: 0;
	display: block;
	content: '';
	height: 100%;
	width: 100%;
	background: linear-gradient(to top, rgb(0, 0, 0), transparent, transparent);
	z-index: 1;
}
.image-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform var(--transition);
	z-index: -1;
}
.image-card .image-card__content {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	padding: 1.5rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	z-index: 2;
}
.image-card .image-card__content h3 {
	margin: 0;
}
.image-card .image-card__content svg {
	transition: transform var(--transition);
}

.testimonials {
	display: grid;
	gap: 3rem;
}

.testimonial {
	padding-left: 4rem;
	position: relative;
}
.testimonial::before {
	content: '“';
	font-size: 6.5rem;
	height: 100%;
	width: 100%;
	display: block;
	position: absolute;
	top: 3.5rem;
	left: 0;
	opacity: 30%;
	color: black;
	font-weight: 700;
	line-height: 1;
}
@media (width < 768px) {
	.banner .flex {
		flex-direction: column;
	}
}

.search-card a {
	display: block;
	padding: 1rem;
}
.search-card h2 {
	margin-block: 0.5rem;
	font-size: 1.5rem;
}
.search-card:not(:last-child) {
	border-bottom: 1px solid var(--color-secondary-300);
}
.search-card .entry-summary {
	color: var(--color-black);
}
.search-card .entry-summary p {
	margin-bottom: 0;
}

/* --- SCREENS BIGGER THAN 792PX --- */
/* --- SCREENS BIGGER THAN 1024PX --- */
@media only screen and (min-width: 1024px) {
	h1 {
		font-size: 4rem;
	}
	h2 {
		font-size: 2rem;
	}
	footer .footer__logo img {
		max-width: 300px;
	}
	footer .footer__main {
		padding-block: 4rem;
		gap: 3rem;
		grid-template-columns: 4fr 2fr 2fr 2fr;
	}
	section {
		padding-top: 4rem;
		padding-bottom: 4rem;
	}
	.testimonials {
		grid-template-columns: 4fr 6fr;
	}
	.testimonial {
		padding-left: 8.5rem;
		position: relative;
	}
	.testimonial::before {
		content: '“';
		font-size: 15rem;
		height: 100%;
		width: 100%;
		display: block;
		position: absolute;
		top: 4rem;
		left: 0;
		opacity: 30%;
		color: black;
		font-weight: 700;
		line-height: 1;
	}
}

/*# sourceMappingURL=style.css.map */

/* --- Live Edits --- */
#inquiry {
	padding: 20px;
	border: 1px solid #ccc;
	border-radius: 6px;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
	max-width: 90vw;
	position: relative;
}

#inquiry::backdrop {
	background: rgba(0, 0, 0, 0.5);
}

#open-inquiry {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	position: fixed;
	bottom: 2rem;
	right: 0;
	z-index: 1000;
	padding: 1.25rem 2.25rem;
	border-radius: 0.5rem 0 0 0.5rem;
	text-transform: uppercase;
	font-weight: 700;
	border: none;
	cursor: pointer;
	background: #f26822;
	color: white;
	box-shadow: 2px 2px 8px rgba(0, 0, 0, 0.3);
	animation: bounce 3s ease-in-out infinite;
	animation-play-state: running;
	animation-delay: 3s;
	animation-iteration-count: infinite;
	animation-duration: 15s;
}

@media (width >= 1024px) {
	#open-inquiry {
		flex-direction: column;
		font-size: 1.25rem;
		bottom: unset;
		top: 70%;
	}
	#open-inquiry svg {
		height: 48px;
		width: 48px;
	}
	#open-inquiry span {
		max-width: 7ch;
	}
}

#close-inquiry {
	padding: 8px;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	background: #f26822;
	color: white;
	position: absolute;
	top: 16px;
	right: 16px;
	height: 40px;
	width: 40px;
}

#close-inquiry svg {
	fill: white;
}

#open-inquiry:hover {
	background-color: #f78755;
	animation-play-state: paused;
}

#inquiry[open] {
	animation: show-dialog 0.3s ease-out;
}

/* Form container styles */
#inquiry .gform-container {
    max-height: 80vh;
}

/* Validation styles */
#inquiry .gform_validation_errors {
    margin-bottom: 1rem;
}

#inquiry .gfield_error input,
#inquiry .gfield_error textarea {
    border-color: #c02b0a;
}

#inquiry .validation_message {
    color: #c02b0a;
    font-size: 0.875rem;
    margin-top: 0.25rem;
}

/* Loading state styles */
#inquiry .gform_wrapper {
    transition: opacity 0.3s ease;
}

#inquiry .gform_wrapper.submitting {
    opacity: 0.7;
    pointer-events: none;
    position: relative;
}

#inquiry .gform_wrapper.submitting::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 30px;
    height: 30px;
    border: 3px solid #f3f3f3;
    border-top: 3px solid #f26822;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

/* Animations */
@keyframes show-dialog {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes bounce {
	0%,
	5%,
	15%,
	25%,
	100% {
		transform: translateY(0);
	}
	10%,
	20% {
		transform: translateY(-10px);
	}
}

@keyframes spin {
    0% { transform: translate(-50%, -50%) rotate(0deg); }
    100% { transform: translate(-50%, -50%) rotate(360deg); }
}


[id] {
	scroll-margin-top: 160px;
}
.announcement {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	/* 	border: 2px solid #071F2B; */
	/* 	background-color: #071F2B; */
	border: 2px solid oklch(68.1% 0.185 43.5deg);
	background-color: oklch(68.1% 0.185 43.5deg);
	box-shadow: 0 0 10px oklch(68.1% 0.185 43.5deg);
	padding: 0.5rem;
	border-radius: 999px;
	line-height: 1lh;
	margin-inline: 1rem;
}

.announcement :is(p, a) {
	font-size: 18px;
}
.announcement p {
	margin-top: 4px !important;
	line-height: 1;
	line-height: 1lh;
	padding-inline-start: 0.5rem;
	text-wrap: pretty;
}
.announcement a {
	background-color: #fff;
	/* 	color: #071F2B; */
	color: oklch(68.1% 0.185 43.5deg);
	border-radius: 999px;
	padding: 0.5rem 1rem .25rem;
	white-space: nowrap;
	text-align: center;
}
@media (width < 768px) {
	.announcement {
		flex-direction: column;
		border-radius: 16px;
		text-align: center;
	}
	.announcement a {
		border-radius: 8px;
		width: 100%;
		padding: .75rem 1rem;
	}
}
.program-logo {
	width: min(40rem, 90%);
	margin-inline: auto;
	-webkit-filter: drop-shadow(0 0 12px rgba(0, 0, 0, 0.75));
	filter: drop-shadow(0 0 12px rgba(0, 0, 0, 0.75));
}
.giving-table table {
	width: 100%;
}
.banner h2 {
	font-size: 1.75rem;
	text-wrap: balance;
}
@media (width > 1000px) {
	#post-262 .kt-img-overlay262_721e82-91 .kt-image-overlay-wrap .kt-block-intrisic {
    	padding-bottom: 25%;
	}
}
.kt-image-overlay-message {
	z-index: 3 !important;
}