/*
 * Coastal Wedding Paws — main stylesheet.
 * Palette inspired by the live site: coastal teal + mint, warm neutrals,
 * Playfair Display headings paired with Roboto body text.
 */

:root {
	--cwp-teal-50:  #f6fbf9;
	--cwp-teal-100: #e7f9f6;
	--cwp-teal-200: #c5e5d8;
	--cwp-teal-400: #35c5b4;
	--cwp-teal-500: #2a9d8f;
	--cwp-teal-600: #1f756a;
	--cwp-teal-900: #0a2421;

	--cwp-sand:     #faf6ef;
	--cwp-ink:      #0d0d0d;
	--cwp-ink-soft: #3c3d3d;
	--cwp-muted:    #6f7170;
	--cwp-line:     #e6ecea;
	--cwp-white:    #ffffff;

	--cwp-font-body:    "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
	--cwp-font-display: "Playfair Display", Georgia, "Times New Roman", serif;

	--cwp-radius:   14px;
	--cwp-radius-lg:22px;
	--cwp-shadow:   0 1px 2px rgba(10, 36, 33, 0.04), 0 8px 24px rgba(10, 36, 33, 0.06);
	--cwp-shadow-lg:0 4px 12px rgba(10, 36, 33, 0.06), 0 20px 50px rgba(10, 36, 33, 0.12);

	--cwp-container: 1140px;
	--cwp-gutter:    1.5rem;
}

/* ---------- Reset / base ---------- */

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

html { -webkit-text-size-adjust: 100%; }

body {
	margin: 0;
	font-family: var(--cwp-font-body);
	font-size: 17px;
	line-height: 1.65;
	color: var(--cwp-ink-soft);
	background: var(--cwp-white);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img, svg { max-width: 100%; height: auto; display: block; }

a {
	color: var(--cwp-teal-600);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
	transition: color 0.15s ease;
}
a:hover, a:focus { color: var(--cwp-teal-500); }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--cwp-font-display);
	color: var(--cwp-teal-900);
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 0.6em;
}
h1 { font-size: clamp(2rem, 4vw + 1rem, 3.2rem); letter-spacing: -0.01em; }
h2 { font-size: clamp(1.6rem, 2vw + 1rem, 2.25rem); }
h3 { font-size: 1.35rem; }

p { margin: 0 0 1.1em; }

ul, ol { margin: 0 0 1.1em; padding-left: 1.25em; }
li + li { margin-top: 0.25em; }

hr { border: 0; border-top: 1px solid var(--cwp-line); margin: 2.5rem 0; }

.muted { color: var(--cwp-muted); }

.screen-reader-text {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	height: 1px; width: 1px;
	overflow: hidden;
	word-wrap: normal;
}
.skip-link {
	position: absolute; top: -100px; left: 1rem;
	background: var(--cwp-teal-500); color: #fff; padding: 0.6em 1em;
	border-radius: 6px; z-index: 1000;
}
.skip-link:focus { top: 1rem; }

/* ---------- Layout helpers ---------- */

.container {
	width: 100%;
	max-width: var(--cwp-container);
	margin: 0 auto;
	padding-left: var(--cwp-gutter);
	padding-right: var(--cwp-gutter);
}

.section { padding: 4rem 0; }
@media (min-width: 768px) { .section { padding: 5.5rem 0; } }

.page-wrap { padding-top: 3rem; padding-bottom: 3.5rem; }
@media (min-width: 768px) { .page-wrap { padding-top: 4.5rem; padding-bottom: 5rem; } }

.prose {
	font-size: 1.05rem;
	line-height: 1.75;
	max-width: 70ch;
}
.prose--centered { margin-left: auto; margin-right: auto; text-align: center; }
.prose--centered ul, .prose--centered ol { text-align: left; display: inline-block; }
.prose h2 { margin-top: 2em; }
.prose img { border-radius: var(--cwp-radius); }

/* ---------- Header ---------- */

.site-header {
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: saturate(180%) blur(8px);
	-webkit-backdrop-filter: saturate(180%) blur(8px);
	border-bottom: 1px solid var(--cwp-line);
	position: sticky; top: 0; z-index: 50;
}
.site-header__inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 1rem; padding-top: 0.85rem; padding-bottom: 0.85rem;
}
.site-branding .custom-logo-link img,
.site-branding img { max-height: 56px; width: auto; display: block; }
.site-logo-link { display: inline-flex; align-items: center; }
.site-logo-img { max-height: 56px; width: auto; display: block; }
.site-title {
	font-family: var(--cwp-font-display);
	font-weight: 700; font-size: 1.4rem;
	color: var(--cwp-teal-900);
	text-decoration: none;
}

/* Nav toggle (mobile) */
.nav-toggle {
	display: inline-flex; flex-direction: column;
	gap: 5px; padding: 10px; border: 0; background: transparent;
	cursor: pointer; border-radius: 8px;
}
.nav-toggle:focus-visible { outline: 2px solid var(--cwp-teal-500); outline-offset: 2px; }
.nav-toggle__bar {
	width: 24px; height: 2px; background: var(--cwp-teal-900);
	border-radius: 2px; transition: transform 0.2s ease, opacity 0.2s ease;
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(4) { transform: translateY(-7px) rotate(-45deg); }

.primary-nav { display: none; }
.primary-nav__menu {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-direction: column; gap: 0.25rem;
}
.primary-nav__menu a {
	display: block; padding: 0.7rem 0.9rem;
	color: var(--cwp-ink); text-decoration: none;
	font-weight: 500; border-radius: 8px;
	transition: background 0.15s ease, color 0.15s ease;
}
.primary-nav__menu a:hover,
.primary-nav__menu .current-menu-item > a {
	background: var(--cwp-teal-100);
	color: var(--cwp-teal-600);
}
.primary-nav__cta {
	display: inline-block;
	margin-top: 0.5rem;
	padding: 0.7rem 1.1rem;
	background: var(--cwp-teal-500); color: var(--cwp-white);
	border-radius: 999px;
	text-decoration: none;
	font-weight: 500;
	transition: background 0.15s ease, transform 0.15s ease;
}
.primary-nav__cta:hover { background: var(--cwp-teal-600); color: var(--cwp-white); }

@media (max-width: 859px) {
	.primary-nav {
		display: block;
		position: absolute; left: 0; right: 0; top: 100%;
		background: var(--cwp-white);
		border-bottom: 1px solid var(--cwp-line);
		padding: 1rem var(--cwp-gutter) 1.4rem;
		box-shadow: var(--cwp-shadow);
		max-height: calc(100vh - 70px);
		overflow-y: auto;
	}
	.primary-nav[hidden] { display: none; }
}

@media (min-width: 860px) {
	.nav-toggle { display: none; }
	.primary-nav { display: flex; align-items: center; gap: 0.5rem; }
	.primary-nav__menu { flex-direction: row; align-items: center; }
	.primary-nav__menu a { padding: 0.5rem 0.75rem; }
	.primary-nav__cta { margin: 0 0 0 0.75rem; }
}

/* ---------- Hero ---------- */

.hero {
	background:
		radial-gradient(1200px 600px at 100% 0%, var(--cwp-teal-100) 0%, transparent 60%),
		radial-gradient(900px 500px at 0% 100%, var(--cwp-sand) 0%, transparent 55%),
		var(--cwp-white);
	padding: 4rem 0 4.5rem;
	overflow: hidden;
	position: relative;
}
.hero__inner {
	display: grid; gap: 2.5rem;
	grid-template-columns: 1fr;
	align-items: center;
}
@media (min-width: 900px) {
	.hero { padding: 6rem 0 7rem; }
	.hero__inner { grid-template-columns: 1.1fr 0.9fr; gap: 4rem; }
}
.hero__eyebrow {
	display: inline-block;
	font-size: 0.8rem; letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--cwp-teal-600);
	background: var(--cwp-teal-100);
	padding: 0.4em 0.9em; border-radius: 999px;
	margin: 0 0 1.25rem;
	font-weight: 500;
}
.hero__title {
	margin: 0 0 1.1rem;
	font-size: clamp(2.2rem, 5vw + 0.5rem, 3.75rem);
}
.hero__lede {
	font-size: 1.15rem;
	color: var(--cwp-ink-soft);
	max-width: 36ch;
	margin-bottom: 1.75rem;
}
.hero__actions {
	display: flex; flex-wrap: wrap; gap: 0.75rem;
	margin: 0;
}
.hero__art {
	position: relative;
	max-width: 460px;
	margin: 0 auto;
}
.hero__art-frame {
	position: relative;
	border-radius: var(--cwp-radius-lg);
	overflow: hidden;
	box-shadow: var(--cwp-shadow-lg);
	background: var(--cwp-teal-100);
	aspect-ratio: 4 / 5;
}
.hero__art-frame::after {
	content: ""; position: absolute;
	inset: -10% -10% auto auto; width: 32%; aspect-ratio: 1 / 1;
	border-radius: 50%; background: var(--cwp-sand);
	opacity: 0.6; z-index: -1;
}
.hero__art-img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}

/* ---------- Buttons ---------- */

.btn {
	display: inline-block;
	padding: 0.85rem 1.4rem;
	border-radius: 999px;
	font-family: inherit; font-weight: 500; font-size: 1rem;
	line-height: 1; text-decoration: none;
	border: 1px solid transparent;
	cursor: pointer;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn--primary { background: var(--cwp-teal-500); color: var(--cwp-white); }
.btn--primary:hover, .btn--primary:focus { background: var(--cwp-teal-600); color: var(--cwp-white); }
.btn--outline {
	background: transparent;
	color: var(--cwp-teal-600);
	border-color: var(--cwp-teal-500);
}
.btn--outline:hover, .btn--outline:focus { background: var(--cwp-teal-100); color: var(--cwp-teal-600); }
.btn--ghost {
	background: transparent;
	color: var(--cwp-teal-900);
	border-color: var(--cwp-line);
}
.btn--ghost:hover, .btn--ghost:focus { background: var(--cwp-teal-100); color: var(--cwp-teal-900); }
.btn--lg { padding: 1.05rem 1.8rem; font-size: 1.05rem; }

/* ---------- Page header ---------- */

.page-header { margin-bottom: 2rem; }
.page-header--centered { text-align: center; }
.page-title { margin: 0; }
.page-thumbnail { margin: 0 0 2rem; border-radius: var(--cwp-radius-lg); overflow: hidden; }
.page-thumbnail img { width: 100%; height: auto; }

.page-empty { text-align: center; padding: 4rem 0; }

/* ---------- Feature grid (home) ---------- */

.feature-grid { background: var(--cwp-teal-50); }
.feature-grid__items {
	display: grid; gap: 1.25rem;
	grid-template-columns: 1fr;
}
@media (min-width: 720px) {
	.feature-grid__items { grid-template-columns: repeat(3, 1fr); gap: 1.75rem; }
}
.feature-card {
	background: var(--cwp-white);
	border-radius: var(--cwp-radius-lg);
	padding: 1.75rem 1.5rem;
	box-shadow: var(--cwp-shadow);
}
.feature-card h3 { margin-top: 0; color: var(--cwp-teal-600); }
.feature-card p:last-child { margin-bottom: 0; }

/* ---------- Pricing ---------- */

.pricing { background: var(--cwp-teal-50); }
.pricing__grid {
	display: grid; gap: 1.5rem;
	grid-template-columns: 1fr;
	align-items: stretch;
}
@media (min-width: 900px) {
	.pricing__grid { grid-template-columns: repeat(3, 1fr); gap: 1.75rem; }
}

.pricing-card {
	background: var(--cwp-white);
	border: 1px solid var(--cwp-line);
	border-radius: var(--cwp-radius-lg);
	padding: 2rem 1.75rem;
	display: flex; flex-direction: column;
	position: relative;
	box-shadow: var(--cwp-shadow);
}
.pricing-card--featured {
	border-color: var(--cwp-teal-500);
	box-shadow: 0 4px 12px rgba(42, 157, 143, 0.10), 0 24px 60px rgba(42, 157, 143, 0.18);
	transform: translateY(-2px);
}
.pricing-card__ribbon {
	position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
	background: var(--cwp-teal-500); color: #fff;
	font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase;
	padding: 0.4em 1em; border-radius: 999px;
	font-weight: 500;
}
.pricing-card__header { text-align: center; margin-bottom: 1.25rem; }
.pricing-card__name {
	font-family: var(--cwp-font-display);
	font-size: 1.6rem;
	margin: 0 0 0.25rem;
	color: var(--cwp-teal-900);
}
.pricing-card__tag {
	font-size: 0.9rem; letter-spacing: 0.04em;
	color: var(--cwp-muted);
	margin: 0 0 1rem;
}
.pricing-card__price {
	font-family: var(--cwp-font-display);
	font-size: 2.4rem; font-weight: 700;
	color: var(--cwp-teal-600);
	margin: 0;
}
.pricing-card__blurb {
	color: var(--cwp-ink-soft);
	font-size: 0.98rem;
	margin: 0 0 1rem;
}
.pricing-card__features {
	list-style: none; padding: 0; margin: 0 0 1.25rem;
	border-top: 1px solid var(--cwp-line);
	padding-top: 1.25rem;
	display: flex; flex-direction: column; gap: 0.5rem;
}
.pricing-card__features li {
	position: relative; padding-left: 1.6rem;
	font-size: 0.97rem;
}
.pricing-card__features li::before {
	content: ""; position: absolute;
	left: 0; top: 0.55em;
	width: 0.55rem; height: 0.55rem;
	border-right: 2px solid var(--cwp-teal-500);
	border-bottom: 2px solid var(--cwp-teal-500);
	transform: rotate(45deg);
}
.pricing-card__best-for {
	font-size: 0.92rem;
	color: var(--cwp-muted);
	margin: auto 0 1.25rem;
}
.pricing-card__cta { margin: 0; text-align: center; }
.pricing-card__cta .btn { width: 100%; }

/* ---------- Two column ---------- */

.two-col {
	display: grid; gap: 2rem;
	grid-template-columns: 1fr;
}
@media (min-width: 800px) { .two-col { grid-template-columns: 1fr 1fr; gap: 3rem; } }

.check-list {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-direction: column; gap: 0.55rem;
}
.check-list li {
	position: relative; padding-left: 1.75rem;
}
.check-list li::before {
	content: ""; position: absolute; left: 0; top: 0.55em;
	width: 0.6rem; height: 0.6rem;
	border-right: 2px solid var(--cwp-teal-500);
	border-bottom: 2px solid var(--cwp-teal-500);
	transform: rotate(45deg);
}

/* ---------- FAQ ---------- */

.faq {
	max-width: 780px;
	margin: 0 auto;
	display: flex; flex-direction: column; gap: 0.85rem;
}
.faq__item {
	background: var(--cwp-white);
	border: 1px solid var(--cwp-line);
	border-radius: var(--cwp-radius);
	padding: 0;
	overflow: hidden;
	transition: box-shadow 0.15s ease, border-color 0.15s ease;
}
.faq__item[open] {
	border-color: var(--cwp-teal-200);
	box-shadow: var(--cwp-shadow);
}
.faq__question {
	list-style: none;
	cursor: pointer;
	padding: 1.05rem 1.25rem;
	display: flex; align-items: center; justify-content: space-between;
	gap: 1rem;
	font-family: var(--cwp-font-display);
	color: var(--cwp-teal-900);
	font-size: 1.1rem; font-weight: 700;
}
.faq__question::-webkit-details-marker { display: none; }
.faq__icon {
	display: inline-block; flex-shrink: 0;
	width: 14px; height: 14px;
	border-right: 2px solid var(--cwp-teal-500);
	border-bottom: 2px solid var(--cwp-teal-500);
	transform: rotate(45deg);
	transition: transform 0.2s ease;
	margin-top: -4px;
}
.faq__item[open] .faq__icon { transform: rotate(-135deg); margin-top: 4px; }
.faq__answer {
	padding: 0 1.25rem 1.25rem;
	color: var(--cwp-ink-soft);
}
.faq__answer p { margin: 0; }

/* ---------- About ---------- */

.about-grid {
	display: grid; gap: 2.5rem;
	grid-template-columns: 1fr;
	align-items: start;
}
@media (min-width: 800px) {
	.about-grid { grid-template-columns: 0.9fr 1.1fr; gap: 3.5rem; }
}
.about-grid__media {
	margin: 0;
	border-radius: var(--cwp-radius-lg);
	overflow: hidden;
	box-shadow: var(--cwp-shadow);
}
.about-grid__media img { width: 100%; height: auto; }

/* ---------- Contact ---------- */

.contact-photo {
	max-width: 480px;
	margin: 2.5rem auto 0;
	border-radius: var(--cwp-radius-lg);
	overflow: hidden;
	box-shadow: var(--cwp-shadow);
}
.contact-photo img { width: 100%; height: auto; display: block; }

.contact-card {
	max-width: 720px;
	margin: 2rem auto 0;
	background: var(--cwp-teal-50);
	border: 1px solid var(--cwp-line);
	border-radius: var(--cwp-radius-lg);
	padding: 2rem;
}
.contact-card__row + .contact-card__row {
	margin-top: 1.5rem; padding-top: 1.5rem;
	border-top: 1px solid var(--cwp-line);
}
.contact-card__row h2 {
	font-size: 1.1rem;
	margin: 0 0 0.5rem;
	letter-spacing: 0.04em; text-transform: uppercase;
	color: var(--cwp-muted);
	font-family: var(--cwp-font-body);
	font-weight: 700;
}
.contact-card__link {
	font-family: var(--cwp-font-display);
	font-size: 1.4rem;
	color: var(--cwp-teal-600);
	text-decoration: none;
}
.contact-card__link:hover { text-decoration: underline; }

.social-links {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: 0.75rem;
}
.social-links a {
	display: inline-block;
	padding: 0.5em 1em;
	background: var(--cwp-white);
	border: 1px solid var(--cwp-line);
	border-radius: 999px;
	text-decoration: none;
	color: var(--cwp-teal-900);
	font-weight: 500;
}
.social-links a:hover { background: var(--cwp-teal-500); color: var(--cwp-white); border-color: var(--cwp-teal-500); }

/* ---------- Venues ---------- */

.venues__disclaimer {
	background: var(--cwp-teal-50);
	border: 1px solid var(--cwp-teal-200);
	border-radius: var(--cwp-radius);
	padding: 1rem 1.25rem;
	font-size: 0.95rem;
	color: var(--cwp-ink-soft);
	margin-top: 1.5rem;
}

.venues-region { margin: 2.5rem 0; }
.venues-region__title {
	font-family: var(--cwp-font-display);
	font-size: 1.6rem;
	color: var(--cwp-teal-600);
	margin: 0 0 1rem;
}

.venues-table-wrap {
	overflow-x: auto;
	border-radius: var(--cwp-radius);
	border: 1px solid var(--cwp-line);
	background: var(--cwp-white);
	box-shadow: var(--cwp-shadow);
}

.venues-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.97rem;
}
.venues-table th,
.venues-table td {
	padding: 0.85rem 1.1rem;
	text-align: left;
	vertical-align: top;
	border-bottom: 1px solid var(--cwp-line);
}
.venues-table thead th {
	background: var(--cwp-teal-50);
	color: var(--cwp-teal-600);
	font-family: var(--cwp-font-body);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-size: 0.82rem;
	font-weight: 700;
}
.venues-table tbody tr:last-child th,
.venues-table tbody tr:last-child td { border-bottom: 0; }
.venues-table tbody tr:nth-child(even) th,
.venues-table tbody tr:nth-child(even) td { background: var(--cwp-sand); }
.venues-table__name { color: var(--cwp-ink); font-weight: 600; }
.venues-table__location { color: var(--cwp-muted); white-space: nowrap; }

/* ---------- Callouts ---------- */

.callout {
	background: var(--cwp-teal-50);
	border: 1px solid var(--cwp-teal-200);
	border-radius: var(--cwp-radius-lg);
	padding: 2rem;
	text-align: left;
	margin: 2rem auto 0;
	max-width: 680px;
}
.callout h2 { margin-top: 0; }

/* ---------- Contact form ---------- */

.contact-form {
	background: var(--cwp-sand);
}
.contact-form__inner {
	max-width: 720px;
	margin: 0 auto;
}
.contact-form__header {
	text-align: center;
	margin-bottom: 2rem;
}
.contact-form__title {
	font-family: var(--cwp-font-display);
	color: var(--cwp-teal-600);
	margin: 0 0 0.6rem;
}
.contact-form__subtitle {
	margin: 0;
	color: var(--cwp-ink-soft);
}

.contact-form__flash {
	border-radius: var(--cwp-radius);
	padding: 1rem 1.25rem;
	margin-bottom: 1.5rem;
	font-weight: 500;
}
.contact-form__flash--success {
	background: var(--cwp-teal-100);
	border: 1px solid var(--cwp-teal-200);
	color: var(--cwp-teal-600);
}
.contact-form__flash--error {
	background: #fdecea;
	border: 1px solid #f5c2bc;
	color: #8a1f12;
}

.contact-form__form {
	background: var(--cwp-white);
	border-radius: var(--cwp-radius-lg);
	padding: 2rem;
	box-shadow: var(--cwp-shadow);
}
.contact-form__grid {
	display: grid;
	gap: 1.1rem;
	grid-template-columns: 1fr;
}
@media (min-width: 600px) {
	.contact-form__grid { grid-template-columns: 1fr 1fr; gap: 1.25rem; }
}
.contact-form__field {
	display: flex;
	flex-direction: column;
	margin-bottom: 1.1rem;
}
.contact-form__field label {
	font-size: 0.92rem;
	font-weight: 600;
	color: var(--cwp-ink);
	margin-bottom: 0.4rem;
}
.contact-form__field input,
.contact-form__field textarea {
	font-family: var(--cwp-font-body);
	font-size: 1rem;
	color: var(--cwp-ink);
	background: var(--cwp-white);
	border: 1px solid var(--cwp-line);
	border-radius: var(--cwp-radius);
	padding: 0.75rem 0.9rem;
	transition: border-color 120ms ease, box-shadow 120ms ease;
}
.contact-form__field input:focus,
.contact-form__field textarea:focus {
	outline: none;
	border-color: var(--cwp-teal-500);
	box-shadow: 0 0 0 3px rgba(42, 157, 143, 0.18);
}
.contact-form__field textarea { resize: vertical; min-height: 140px; }

.contact-form__field--honeypot {
	position: absolute;
	left: -10000px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.contact-form__actions { text-align: center; margin-top: 0.5rem; }
.contact-form__actions .btn { min-width: 200px; }

/* ---------- CTA band ---------- */

.cta-band {
	background:
		radial-gradient(800px 400px at 50% 120%, var(--cwp-teal-600) 0%, transparent 60%),
		var(--cwp-teal-500);
	color: var(--cwp-white);
}
.cta-band__inner { text-align: center; max-width: 640px; margin: 0 auto; }
.cta-band__title { color: var(--cwp-white); margin-bottom: 0.6rem; }
.cta-band__copy { color: rgba(255, 255, 255, 0.9); margin-bottom: 1.5rem; }
.cta-band .btn--primary {
	background: var(--cwp-white);
	color: var(--cwp-teal-600);
}
.cta-band .btn--primary:hover { background: var(--cwp-teal-100); color: var(--cwp-teal-600); }

/* ---------- 404 ---------- */

.page-404 { text-align: center; padding: 3rem 0 1rem; }
.page-404__eyebrow {
	font-family: var(--cwp-font-display);
	font-size: 4rem;
	line-height: 1;
	letter-spacing: 0.05em;
	color: var(--cwp-teal-600);
	margin: 0 0 0.5rem;
	opacity: 0.85;
}
.page-404__lede { color: var(--cwp-ink-soft); margin: 0.5rem auto 2rem; max-width: 36rem; }
.page-404__links {
	list-style: none;
	margin: 0 auto 2rem;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem 1.25rem;
}
.page-404__links a {
	display: inline-block;
	padding: 0.4rem 0.25rem;
	border-bottom: 1px solid currentColor;
}
.page-404__actions { margin-top: 1.5rem; }

/* ---------- Footer ---------- */

.site-footer {
	background: var(--cwp-teal-900);
	color: rgba(255, 255, 255, 0.82);
	padding: 4rem 0 1.5rem;
	margin-top: 4rem;
}
.site-footer a { color: var(--cwp-teal-100); }
.site-footer a:hover { color: var(--cwp-white); }
.site-footer .widget-title,
.site-footer h3 {
	color: var(--cwp-white);
	font-family: var(--cwp-font-body);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 0.95rem;
	font-weight: 700;
	margin-bottom: 0.85rem;
}
.site-footer__widgets {
	display: grid; gap: 2rem;
	grid-template-columns: 1fr;
}
@media (min-width: 720px) { .site-footer__widgets { grid-template-columns: 1.3fr 1fr 1fr; gap: 2.5rem; } }

.site-footer__menu,
.site-footer .menu {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-direction: column; gap: 0.4rem;
}
.site-footer__menu a {
	text-decoration: none;
}

.site-footer .social-links a {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.15);
	color: var(--cwp-white);
}
.site-footer .social-links a:hover {
	background: var(--cwp-teal-500);
	border-color: var(--cwp-teal-500);
}

.site-footer__credits {
	margin-top: 3rem;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	font-size: 0.88rem;
	color: rgba(255, 255, 255, 0.65);
	text-align: center;
}
.site-footer__credits p { margin: 0; }
.site-footer__credits a {
	color: rgba(255, 255, 255, 0.92);
	text-decoration: underline;
	text-underline-offset: 2px;
}
.site-footer__credits a:hover,
.site-footer__credits a:focus { color: #fff; }
.site-footer__sep { color: rgba(255, 255, 255, 0.4); margin: 0 0.25rem; }

/* ---------- Block editor / content tweaks ---------- */

.page-content > .wp-block-image,
.page-content > .wp-block-cover { margin: 2rem 0; border-radius: var(--cwp-radius-lg); overflow: hidden; }
.page-content blockquote {
	border-left: 4px solid var(--cwp-teal-500);
	padding: 0.5rem 1.25rem;
	margin: 1.5rem 0;
	color: var(--cwp-ink-soft);
	font-style: italic;
}

/* ---------- Print ---------- */

@media print {
	.site-header, .site-footer, .cta-band, .primary-nav__cta { display: none; }
	a { color: inherit; text-decoration: none; }
}
