@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@500;600;700&display=swap");

:root {
	--max-width: 1100px;
	--header-height: 72px;
	--radius: 12px;

	/* Brand core */
	--primary-color: #091c61; /* logo/header navy */
	--primary-hover: #0d2b8f;
	--primary-active: #071749;

	--secondary-color: #c7a64a; /* premium gold */
	--secondary-hover: #b7963d;
	--secondary-active: #9d8034;

	/* Surfaces + type */
	--background-color: #f3f6fb;
	--surface-color: #eaf0f7;
	--card-color: #f8fbff;

	--text-color: #243247;
	--muted-text-color: #5d6b7d;
	--border-color: #d2dbe6;

	/* On-color text */
	--text-on-primary: #eef2ff;
	--text-on-primary-muted: #d6e0f7;
	--text-on-secondary: #1f2430;

	/* Effects */
	--shadow: 0 8px 24px rgba(10, 28, 70, 0.1);
	--shadow-soft: 0 8px 24px rgba(10, 28, 70, 0.1);
	--shadow-hover: 0 12px 30px rgba(10, 28, 70, 0.16);

	/* Brand-consistent gradients */
	--hero-gradient: linear-gradient(
		135deg,
		rgba(9, 28, 97, 0.1) 0%,
		rgba(199, 166, 74, 0.16) 100%
	);
/*	 --cta-gradient: linear-gradient(135deg, #d4b45b 0%, #b8963a 100%); */
	--cta-gradient: linear-gradient(161deg, #ffde59 45%, #b8963a 100%);

	/* Link system (for normal text links only) */
	--link-color: #0f2a7a;
	--link-hover: #153a9f;
	--link-active: #08184a;
	--link-underline: rgba(15, 42, 122, 0.35);
	--link-underline-hover: rgba(21, 58, 159, 0.55);
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: "Montserrat", Arial, Helvetica, sans-serif;
	font-weight: 500;
	line-height: 1.6;
	color: var(--text-color);
	background: var(--background-color);
}

h1,h2,h3,h4,h5,h6 {
	font-family: "Montserrat", Arial, sans-serif;
	font-weight: 600;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

/* Normal text links */
a:not(.button) {
	color: var(--link-color);
	text-decoration-line: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.16em;
	text-decoration-color: var(--link-underline);
	transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

a:not(.button):hover,
a:not(.button):focus-visible {
	color: var(--link-hover);
	text-decoration-color: var(--link-underline-hover);
	text-decoration-thickness: 2px;
}

a:not(.button):active {
	color: var(--link-active);
}

/* Buttons never get underline from link styles */
.button,
a.button,
a.button:hover,
a.button:focus,
a.button:focus-visible,
a.button:active,
a.button:visited {
	text-decoration: none;
}
.skip-link,
.skip-link:visited {
	color: var(--text-on-primary);
}

.skip-link {
	position: absolute;
	top: -40px;
	left: 12px;
	background: var(--primary-color);
	color: var(--text-on-primary);
	padding: 0.75rem 1rem;
	z-index: 1000;
	border-radius: 8px;
}

.skip-link:focus {
	top: 12px;
}

.site-header,
.site-footer {
	background: var(--primary-color);
	color: var(--text-on-primary);
}

.container {
	width: min(100% - 2rem, var(--max-width));
	margin: 0 auto;
}

.header-inner {
	min-height: var(--header-height);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.2rem 0;
	flex-wrap: wrap;
}

.branding {
	display: flex;
	align-items: center;
	gap: 0.875rem;
	min-width: 0;
}

.logo-wrap {
	width: 72px;
	height: 90px;
	display: grid;
	place-items: center;
	font-size: 0.8rem;
	text-align: center;
	padding: 0;
	flex: 0 0 auto;
}

.site-title-group {
	min-width: 0;
}

.site-title {
	margin: 0;
	font-size: 1.4rem;
	line-height: 1.2;
}

.site-tagline {
	margin: 0.2rem 0 0;
	color: var(--text-on-primary-muted);
	font-size: 0.95rem;
}

.site-nav ul,
.footer-nav ul {
	list-style: none;
	display: flex;
	gap: 1rem;
	padding: 0;
	margin: 0;
	flex-wrap: wrap;
}

/* Header/footer nav links */
.site-nav a,
.footer-nav a {
	color: var(--text-on-primary);
	text-decoration: none;
}

.site-nav a:hover,
.site-nav a:focus-visible,
.footer-nav a:hover,
.footer-nav a:focus-visible {
	color: #d8e2ff;
	text-decoration: underline;
	text-underline-offset: 0.2em;
	text-decoration-color: rgba(216, 226, 255, 0.5);
}

.hero {
	background: var(--hero-gradient), var(--surface-color);
	padding: 4rem 0 3rem;
	border-bottom: 1px solid var(--border-color);
}

.hero-inner {
	display: grid;
	gap: 1.5rem;
}

.hero h2 {
	margin: 0;
	font-size: clamp(2rem, 5vw, 3rem);
	line-height: 1.15;
	color: var(--primary-color);
}

.hero p {
	margin: 0;
	max-width: 60ch;
	color: var(--muted-text-color);
	font-size: 1.05rem;
}

.hero-actions {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
}

/* Button system */
.button {
	display: inline-block;
	padding: 0.85rem 1.2rem;
	border-radius: 999px;
	font-weight: 700;
	border: 2px solid transparent;
	transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease,
		transform 0.15s ease, box-shadow 0.2s ease;
}

button.button {
	font: inherit;
	font-weight: 700;
	appearance: none;
	-webkit-appearance: none;
}

.button:hover {
	transform: translateY(-1px);
	box-shadow: var(--shadow-hover);
}

.button:active {
	transform: translateY(0);
	box-shadow: var(--shadow-soft);
}

.button:focus-visible {
	outline: 3px solid rgba(13, 43, 143, 0.35);
	outline-offset: 2px;
}

.button-primary {
	background: var(--cta-gradient);
	color: var(--text-on-secondary);
	border-color: rgba(122, 96, 33, 0.35);
}

.button-primary:hover,
.button-primary:focus-visible {
	background: linear-gradient(135deg, #ffe98a 0%, #dcb95a 100%);
}

.button-primary:active {
	background: linear-gradient(135deg, #c7a64a 0%, #aa8a35 100%);
}

.button-secondary {
	background: transparent;
	color: var(--primary-color);
	border-color: var(--primary-color);
}

.button-secondary:hover,
.button-secondary:focus-visible {
	background: rgba(216, 226, 255, 0.65);
	color: var(--primary-hover);
	border-color: var(--primary-hover);
}

.button-secondary:active {
	background: rgba(9, 28, 97, 0.14);
	color: var(--primary-active);
	border-color: var(--primary-active);
}

main {
	padding: 1.5rem 0;
}

main section {
	margin: 2rem 1rem;
}

.about-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	align-items: start;
}

.about-text p:first-child {
	margin-top: 0;
}

.about-image {
	display: block;
	width: 100%;
	max-width: 420px;
	justify-self: center;
}

.about-image img {

	display: block;

	width: 100%;
	
height: auto;

	border-radius: 16px;

}


.photo-gallery-intro {

	margin-top: 0;

}


.photo-grid {

	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;

}


.photo-item {

	margin: 0;

}


.photo-item img {

	width: 100%;
	height: auto;
	border-radius: 12px;
	border: 1px solid var(--border-color);

	box-shadow: var(--shadow-soft);

}

.photo-item figcaption {

	margin-top: 0.55rem;

	font-size: 0.95rem;

	color: var(--muted-text-color);

}


@media (min-width: 900px) {

	.about-layout {
		grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);

		gap: 2rem;
	}
	.about-image {
		justify-self: end;
		align-self: start;

	}
	.photo-grid {

		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 1.25rem;

	}

}

.content-card {
	background: var(--card-color);
	border: 1px solid var(--border-color);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 1.5rem;
}

.content-card h3 {
	margin-top: 0;
	color: var(--primary-color);
}

.contact-methods {
	margin-top: 1.25rem;
}

.contact-methods-spaced {
	margin-top: 1.5rem;
}

.contact-intro {

	margin-bottom: 1rem;

}


.contact-disclosure {

	margin-top: -0.35rem;

	margin-bottom: 1rem;

	font-size: 0.9rem;

	color: var(--muted-text-color);

}


.contact-links {

	display: flex;
	gap: 0.75rem;

	flex-wrap: wrap;
	align-items: center;
	margin-bottom: 1rem;
}

.contact-addresses {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	width: 100%;
}

.contact-form {
	display: grid;
	gap: 1rem;
	margin-top: 1rem;
}

.contact-form .field-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}

.form-field {
	display: grid;
	gap: 0.4rem;
}

.form-field label,
.checkbox-label {
	font-weight: 600;
	color: var(--primary-color);
}

.required-mark {
	color: var(--secondary-active);
	margin-left: 0.2rem;
}

.form-field input,
.form-field textarea {
	width: 100%;
	border: 1px solid var(--border-color);
	border-radius: 12px;
	padding: 0.9rem 1rem;
	font: inherit;
	color: var(--text-color);
	background: #fff;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.form-field input::placeholder,
.form-field textarea::placeholder {
	color: #7a8797;
}

.form-field input:focus,
.form-field textarea:focus {
	outline: none;
	border-color: var(--primary-hover);
	box-shadow: 0 0 0 3px rgba(13, 43, 143, 0.14);
}

.form-help {
	margin: 0;
	font-size: 0.92rem;
	color: var(--muted-text-color);
}

.checkbox-field {
	display: grid;
	gap: 0.5rem;
	padding: 1rem;
	border: 1px solid var(--border-color);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.55);
}

.checkbox-row {
	display: flex;
	gap: 0.75rem;
	align-items: flex-start;
}

.checkbox-row input {
	margin-top: 0.25rem;
	width: 1rem;
	height: 1rem;
	accent-color: var(--primary-color);
	flex: 0 0 auto;
}

.checkbox-copy {
	margin: 0;
	font-size: 0.95rem;
	color: var(--text-color);
}

.policy-note {
	margin: 0;
	font-size: 0.88rem;
	color: var(--muted-text-color);
}

.form-actions {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	align-items: center;
}

.form-actions .button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.35rem;
}

.form-status {
	padding: 1rem;
	border-radius: 12px;
	border: 1px solid transparent;
}

.form-status-success {
	background: rgba(199, 166, 74, 0.12);
	border-color: rgba(199, 166, 74, 0.35);
}

.form-status-error {
	background: rgba(209, 79, 79, 0.08);
	border-color: rgba(209, 79, 79, 0.28);
}

.form-status p {
	margin: 0;
}

.mailing-address,
.corporate-address {
	text-align: left;
	font-style: normal;
	line-height: 1.35;
	padding: 1rem;
	border: 1px solid var(--border-color);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.55);
	min-width: 0;
}

.mailing-label {
	display: block;
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--muted-text-color);
	margin-bottom: 0.15rem;
}

.contact-details {
	margin: 0;
	line-height: 1.8;
}

@media (min-width: 700px) {
	.contact-addresses {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 760px) {
	.contact-form .field-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.contact-form .field-grid .form-field:first-child {
		grid-column: 1 / -1;
	}
}

.site-footer {
	margin-top: 0.5rem;
	padding: 1.5rem 0;
}

.footer-inner {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	align-items: center;
	flex-wrap: wrap;
}
.website-design {

	display: inline-block;
	font-size: 0.78rem;

	line-height: 1.2;

	letter-spacing: 0.01em;
	color: rgba(214, 224, 247, 0.72);
	
white-space: normal;

}

.footer-copy {
	margin: 0;
	color: var(--text-on-primary-muted);
}

@media (max-width: 720px) {
	.header-inner,
	.footer-inner {
		align-items: flex-start;
	}

	.site-nav ul,
	.footer-nav ul {
		gap: 0.75rem;
	}

	.hero {
		padding: 3rem 0 2.5rem;
	}

	.content-card {
		padding: 1.2rem;
	}

	.website-design {
		display: block;
		margin-left: 0;
		padding-left: 0;
		margin-top: 0.35rem;
	}
}
