/* ============================================================
   Dommes Directory — main stylesheet
   Tokens live in theme.json (--wp--preset--color--*, --wp--preset--font-family--*).
   This file only orchestrates layout and components.
   ============================================================ */

:root {
	--dd-color-bg:         var(--wp--preset--color--warm-ivory);
	--dd-color-ink:        var(--wp--preset--color--charcoal);
	--dd-color-primary:    var(--wp--preset--color--midnight-blue);
	--dd-color-accent:     var(--wp--preset--color--burnt-orange);
	--dd-color-gold:       var(--wp--preset--color--soft-gold);
	--dd-color-gold-muted: var(--wp--preset--color--muted-gold);
	--dd-color-line:       rgba(13, 27, 46, 0.12);

	--dd-font-display: var(--wp--preset--font-family--playfair);
	--dd-font-body:    var(--wp--preset--font-family--lato);

	--dd-radius: 2px;
	--dd-header-height: 88px;
	--dd-shadow-card: 0 24px 60px -28px rgba(13, 27, 46, 0.35);

	--dd-container: 1240px;

	/* Brand gradients (centralized so every usage stays in sync) */
	--dd-gradient-gilded:    linear-gradient(135deg, var(--dd-color-gold) 0%, var(--dd-color-accent) 100%);
	--dd-gradient-midnight:  linear-gradient(135deg, var(--dd-color-primary) 0%, #1A1A1A 100%);
}

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

html { scroll-behavior: smooth; }

/* ---------- Scroll-reveal base (shared site-wide) ---------- */
[data-dd-anim] {
	opacity: 0;
	transform: translateY(28px);
	transition:
		opacity 800ms cubic-bezier(.2,.7,.2,1),
		transform 800ms cubic-bezier(.2,.7,.2,1);
	will-change: opacity, transform;
}
[data-dd-anim].is-visible {
	opacity: 1;
	transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
	[data-dd-anim] { opacity: 1; transform: none; transition: none; }
}

body {
	margin: 0;
	background: var(--dd-color-bg);
	color: var(--dd-color-ink);
	font-family: var(--dd-font-body);
	font-size: 1.0625rem;
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

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

a {
	color: var(--dd-color-accent);
	text-decoration: none;
	transition: color 200ms ease;
}
a:hover, a:focus-visible { color: var(--dd-color-primary); }

a:focus-visible,
button:focus-visible,
input:focus-visible {
	outline: 2px solid var(--dd-color-gold);
	outline-offset: 3px;
}

/* ---------- Layout primitives ---------- */

.dd-container {
	width: 100%;
	max-width: var(--dd-container);
	margin-inline: auto;
	padding-inline: clamp(1.25rem, 4vw, 2.5rem);
}

.dd-hairline {
	display: inline-block;
	width: 48px;
	height: 1px;
	background: var(--dd-color-gold);
	vertical-align: middle;
}

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

.dd-site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(246, 241, 232, 0.92);
	backdrop-filter: saturate(140%) blur(10px);
	-webkit-backdrop-filter: saturate(140%) blur(10px);
	border-bottom: 1px solid var(--dd-color-line);
}

.dd-header-inner {
	min-height: var(--dd-header-height);
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: clamp(1rem, 3vw, 2.5rem);
}

.dd-brand {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	color: var(--dd-color-primary);
}
.dd-brand:hover { color: var(--dd-color-primary); }
.dd-brand__crown { color: var(--dd-color-gold); }
.dd-brand__text { display: flex; flex-direction: column; line-height: 1; }
.dd-brand__name {
	font-family: var(--dd-font-display);
	font-weight: 700;
	font-size: 1.5rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
.dd-brand__sub {
	font-family: var(--dd-font-body);
	font-size: 0.6875rem;
	letter-spacing: 0.35em;
	text-transform: uppercase;
	color: var(--dd-color-gold-muted);
	margin-top: 0.25rem;
}

.dd-nav { justify-self: center; }
.dd-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: clamp(1rem, 2.4vw, 2rem);
	align-items: center;
}
.dd-nav a {
	color: var(--dd-color-primary);
	font-weight: 700;
	font-size: 0.78rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	padding: 0.5rem 0;
	border-bottom: 2px solid transparent;
}
.dd-nav a:hover,
.dd-nav .current-menu-item > a,
.dd-nav .current_page_item > a {
	color: var(--dd-color-accent);
	border-bottom-color: var(--dd-color-gold);
}

.dd-header-actions { justify-self: end; display: inline-flex; gap: 0.75rem; align-items: center; }

/* Top bar — thin strip above the main header holding the account link. */
.dd-topbar {
	background: var(--dd-color-primary);
	color: #fff;
	font-size: 0.78rem;
}
.dd-topbar__inner {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	min-height: 38px;
	gap: 1rem;
}
.dd-topbar__link {
	display: inline-flex; align-items: center; gap: 0.4rem;
	white-space: nowrap;
	font-weight: 700;
	letter-spacing: 0.1em; text-transform: uppercase;
	color: #fff; text-decoration: none;
	transition: color 200ms ease;
}
.dd-topbar__link .dd-icon { color: var(--dd-color-gold); flex-shrink: 0; }
.dd-topbar__link:hover,
.dd-topbar__link:focus-visible { color: var(--dd-color-gold); }
.dd-topbar__link--logout .dd-icon { color: rgba(255, 255, 255, 0.6); }

.dd-mobile-toggle {
	display: none;
	background: transparent;
	border: 1px solid var(--dd-color-primary);
	color: var(--dd-color-primary);
	width: 42px;
	height: 42px;
	cursor: pointer;
	padding: 0;
	border-radius: var(--dd-radius);
}
.dd-mobile-toggle:hover { background: var(--dd-color-primary); color: var(--dd-color-bg); }

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

.dd-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-family: var(--dd-font-body);
	font-weight: 700;
	font-size: 0.8125rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 0.9rem 1.75rem;
	border-radius: var(--dd-radius);
	border: 1px solid transparent;
	cursor: pointer;
	transition: transform 180ms ease, background 200ms ease, color 200ms ease, border-color 200ms ease;
}
.dd-btn:hover { transform: translateY(-1px); }

.dd-btn--primary   { background: var(--dd-color-primary); color: var(--dd-color-bg); }
.dd-btn--primary:hover { background: var(--dd-color-charcoal, #1A1A1A); color: var(--dd-color-bg); }

.dd-btn--accent    { background: var(--dd-color-accent); color: #fff; }
.dd-btn--accent:hover { background: #B34800; color: #fff; }

.dd-btn--ghost     {
	background: transparent;
	color: var(--dd-color-gold-muted);
	border-color: var(--dd-color-gold-muted);
}
.dd-btn--ghost:hover { background: var(--dd-color-gold-muted); color: var(--dd-color-bg); }

/* ---------- Page hero ---------- */

.dd-page-hero {
	background: linear-gradient(180deg, #FFFFFF 0%, var(--dd-color-bg) 100%);
	padding-block: clamp(3.5rem, 8vw, 6rem);
	border-bottom: 1px solid var(--dd-color-line);
	text-align: center;
}
.dd-page-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	color: var(--dd-color-accent);
	font-weight: 700;
	font-size: 0.75rem;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	margin-bottom: 1.25rem;
}
.dd-page-hero h1 {
	font-family: var(--dd-font-display);
	font-weight: 700;
	font-size: clamp(2.5rem, 5.2vw, 4rem);
	line-height: 1.05;
	letter-spacing: -0.01em;
	color: var(--dd-color-primary);
	margin: 0 0 1rem;
}
.dd-page-hero__lede {
	max-width: 640px;
	margin: 0 auto;
	color: rgba(13, 27, 46, 0.75);
	font-size: 1.125rem;
}

/* ---------- Content / single page ---------- */

.dd-page {
	padding-block: clamp(2.5rem, 6vw, 5rem);
}
.dd-page .entry-content > * {
	max-width: 780px;
	margin-inline: auto;
}
.dd-page .entry-content > .alignwide  { max-width: 1080px; }
.dd-page .entry-content > .alignfull  { max-width: none; }

.entry-content h2 { margin-top: 2.5em; }
.entry-content h3 { margin-top: 2em; }

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

.dd-404 {
	min-height: calc(100vh - var(--dd-header-height) - 320px);
	display: grid;
	place-items: center;
	text-align: center;
	padding-block: clamp(4rem, 10vw, 8rem);
	background:
		radial-gradient(ellipse at center, rgba(205, 170, 103, 0.10) 0%, transparent 60%),
		var(--dd-color-bg);
}
.dd-404__crown { color: var(--dd-color-gold); margin-bottom: 1.5rem; }
.dd-404__code {
	font-family: var(--dd-font-display);
	font-size: clamp(4rem, 10vw, 7rem);
	color: var(--dd-color-gold-muted);
	letter-spacing: 0.2em;
	line-height: 1;
	margin: 0 0 0.5rem;
	opacity: 0.55;
}
.dd-404 h1 {
	font-family: var(--dd-font-display);
	font-size: clamp(2rem, 4.5vw, 3.25rem);
	color: var(--dd-color-primary);
	margin: 0 0 1rem;
	line-height: 1.15;
}
.dd-404__lede {
	max-width: 540px;
	margin: 0 auto 2rem;
	color: rgba(13, 27, 46, 0.72);
	font-size: 1.0625rem;
}
.dd-404__actions { display: inline-flex; gap: 0.75rem; flex-wrap: wrap; justify-content: center; }
.dd-404__search { max-width: 480px; margin: 2.5rem auto 0; }

/* ---------- Search form ---------- */

.dd-search-form {
	display: flex;
	gap: 0.5rem;
	background: #fff;
	padding: 0.5rem;
	border: 1px solid var(--dd-color-line);
	border-radius: var(--dd-radius);
}
.dd-search-form input[type="search"] {
	flex: 1;
	border: 0;
	padding: 0.65rem 0.85rem;
	font: inherit;
	background: transparent;
	color: var(--dd-color-ink);
}
.dd-search-form input[type="search"]:focus { outline: none; }

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

.dd-site-footer {
	background: var(--dd-color-primary);
	color: rgba(246, 241, 232, 0.78);
	padding-block: clamp(3.5rem, 6vw, 5rem) 0;
	position: relative;
}
.dd-site-footer::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0; height: 3px;
	background: linear-gradient(90deg, transparent 0%, var(--dd-color-gold) 50%, transparent 100%);
}

.dd-footer-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: clamp(2rem, 4vw, 3.5rem);
	padding-bottom: 3rem;
	border-bottom: 1px solid rgba(246, 241, 232, 0.12);
}
.dd-footer-col h4 {
	font-family: var(--dd-font-body);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--dd-color-gold);
	margin: 0 0 1.25rem;
}
.dd-footer-col ul { list-style: none; margin: 0; padding: 0; }
.dd-footer-col li { margin-bottom: 0.65rem; }
.dd-footer-col a {
	color: rgba(246, 241, 232, 0.78);
	font-size: 0.9375rem;
}
.dd-footer-col a:hover { color: var(--dd-color-gold); }

.dd-footer-brand .dd-brand__name { color: #fff; }
.dd-footer-brand .dd-brand__sub  { color: var(--dd-color-gold); }
.dd-footer-tagline {
	margin: 1rem 0 1.5rem;
	font-size: 0.9375rem;
	line-height: 1.6;
	color: rgba(246, 241, 232, 0.7);
	max-width: 36ch;
}
.dd-trust-row {
	display: flex;
	gap: 1.25rem;
	flex-wrap: wrap;
	margin-top: 0.5rem;
}
.dd-trust-pill {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.7rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--dd-color-gold);
}

.dd-footer-bottom {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: center;
	align-items: center;
	padding-block: 1.5rem 2rem;
	font-size: 0.8125rem;
	color: rgba(246, 241, 232, 0.55);
	text-align: center;
}
.dd-footer-bottom a { color: rgba(246, 241, 232, 0.7); }
.dd-footer-bottom a:hover { color: var(--dd-color-gold); }

/* ---------- Skip link ---------- */

.dd-skip-link {
	position: absolute;
	left: -999px;
	top: 0;
	background: var(--dd-color-primary);
	color: var(--dd-color-bg);
	padding: 0.75rem 1.25rem;
	z-index: 1000;
}
.dd-skip-link:focus { left: 1rem; top: 1rem; }

/* ---------- Responsive ---------- */

/* ---------- Mobile menu panel ---------- */
/* Lives OUTSIDE the header in the DOM so the header's sticky
   z-index stacking context can't trap it underneath the hero. */
.dd-mobile-panel {
	position: fixed;
	inset: 0;
	z-index: 9999;
	background: linear-gradient(165deg, #0D1B2E 0%, #1A1A1A 100%);
	color: var(--dd-color-bg);
	transform: translateX(100%);
	transition: transform 380ms cubic-bezier(.2,.7,.2,1), visibility 0s linear 380ms;
	visibility: hidden;
	padding: calc(var(--dd-header-height) + 2rem) 2rem 2.5rem;
	overflow-y: auto;
	display: flex;
	flex-direction: column;
	gap: 2rem;
}
.dd-mobile-panel::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0; height: 1px;
	background: linear-gradient(90deg, transparent, var(--dd-color-gold), transparent);
	opacity: 0.6;
}
body.dd-menu-open .dd-mobile-panel {
	transform: translateX(0);
	visibility: visible;
	transition: transform 380ms cubic-bezier(.2,.7,.2,1), visibility 0s linear 0s;
}
body.dd-menu-open { overflow: hidden; }

.dd-mobile-panel__nav { flex: 1; }
.dd-mobile-panel__nav ul,
.dd-mobile-panel__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}
/* Scope the link styling to the nav so the CTA button isn't affected. */
.dd-mobile-panel__nav a {
	display: block;
	width: 100%;
	font-family: var(--dd-font-display);
	font-size: clamp(1.5rem, 5vw, 2.25rem);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -0.005em;
	text-decoration: none;
	color: var(--dd-color-bg);
	padding: 0.65rem 0;
	border-bottom: 1px solid rgba(205, 170, 103, 0.15);
	transition: color 200ms ease, padding 220ms ease, border-color 200ms ease;
}
.dd-mobile-panel__nav a:hover,
.dd-mobile-panel__nav a:focus-visible {
	color: var(--dd-color-gold);
	padding-left: 0.5rem;
	border-color: rgba(205, 170, 103, 0.45);
}

/* Account link inside the mobile panel, above the CTA. */
.dd-mobile-panel__account {
	display: flex; align-items: center; gap: 0.5rem;
	margin: 0 0 1rem;
	font-size: 0.95rem; font-weight: 700;
	letter-spacing: 0.04em;
	color: #fff; text-decoration: none;
}
.dd-mobile-panel__account .dd-icon { color: var(--dd-color-gold); flex-shrink: 0; }
.dd-mobile-panel__account:hover,
.dd-mobile-panel__account:focus-visible { color: var(--dd-color-gold); }

/* CTA button uses the global .dd-btn styling, full-width inside the panel. */
.dd-mobile-panel__cta {
	width: 100%;
	margin: 0 0 1rem;
	padding-block: 1.05rem;
	font-size: 0.82rem;
	letter-spacing: 0.18em;
	border-radius: 3px;
	box-shadow: 0 12px 32px -10px rgba(204, 85, 0, 0.55);
}

/* Close X button at the top-right of the mobile panel. */
.dd-mobile-panel__close {
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	width: 44px;
	height: 44px;
	display: inline-grid;
	place-items: center;
	background: transparent;
	color: var(--dd-color-bg);
	border: 1px solid rgba(246, 241, 232, 0.3);
	border-radius: 50%;
	cursor: pointer;
	padding: 0;
	transition: background 200ms ease, border-color 200ms ease, transform 200ms ease;
	z-index: 1;
}
.dd-mobile-panel__close:hover,
.dd-mobile-panel__close:focus-visible {
	background: rgba(205, 170, 103, 0.15);
	border-color: var(--dd-color-gold);
	color: var(--dd-color-gold);
	transform: rotate(90deg);
}

@media (min-width: 961px) {
	.dd-mobile-panel { display: none; }
}

@media (max-width: 960px) {
	.dd-nav { display: none; }
	.dd-mobile-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		position: relative;
		z-index: 10000;
		transition: color 200ms ease, border-color 200ms ease, background 200ms ease;
	}
	body.dd-menu-open .dd-mobile-toggle {
		background: transparent;
		color: var(--dd-color-bg);
		border-color: rgba(246, 241, 232, 0.5);
	}
	body.dd-menu-open .dd-mobile-toggle:hover {
		background: rgba(246, 241, 232, 0.1);
	}
	.dd-mobile-toggle .dd-icon { transition: transform 280ms ease; }
	body.dd-menu-open .dd-mobile-toggle .dd-icon { transform: rotate(90deg); }

	/* Hide the header Join Now button + top bar on mobile — both live in
	   the slide-out panel, the hamburger replaces them visually. */
	.dd-header-actions__cta { display: none; }
	.dd-topbar { display: none; }

	.dd-footer-grid { grid-template-columns: 1fr 1fr; }
	.dd-footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 700px) {
	/* Every .dd-btn stretches to fill its container on phones for
	   thumb-friendly tap targets. The hamburger toggle and the
	   close X are not .dd-btn so they keep their compact shape. */
	.dd-btn { width: 100%; justify-content: center; }
}

@media (max-width: 560px) {
	.dd-brand__sub { display: none; }
	.dd-brand__name { font-size: 1.2rem; letter-spacing: 0.04em; }
	.dd-footer-grid { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */

/* The whole contact page sits on a single continuous gradient applied
   to .dd-contact-page so the hero/main boundary completely disappears.
   The sections themselves are transparent; only one decorative layer
   is painted, on the wrapper, spanning the full page height. */
.dd-contact-page {
	position: relative;
	isolation: isolate;
	margin-top: calc(var(--dd-header-height) * -1);
	padding-top: var(--dd-header-height);
	background: linear-gradient(180deg, #060C16 0%, #0D1B2E 32%, #0A1525 100%);
	color: #fff;
}
.dd-contact-page__decor {
	position: absolute;
	inset: 0;
	z-index: -1;
	pointer-events: none;
	background:
		radial-gradient(ellipse at 18% 6%, rgba(205, 170, 103, 0.22) 0%, transparent 35%),
		radial-gradient(ellipse at 88% 38%, rgba(204, 85, 0, 0.18) 0%, transparent 38%);
}

.dd-contact-hero {
	position: relative;
	padding-block: clamp(3rem, 6vw, 5rem) clamp(5rem, 9vw, 7rem);
	background: transparent;
	color: #fff;
}
.dd-contact-hero__inner { text-align: center; }
.dd-contact-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	color: var(--dd-color-gold);
	font-size: 0.72rem;
	letter-spacing: 0.34em;
	text-transform: uppercase;
	margin-bottom: 1.5rem;
	font-weight: 700;
}
.dd-contact-hero__eyebrow .dd-hairline { background: var(--dd-color-gold); width: 32px; }
.dd-contact-hero__title {
	font-family: var(--dd-font-display);
	font-weight: 700;
	font-size: clamp(2.25rem, 5vw, 4rem);
	line-height: 1.08;
	letter-spacing: -0.01em;
	color: #fff;
	margin: 0 auto 1.25rem;
	max-width: 22ch;
}
.dd-contact-hero__title em {
	background: var(--dd-gradient-gilded);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
	font-style: italic;
	padding-right: 0.25em;
	margin-right: -0.25em;
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
}
.dd-contact-hero__lede {
	max-width: 640px;
	margin: 0 auto;
	color: rgba(246, 241, 232, 0.78);
	font-size: 1.0625rem;
	line-height: 1.7;
}

.dd-contact-main {
	background: transparent;
	color: #fff;
	padding-block: 0 clamp(3rem, 6vw, 5rem);
}

.dd-contact-grid {
	display: grid;
	grid-template-columns: 1.45fr 1fr;
	gap: clamp(2.5rem, 5vw, 4.5rem);
	align-items: start;
}

.dd-contact-form-wrap {
	background: rgba(246, 241, 232, 0.03);
	border: 1px solid rgba(205, 170, 103, 0.18);
	border-radius: 4px;
	padding: clamp(1.5rem, 3vw, 2.5rem);
}
.dd-contact-form__heading {
	font-family: var(--dd-font-display);
	font-size: clamp(1.4rem, 2vw, 1.75rem);
	color: #fff;
	margin: 0 0 0.5rem;
	line-height: 1.2;
}
.dd-contact-form__sub {
	margin: 0 0 2rem;
	color: rgba(246, 241, 232, 0.72);
	font-size: 0.95rem;
	line-height: 1.6;
}

/* ----- Form fields ----- */
.dd-contact-form { display: flex; flex-direction: column; gap: 1.25rem; }
.dd-field-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.25rem;
}
.dd-field { display: flex; flex-direction: column; gap: 0.5rem; }
.dd-field label {
	font-size: 0.7rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--dd-color-gold);
	font-weight: 700;
	display: inline-flex;
	gap: 0.4rem;
	align-items: center;
}
.dd-field--required > label::after {
	content: "*";
	color: var(--dd-color-accent);
	margin-left: 0.15em;
}
.dd-field__opt {
	color: rgba(246, 241, 232, 0.5);
	font-weight: 400;
	letter-spacing: 0.12em;
	text-transform: none;
	font-size: 0.7rem;
}
.dd-field input,
.dd-field textarea {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(205, 170, 103, 0.25);
	color: var(--dd-color-bg);
	padding: 0.9rem 1rem;
	font: inherit;
	font-size: 1rem;
	border-radius: 2px;
	transition: border-color 200ms ease, background 200ms ease, box-shadow 200ms ease;
	width: 100%;
}
.dd-field input::placeholder,
.dd-field textarea::placeholder { color: rgba(246, 241, 232, 0.45); }
.dd-field input:focus,
.dd-field textarea:focus {
	outline: none;
	border-color: var(--dd-color-gold);
	background: rgba(255, 255, 255, 0.06);
	box-shadow: 0 0 0 3px rgba(205, 170, 103, 0.18);
}
.dd-field textarea { resize: vertical; min-height: 140px; }
.dd-field--honey {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.dd-form-actions {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 0.5rem;
}
.dd-form-meta {
	margin: 0;
	font-size: 0.78rem;
	color: rgba(246, 241, 232, 0.55);
	text-align: left;
}
.dd-form-meta a { color: rgba(246, 241, 232, 0.8); text-decoration: underline; }
.dd-form-meta a:hover { color: var(--dd-color-gold); }

.dd-form-status {
	margin-top: 1rem;
	padding: 0.85rem 1rem;
	border-radius: 2px;
	font-size: 0.95rem;
	line-height: 1.5;
	display: none;
}
.dd-form-status.is-success {
	display: block;
	background: rgba(56, 142, 60, 0.15);
	border: 1px solid rgba(120, 200, 130, 0.35);
	color: #B6EFC4;
}
.dd-form-status.is-error {
	display: block;
	background: rgba(204, 85, 0, 0.15);
	border: 1px solid rgba(204, 85, 0, 0.45);
	color: #FFC9A3;
}

.dd-contact-form__spinner { display: none; width: 1em; height: 1em; border: 2px solid currentColor; border-right-color: transparent; border-radius: 50%; animation: ddSpin 700ms linear infinite; }
.dd-contact-form button.is-loading .dd-contact-form__label { opacity: 0.5; }
.dd-contact-form button.is-loading .dd-contact-form__spinner { display: inline-block; margin-left: 0.6em; }
@keyframes ddSpin { to { transform: rotate(360deg); } }

/* ----- Side info column -----
   Two presentation modes:
   1. Default — a structured "How we work" list with hairline gold rules.
   2. Custom — whatever the WP page editor outputs via the_content().
      We override the default theme.json text colors (midnight blue on
      midnight blue is invisible) so any Gutenberg blocks render legibly
      on the dark column. */
.dd-contact-info { color: rgba(246, 241, 232, 0.85); }
.dd-contact-info :is(h1, h2, h3, h4, h5, h6) {
	color: #fff;
	font-family: var(--dd-font-display);
	line-height: 1.2;
}
.dd-contact-info h1 { font-size: clamp(1.75rem, 2.6vw, 2.25rem); margin: 0 0 1.25rem; }
.dd-contact-info h2 { font-size: clamp(1.4rem, 2vw, 1.75rem); margin: 0 0 1rem; }
.dd-contact-info h3 { font-size: 1.2rem; color: var(--dd-color-gold); margin: 1.5rem 0 0.5rem; }
.dd-contact-info h4 {
	font-family: var(--dd-font-body);
	font-size: 0.75rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--dd-color-gold);
	margin: 1.5rem 0 0.75rem;
}
.dd-contact-info p {
	margin: 0 0 1rem;
	color: rgba(246, 241, 232, 0.78);
	font-size: 0.95rem;
	line-height: 1.65;
}
.dd-contact-info p:last-child { margin-bottom: 0; }
.dd-contact-info a { color: var(--dd-color-gold); text-decoration: underline; text-decoration-color: rgba(205, 170, 103, 0.4); }
.dd-contact-info a:hover { color: var(--dd-color-accent); text-decoration-color: currentColor; }
.dd-contact-info ul,
.dd-contact-info ol {
	color: rgba(246, 241, 232, 0.78);
	padding-left: 1.25rem;
}
.dd-contact-info strong { color: #fff; }
.dd-contact-info__custom > :first-child { margin-top: 0; }

.dd-contact-info__heading {
	font-family: var(--dd-font-display);
	font-size: clamp(1.4rem, 2vw, 1.75rem);
	color: #fff;
	margin: 0 0 1.5rem;
	line-height: 1.2;
}
.dd-contact-info__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 1.75rem;
}
.dd-contact-info__list li { border-left: 2px solid rgba(205, 170, 103, 0.4); padding-left: 1.25rem; }
.dd-contact-info__list h3 {
	font-family: var(--dd-font-display);
	font-size: 1.1rem;
	color: var(--dd-color-gold);
	margin: 0 0 0.4rem;
	line-height: 1.3;
}
.dd-contact-info__list p {
	margin: 0;
	color: rgba(246, 241, 232, 0.72);
	font-size: 0.95rem;
	line-height: 1.6;
}
.dd-contact-info__list a { color: var(--dd-color-gold); text-decoration: underline; }
.dd-contact-info__list a:hover { color: var(--dd-color-accent); }

@media (max-width: 1024px) {
	.dd-contact-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   SHARED CARDS & CAROUSELS
   Promoted from homepage.css so every template can render the
   listing card / scroll-snap carousel without enqueueing the
   homepage stylesheet. Homepage keeps its own copy and overrides
   are no-ops (same values).
   ============================================================ */

.dd-carousel { position: relative; }
.dd-carousel__track {
	display: flex;
	gap: 1.25rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	scroll-padding: 0.5rem;
	padding-block: 0.75rem;
	margin-inline: -0.5rem;
	padding-inline: 0.5rem;
	scrollbar-width: none;
}
.dd-carousel__track::-webkit-scrollbar { display: none; }
.dd-carousel__track:focus-visible { outline: 2px solid var(--dd-color-gold); outline-offset: 4px; }

.dd-carousel__nav {
	position: absolute;
	top: 40%;
	transform: translateY(-50%);
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: #fff;
	border: 1px solid var(--dd-color-line);
	color: var(--dd-color-primary);
	font-family: var(--dd-font-display);
	font-size: 1.5rem;
	line-height: 1;
	cursor: pointer;
	box-shadow: 0 10px 30px -10px rgba(13, 27, 46, 0.2);
	transition: background 200ms ease, color 200ms ease, transform 200ms ease;
	z-index: 4;
}
.dd-carousel__nav:hover { background: var(--dd-color-primary); color: var(--dd-color-bg); transform: translateY(-50%) scale(1.06); }
.dd-carousel__nav--prev { left: -16px; }
.dd-carousel__nav--next { right: -16px; }
.dd-carousel__nav[disabled] { opacity: 0; pointer-events: none; }

.dd-card {
	flex: 0 0 290px;
	scroll-snap-align: start;
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: 6px;
	overflow: hidden;
	color: inherit;
	box-shadow: 0 18px 50px -28px rgba(13, 27, 46, 0.45);
	transition: transform 350ms cubic-bezier(.2,.7,.2,1), box-shadow 350ms ease;
	position: relative;
	text-decoration: none;
}
.dd-card:hover {
	transform: translateY(-8px);
	box-shadow:
		0 38px 80px -24px rgba(13, 27, 46, 0.6),
		0 0 0 1.5px rgba(205, 170, 103, 0.9);
	color: inherit;
}
.dd-card:hover .dd-card__media { transform: scale(1.05); }
.dd-card__media {
	position: relative;
	height: 360px;
	background-color: var(--dd-color-primary);
	background-size: cover;
	background-position: center;
	overflow: hidden;
	transition: transform 700ms cubic-bezier(.2,.7,.2,1);
}
/* The card thumbnail is now a real <img> filling the media box (replacing
   the former CSS background-image), kept behind the gradient + badges. */
.dd-card__media img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
}
.dd-card__media::after {
	content: "";
	position: absolute; inset: 0;
	background: linear-gradient(180deg,
		transparent 0%,
		transparent 38%,
		rgba(13, 27, 46, 0.55) 72%,
		rgba(6, 12, 22, 0.92) 100%);
	transition: background 350ms ease;
}
/* Gold corner arrow that slides in on hover (pure CSS, no markup). */
.dd-card::after {
	content: "→";
	position: absolute;
	top: 0.9rem;
	left: 0.9rem;
	width: 34px;
	height: 34px;
	display: grid;
	place-items: center;
	border-radius: 50%;
	background: var(--dd-gradient-gilded);
	color: var(--dd-color-primary);
	font-family: var(--dd-font-body);
	font-size: 1rem;
	font-weight: 700;
	opacity: 0;
	transform: translateY(-6px) rotate(-12deg);
	transition: opacity 300ms ease, transform 300ms cubic-bezier(.2,.7,.2,1);
	z-index: 3;
	pointer-events: none;
}
.dd-card:hover::after { opacity: 1; transform: translateY(0) rotate(0); }
.dd-card__media-placeholder {
	color: var(--dd-color-gold);
	opacity: 0.55;
	display: grid;
	place-items: center;
	width: 100%; height: 100%;
}
.dd-card__badge {
	position: absolute;
	top: 0.85rem;
	right: 0.85rem;
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	background: var(--dd-color-gold);
	color: var(--dd-color-primary);
	font-size: 0.6rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	font-weight: 700;
	padding: 0.35rem 0.6rem;
	border-radius: 2px;
	z-index: 2;
}
.dd-card__badge--premium {
	background: var(--dd-color-primary);
	color: var(--dd-color-gold);
	box-shadow: inset 0 0 0 1px var(--dd-color-gold);
}
.dd-card__distance {
	position: absolute;
	top: 0.85rem;
	left: 0.85rem;
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	background: rgba(13, 27, 46, 0.78);
	color: #fff;
	font-size: 0.65rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-weight: 700;
	padding: 0.35rem 0.55rem;
	border-radius: 2px;
	z-index: 2;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}
.dd-card__distance .dd-icon { color: var(--dd-color-gold); }
.dd-card__body {
	position: absolute;
	left: 0; right: 0; bottom: 0;
	padding: 1.25rem 1.25rem 1.35rem;
	z-index: 2;
	color: #fff;
}
.dd-card__city {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	font-size: 0.65rem;
	letter-spacing: 0.22em;
	font-weight: 700;
	color: var(--dd-color-gold);
	margin-bottom: 0.4rem;
}
.dd-card__name {
	font-family: var(--dd-font-display);
	font-size: 1.4rem;
	line-height: 1.1;
	margin: 0 0 0.5rem;
	color: #fff;
	transition: color 200ms ease;
}
.dd-card__name::after {
	content: "";
	display: block;
	width: 0;
	height: 2px;
	margin-top: 0.5rem;
	background: var(--dd-gradient-gilded);
	transition: width 380ms cubic-bezier(.2,.7,.2,1);
}
.dd-card:hover .dd-card__name { color: #fff; }
.dd-card:hover .dd-card__name::after { width: 2.75rem; }
.dd-card__services {
	display: block;
	font-size: 0.78rem;
	color: rgba(246, 241, 232, 0.78);
	letter-spacing: 0.02em;
}

/* ============================================================
   ARCHIVE PAGES (every CPT)
   Brand-aligned rhythm: dark hero → light editorial body (cards on
   warm ivory) → dark trust + tiles + CTA. Echoes the homepage flow.
   ============================================================ */

.dd-archive-page {
	position: relative;
	isolation: isolate;
	margin-top: calc(var(--dd-header-height) * -1);
	padding-top: var(--dd-header-height);
	background: var(--dd-color-bg);
	color: var(--dd-color-ink);
}
.dd-archive-page__decor {
	display: none;
}

/* ----- Archive hero (dark, fades down to ivory) ----- */
.dd-archive-hero {
	position: relative;
	padding-block: clamp(2.5rem, 5vw, 4rem) clamp(4rem, 8vw, 6.5rem);
	text-align: center;
	color: #fff;
	background:
		linear-gradient(180deg,
			#060C16 0%,
			#0D1B2E 25%,
			#0F1B30 65%,
			var(--dd-color-bg) 100%);
	isolation: isolate;
	overflow: hidden;
}
.dd-archive-hero::before {
	content: "";
	position: absolute; inset: 0; z-index: -1;
	background:
		radial-gradient(ellipse at 15% 25%, rgba(205, 170, 103, 0.22) 0%, transparent 45%),
		radial-gradient(ellipse at 88% 40%, rgba(204, 85, 0, 0.18) 0%, transparent 45%);
	-webkit-mask-image: linear-gradient(180deg, black 0%, black 70%, transparent 100%);
	mask-image: linear-gradient(180deg, black 0%, black 70%, transparent 100%);
}
.dd-archive-hero__inner { max-width: 860px; margin-inline: auto; position: relative; }
.dd-breadcrumb {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.6rem;
	font-size: 0.72rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: rgba(246, 241, 232, 0.5);
	margin-bottom: 1.75rem;
}
.dd-breadcrumb a {
	color: rgba(246, 241, 232, 0.7);
	text-decoration: none;
}
.dd-breadcrumb a:hover { color: var(--dd-color-gold); }
.dd-breadcrumb__sep { color: rgba(205, 170, 103, 0.5); }
.dd-breadcrumb__current { color: var(--dd-color-gold); }
.dd-archive-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	color: var(--dd-color-gold);
	font-size: 0.72rem;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	margin-bottom: 1.25rem;
	font-weight: 700;
}
.dd-archive-hero__eyebrow .dd-hairline { background: var(--dd-color-gold); width: 32px; }
.dd-archive-hero__title {
	font-family: var(--dd-font-display);
	font-weight: 700;
	font-size: clamp(2rem, 4.5vw, 3.5rem);
	line-height: 1.08;
	letter-spacing: -0.01em;
	color: #fff;
	margin: 0 auto 1.25rem;
	max-width: 22ch;
}
.dd-archive-hero__title em {
	background: var(--dd-gradient-gilded);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
	font-style: italic;
	padding-right: 0.25em;
	margin-right: -0.25em;
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
}
.dd-archive-hero__lede {
	max-width: 620px;
	margin: 0 auto;
	color: rgba(246, 241, 232, 0.78);
	font-size: 1.0625rem;
	line-height: 1.7;
}

/* ----- Featured carousel (light ivory) ----- */
.dd-archive-featured {
	background: var(--dd-color-bg);
	padding-block: clamp(2.5rem, 5vw, 4rem);
}
.dd-archive-featured .dd-section-head { margin-bottom: 2rem; }

/* ----- Grid (slightly deeper cream, gives editorial rhythm) ----- */
.dd-archive-grid-section {
	background: #FBF7F0;
	padding-block: clamp(2.5rem, 5vw, 4.5rem);
}
.dd-archive-grid-section .dd-section-head { margin-bottom: 2.5rem; }

/* Two-column layout: filter sidebar + results. */
.dd-archive-layout {
	display: grid;
	grid-template-columns: 280px minmax(0, 1fr);
	gap: clamp(1.5rem, 3vw, 2.5rem);
	align-items: start;
}
.dd-archive-results { min-width: 0; }
.dd-archive-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 1.5rem;
}

/* ----- Filter sidebar ----- */
.dd-filters { position: sticky; top: calc(var(--dd-header-height) + 1rem); }
.dd-filters__toggle { display: none; width: 100%; justify-content: center; margin-bottom: 1rem; }
.dd-filters__form {
	background: #fff;
	border: 1px solid rgba(205, 170, 103, 0.35);
	border-radius: 6px;
	padding: 1.25rem 1.25rem 1.5rem;
	box-shadow: 0 18px 44px -30px rgba(13, 27, 46, 0.4);
}
.dd-filters__head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin-bottom: 0.75rem;
	padding-bottom: 0.85rem;
	border-bottom: 1px solid rgba(13, 27, 46, 0.08);
}
.dd-filters__title {
	font-family: var(--dd-font-display);
	font-size: 1.25rem;
	color: var(--dd-color-primary);
	margin: 0;
}
.dd-filters__clear {
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--dd-color-accent);
	font-weight: 700;
	text-decoration: none;
}
.dd-filters__clear:hover { text-decoration: underline; }

.dd-filter-group { border-bottom: 1px solid rgba(13, 27, 46, 0.08); }
.dd-filter-group > summary {
	list-style: none;
	cursor: pointer;
	padding: 0.9rem 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	font-family: var(--dd-font-body);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--dd-color-primary);
}
.dd-filter-group > summary::-webkit-details-marker { display: none; }
.dd-filter-group > summary::after {
	content: "+";
	font-size: 1.1rem;
	color: var(--dd-color-gold);
	transition: transform 200ms ease;
}
.dd-filter-group[open] > summary::after { content: "−"; }
.dd-filter-group__count {
	margin-left: auto;
	margin-right: 0.5rem;
	min-width: 20px;
	height: 20px;
	display: inline-grid;
	place-items: center;
	background: var(--dd-color-accent);
	color: #fff;
	border-radius: 10px;
	font-size: 0.7rem;
	letter-spacing: 0;
	padding: 0 0.35rem;
}
.dd-filter-group__body { padding: 0 0 1rem; }
.dd-filter-group__body--checks { display: flex; flex-direction: column; gap: 0.55rem; }
.dd-filter-group__body--checks.is-scroll {
	max-height: 240px;
	overflow-y: auto;
	padding-right: 0.5rem;
}

.dd-filter-field { display: block; margin-bottom: 1rem; }
.dd-filter-field__label {
	display: flex;
	justify-content: space-between;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(13, 27, 46, 0.6);
	margin-bottom: 0.4rem;
}
.dd-filter-field__label output { color: var(--dd-color-accent); }
.dd-filter-field select {
	width: 100%;
	padding: 0.6rem 0.7rem;
	border: 1px solid rgba(13, 27, 46, 0.18);
	border-radius: 3px;
	background: #fff;
	font: inherit;
	font-size: 0.9rem;
	color: var(--dd-color-ink);
}
.dd-filter-field--range input[type="range"] {
	width: 100%;
	accent-color: var(--dd-color-accent);
}

/* Location field — free-text geo autocomplete + "use my location",
   mirroring the homepage hero search (powered by the same main.js). */
.dd-filter-field--location { position: relative; }
.dd-filter-location {
	display: flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0 0.6rem;
	border: 1px solid rgba(13, 27, 46, 0.18);
	border-radius: 3px;
	background: #fff;
	transition: border-color 200ms ease, box-shadow 200ms ease;
}
.dd-filter-location:focus-within {
	border-color: var(--dd-color-accent);
	box-shadow: 0 0 0 3px rgba(205, 170, 103, 0.18);
}
.dd-filter-location__icon { color: var(--dd-color-accent); flex-shrink: 0; }
.dd-filter-location input::placeholder,
.dd-filter-search input::placeholder { color: rgba(13, 27, 46, 0.4); font-style: italic; }

/* Search bar (same shell as the location field) */
.dd-filter-search {
	display: flex; align-items: center; gap: 0.45rem; padding: 0 0.6rem;
	border: 1px solid rgba(13, 27, 46, 0.18); border-radius: 3px;
	background: #fff; transition: border-color 200ms ease, box-shadow 200ms ease;
}
.dd-filter-search:focus-within { border-color: var(--dd-color-accent); box-shadow: 0 0 0 3px rgba(205, 170, 103, 0.18); }
.dd-filter-search__icon { color: var(--dd-color-accent); flex-shrink: 0; }
.dd-filter-search input {
	flex: 1; min-width: 0; border: 0; background: transparent;
	font: inherit; font-size: 0.9rem; color: var(--dd-color-ink);
	padding: 0.6rem 0; outline: none;
}
.dd-filter-search input::-webkit-search-cancel-button { -webkit-appearance: none; appearance: none; }
.dd-filter-field--search { margin-bottom: 1.4rem; }

/* AJAX results loading state (subtle dim + non-interactive). */
.dd-archive-results { transition: opacity 180ms ease; }
.dd-archive-results.is-loading { opacity: 0.55; pointer-events: none; }

/* Infinite scroll: hide the numbered pagination once JS takes over, and
   show a small spinner while the next page loads. */
.dd-archive-pagination.is-ajax-hidden { display: none; }
.dd-archive-sentinel { height: 1px; }
.dd-archive-results.is-loading-more .dd-archive-sentinel {
	height: 52px; position: relative;
}
.dd-archive-results.is-loading-more .dd-archive-sentinel::after {
	content: ""; position: absolute; left: 50%; top: 50%;
	width: 24px; height: 24px; margin: -12px 0 0 -12px;
	border: 2px solid rgba(204, 85, 0, 0.25); border-top-color: var(--dd-color-accent);
	border-radius: 50%; animation: dd-spin 0.7s linear infinite;
}
@keyframes dd-spin { to { transform: rotate(360deg); } }

/* Search results page — self-contained refine form (homepage.css isn't
   loaded here, so the hero search form needs its own layout). */
.dd-search-hero { padding-bottom: clamp(1.5rem, 3vw, 2.5rem); }
.dd-search-form {
	display: grid; gap: 0.6rem; margin-top: 1.5rem;
	grid-template-columns: 1.3fr 0.9fr 1.3fr auto;
	align-items: stretch; max-width: 920px;
}
.dd-search-form .dd-hero-search__field {
	position: relative; display: flex; align-items: center; gap: 0.5rem;
	background: #fff; border: 1px solid rgba(13, 27, 46, 0.12); border-radius: 8px;
	padding: 0 0.8rem; min-width: 0;
}
.dd-search-form .dd-hero-search__field--text input,
.dd-search-form .dd-hero-search__field select {
	flex: 1; min-width: 0; border: 0; background: transparent; outline: none;
	font: inherit; font-size: 0.95rem; color: var(--dd-color-ink); padding: 0.8rem 0;
}
.dd-search-form .dd-hero-search__field select { cursor: pointer; }
.dd-search-form .dd-hero-search__icon { color: var(--dd-color-accent); flex-shrink: 0; }
.dd-search-form .dd-hero-search__locate {
	background: transparent; border: 0; color: var(--dd-color-accent);
	cursor: pointer; padding: 0.3rem; border-radius: 4px; flex-shrink: 0;
}
.dd-search-form .dd-hero-search__locate:hover { background: rgba(204, 85, 0, 0.1); }
.dd-search-form input::placeholder { color: rgba(13, 27, 46, 0.4); }
.dd-search-form .dd-hero-search__submit { white-space: nowrap; }
.dd-search-form .dd-autocomplete-list {
	position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 20;
	background: #fff; border: 1px solid var(--dd-color-line); border-radius: 8px;
	box-shadow: 0 18px 40px -24px rgba(13, 27, 46, 0.4); list-style: none; margin: 0; padding: 4px; max-height: 280px; overflow: auto;
}
@media (max-width: 820px) {
	.dd-search-form { grid-template-columns: 1fr 1fr; }
	.dd-search-form .dd-hero-search__field--icon,
	.dd-search-form .dd-hero-search__submit { grid-column: 1 / -1; }
}
.dd-filter-location input {
	flex: 1;
	min-width: 0;
	border: 0;
	background: transparent;
	font: inherit;
	font-size: 0.9rem;
	color: var(--dd-color-ink);
	padding: 0.6rem 0;
	outline: none;
}
.dd-filter-location__locate {
	flex-shrink: 0;
	display: inline-grid;
	place-items: center;
	width: 28px;
	height: 28px;
	border: 1px solid rgba(13, 27, 46, 0.15);
	background: transparent;
	color: var(--dd-color-ink);
	border-radius: 50%;
	cursor: pointer;
	padding: 0;
	transition: background 200ms ease, color 200ms ease, border-color 200ms ease, transform 400ms cubic-bezier(.2,.7,.2,1);
}
.dd-filter-location__locate:hover {
	background: var(--dd-color-accent);
	color: #fff;
	border-color: var(--dd-color-accent);
}
.dd-filter-location__locate.is-locating { animation: ddPulseLocate 900ms ease-in-out infinite; }
@keyframes ddPulseLocate {
	0%, 100% { transform: scale(1); }
	50%      { transform: scale(1.12); }
}

/* Autocomplete dropdown (shared markup with the hero; styled here so it
   also works on archive pages, where homepage.css is not loaded). */
.dd-autocomplete-list {
	position: absolute;
	top: calc(100% + 6px);
	left: 0;
	right: 0;
	list-style: none;
	margin: 0;
	padding: 0.35rem 0;
	background: #fff;
	border: 1px solid rgba(205, 170, 103, 0.45);
	border-radius: 3px;
	box-shadow: 0 24px 60px -22px rgba(13, 27, 46, 0.45);
	max-height: 320px;
	overflow-y: auto;
	z-index: 60;
	text-align: left;
}
.dd-autocomplete-list[hidden] { display: none; }
.dd-autocomplete-list li {
	padding: 0.6rem 0.85rem;
	font-size: 0.9rem;
	color: var(--dd-color-ink);
	cursor: pointer;
	border-bottom: 1px solid rgba(13, 27, 46, 0.05);
	transition: background 120ms ease, color 120ms ease;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.dd-autocomplete-list li:last-child { border-bottom: 0; }
.dd-autocomplete-list li:hover,
.dd-autocomplete-list li.is-active {
	background: rgba(205, 170, 103, 0.18);
	color: var(--dd-color-ink);
}

.dd-filter-check {
	display: flex;
	align-items: center;
	gap: 0.55rem;
	font-size: 0.9rem;
	color: var(--dd-color-ink);
	cursor: pointer;
}
.dd-filter-check input { accent-color: var(--dd-color-accent); width: 16px; height: 16px; flex-shrink: 0; }

.dd-filters__actions { margin-top: 1.25rem; }
.dd-filters__actions .dd-btn { width: 100%; justify-content: center; }

@media (max-width: 900px) {
	.dd-archive-layout { grid-template-columns: 1fr; }
	.dd-filters { position: static; }
	.dd-filters__toggle { display: inline-flex; }
	.dd-filters__form { display: none; margin-bottom: 1.5rem; }
	.dd-filters.is-open .dd-filters__form { display: block; }
}
.dd-card--archive {
	flex: initial;
	width: 100%;
	scroll-snap-align: none;
}
.dd-card--archive .dd-card__media { height: 360px; }

.dd-archive-pagination {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin-top: 3rem;
	flex-wrap: wrap;
}
.dd-archive-pagination .page-numbers {
	min-width: 42px;
	height: 42px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0 0.85rem;
	background: #fff;
	border: 1px solid rgba(205, 170, 103, 0.55);
	color: var(--dd-color-primary);
	font-size: 0.95rem;
	font-weight: 700;
	text-decoration: none;
	border-radius: 3px;
	transition: background 200ms ease, color 200ms ease, border-color 200ms ease;
}
.dd-archive-pagination .page-numbers:hover {
	background: var(--dd-color-gold);
	color: var(--dd-color-primary);
	border-color: var(--dd-color-gold);
}
.dd-archive-pagination .page-numbers.current {
	background: var(--dd-color-primary);
	color: var(--dd-color-bg);
	border-color: var(--dd-color-primary);
}
.dd-archive-pagination .dots {
	background: transparent;
	border: 0;
	color: rgba(13, 27, 46, 0.4);
}

.dd-archive-empty {
	text-align: center;
	padding: 3rem 1.25rem;
	background: #fff;
	border: 1px dashed rgba(205, 170, 103, 0.55);
	border-radius: 6px;
	max-width: 620px;
	margin-inline: auto;
}
.dd-archive-empty p {
	color: rgba(13, 27, 46, 0.75);
	font-size: 1.0625rem;
	margin: 0 0 1.5rem;
}

/* ----- 6 cross-CPT tiles (light ivory band, dark tiles inside) ----- */
.dd-archive-others {
	background: var(--dd-color-bg);
	padding-block: clamp(3rem, 5vw, 4.5rem);
}
.dd-archive-others .dd-section-head { margin-bottom: 3rem; }

.dd-cpt-links {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.25rem;
}
.dd-cpt-link {
	position: relative;
	display: block;
	overflow: hidden;
	border-radius: 6px;
	color: #fff;
	text-decoration: none;
	aspect-ratio: 3 / 4;
	border: 1px solid rgba(205, 170, 103, 0.30);
	transition: transform 350ms ease, border-color 350ms ease, box-shadow 350ms ease;
	background: var(--dd-gradient-midnight);
	box-shadow: 0 22px 50px -28px rgba(13, 27, 46, 0.4);
}
.dd-cpt-link:hover {
	transform: translateY(-5px);
	border-color: var(--dd-color-gold);
	box-shadow: 0 32px 70px -28px rgba(13, 27, 46, 0.55);
	color: #fff;
}
.dd-cpt-link__media {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	transition: transform 800ms cubic-bezier(.2,.7,.2,1);
	display: grid;
	place-items: center;
}
.dd-cpt-link:hover .dd-cpt-link__media { transform: scale(1.06); }
.dd-cpt-link__placeholder-icon {
	color: var(--dd-color-gold);
	opacity: 0.55;
}
.dd-cpt-link__veil {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg,
		rgba(13, 27, 46, 0.18) 0%,
		rgba(13, 27, 46, 0.45) 55%,
		rgba(6, 12, 22, 0.95) 100%);
}
.dd-cpt-link__body {
	position: absolute;
	left: 0; right: 0; bottom: 0;
	padding: 1.5rem 1.5rem 1.65rem;
	z-index: 2;
}
.dd-cpt-link__icon {
	display: inline-grid;
	place-items: center;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	border: 1px solid rgba(205, 170, 103, 0.55);
	background: rgba(13, 27, 46, 0.4);
	color: var(--dd-color-gold);
	margin-bottom: 0.85rem;
	transition: background 280ms ease, color 280ms ease, border-color 280ms ease;
}
.dd-cpt-link:hover .dd-cpt-link__icon {
	background: var(--dd-gradient-gilded);
	color: var(--dd-color-primary);
	border-color: transparent;
}
.dd-cpt-link__title {
	font-family: var(--dd-font-display);
	font-size: clamp(1.3rem, 1.8vw, 1.6rem);
	color: #fff;
	margin: 0 0 0.35rem;
	line-height: 1.2;
	transition: color 220ms ease;
}
.dd-cpt-link:hover .dd-cpt-link__title { color: var(--dd-color-gold); }
.dd-cpt-link__sub {
	display: block;
	font-size: 0.85rem;
	color: rgba(246, 241, 232, 0.75);
	line-height: 1.4;
}

/* ----- Shared ornamental divider (gold line · diamond · gold line) ----- */
.dd-ornament {
	display: inline-flex;
	align-items: center;
	gap: 0.85rem;
	margin-top: 2rem;
}
.dd-ornament__line {
	width: clamp(36px, 8vw, 72px);
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--dd-color-gold));
}
.dd-ornament__line:last-child {
	background: linear-gradient(90deg, var(--dd-color-gold), transparent);
}
.dd-ornament__diamond {
	width: 8px;
	height: 8px;
	background: var(--dd-color-gold);
	transform: rotate(45deg);
	flex-shrink: 0;
}

/* ----- "Why Dommes Directory" reminder (dark band, CPT-unique copy) ----- */
.dd-archive-why {
	position: relative;
	overflow: hidden;
	isolation: isolate;
	background: var(--dd-gradient-midnight);
	color: #fff;
	padding-block: clamp(4rem, 7vw, 6rem);
	text-align: center;
}
.dd-archive-why__bg {
	position: absolute; inset: 0; z-index: -1;
	background:
		radial-gradient(ellipse at 18% 10%, rgba(205, 170, 103, 0.18) 0%, transparent 45%),
		radial-gradient(ellipse at 85% 90%, rgba(204, 85, 0, 0.12) 0%, transparent 48%);
}
.dd-archive-why__inner { max-width: 760px; margin-inline: auto; }
.dd-archive-why__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	color: var(--dd-color-gold);
	font-size: 0.72rem;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	font-weight: 700;
	margin-bottom: 1.75rem;
}
.dd-archive-why__eyebrow .dd-hairline { background: var(--dd-color-gold); width: 28px; }
.dd-archive-why__line {
	font-family: var(--dd-font-display);
	font-style: italic;
	font-size: clamp(1.4rem, 2.5vw, 2.05rem);
	line-height: 1.45;
	color: rgba(255, 255, 255, 0.95);
	margin: 0 auto 2rem;
	max-width: 32ch;
}
.dd-archive-why__points {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem 2rem;
}
.dd-archive-why__points li {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.78rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	font-weight: 700;
	color: rgba(246, 241, 232, 0.85);
}
.dd-archive-why__points .dd-icon { color: var(--dd-color-gold); }

/* ----- Archive get-listed CTA (dark band, CPT-unique copy) ----- */
.dd-archive-cta {
	position: relative;
	overflow: hidden;
	isolation: isolate;
	background: var(--dd-color-charcoal, #1A1A1A);
	color: #fff;
	padding-block: clamp(4rem, 7vw, 6rem);
	text-align: center;
}
.dd-archive-cta__bg {
	position: absolute; inset: 0; z-index: -1;
	background:
		radial-gradient(ellipse at 50% 0%, rgba(205, 170, 103, 0.20) 0%, transparent 55%),
		radial-gradient(ellipse at 80% 100%, rgba(204, 85, 0, 0.16) 0%, transparent 55%),
		linear-gradient(165deg, #1A1A1A 0%, #0D1B2E 100%);
}
.dd-archive-cta__inner { max-width: 640px; margin-inline: auto; }
.dd-archive-cta__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.65rem;
	color: var(--dd-color-gold);
	font-size: 0.72rem;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	font-weight: 700;
	margin-bottom: 1.25rem;
}
.dd-archive-cta__eyebrow .dd-hairline { background: var(--dd-color-gold); width: 32px; }
.dd-archive-cta__title {
	font-family: var(--dd-font-display);
	font-size: clamp(1.85rem, 3.6vw, 2.85rem);
	line-height: 1.12;
	color: #fff;
	margin: 0 auto 1.25rem;
	max-width: 18ch;
}
.dd-archive-cta__copy {
	color: rgba(246, 241, 232, 0.82);
	font-size: 1.0625rem;
	line-height: 1.7;
	margin: 0 auto 2rem;
	max-width: 52ch;
}

@media (max-width: 1024px) {
	.dd-archive-grid { grid-template-columns: repeat(2, 1fr); }
	.dd-cpt-links { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
	.dd-archive-grid { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
	.dd-cpt-links { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
	.dd-card--archive .dd-card__media { height: 320px; }
	.dd-carousel__nav { display: none; }
	.dd-archive-cta .dd-btn { width: 100%; justify-content: center; }
}

/* ============================================================
   SECTION HEADS (shared by every page that uses the helper)
   Lives in main.css so non-homepage templates can reuse it
   without having to enqueue homepage.css.
   ============================================================ */

.dd-section-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 1rem;
	margin-bottom: 2.5rem;
}
.dd-section-head--center {
	flex-direction: column;
	align-items: center;
	text-align: center;
	margin-bottom: 3.5rem;
}
.dd-section-head__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.65rem;
	color: var(--dd-color-accent);
	font-size: 0.72rem;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	font-weight: 700;
	margin-bottom: 0.6rem;
}
.dd-section-head__eyebrow--gold { color: var(--dd-color-gold); }
.dd-section-head__title {
	font-family: var(--dd-font-display);
	font-size: clamp(1.75rem, 3.4vw, 2.65rem);
	color: var(--dd-color-primary);
	line-height: 1.15;
	margin: 0;
	max-width: 22ch;
}
.dd-section-head--center .dd-section-head__title { margin-inline: auto; }
.dd-section-head__title--ivory { color: #fff; max-width: 24ch; }
.dd-section-head__lede {
	max-width: 720px;
	margin: 1.25rem auto 0;
	color: rgba(246, 241, 232, 0.78);
	font-size: 1.0625rem;
	line-height: 1.7;
}
.dd-section-head__link {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	color: var(--dd-color-primary);
	font-size: 0.78rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	font-weight: 700;
	padding-bottom: 0.4rem;
	border-bottom: 1px solid var(--dd-color-gold);
	flex-shrink: 0;
	transition: gap 200ms ease, color 200ms ease;
}
.dd-section-head__link:hover { gap: 0.75rem; color: var(--dd-color-accent); }

@media (max-width: 700px) {
	/* Default section heads stack to the left; the --center variant
	   stays centered (otherwise eyebrows and pretitles drift to the
	   left and break the editorial composition). */
	.dd-section-head { flex-direction: column; align-items: flex-start; }
	.dd-section-head--center { align-items: center; text-align: center; }
}

@media (max-width: 700px) {
	.dd-field-row { grid-template-columns: 1fr; }
	.dd-contact-form-wrap { padding: 1.5rem 1.25rem; }
}

