:root {
	--arch-wine: #2a0f13;
	--arch-wine-2: #421519;
	--arch-burgundy: #6f1d2c;
	--arch-burgundy-2: #8f2937;
	--arch-gold: #c99a3f;
	--arch-gold-light: #f2d083;
	--arch-cream: #f8f1e4;
	--arch-ivory: #fffaf0;
	--arch-white: #ffffff;
	--arch-ink: #241b1e;
	--arch-muted: #756469;
	--arch-line: #eadcc8;
	--arch-shadow: 0 22px 60px rgba(42, 15, 19, 0.14);
	--arch-shadow-soft: 0 12px 36px rgba(42, 15, 19, 0.10);
	--arch-radius: 18px;
	--arch-radius-sm: 10px;
	--arch-content: min(1200px, calc(100vw - 40px));
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
	margin: 0;
	background: var(--arch-ivory);
	color: var(--arch-ink);
	font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

body.admin-bar .arch-site-header { top: 32px; }

a { color: inherit; }

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

h1, h2, h3, h4, h5, h6 {
	margin: 0 0 0.7em;
	color: var(--arch-wine);
	font-family: Georgia, "Times New Roman", serif;
	font-weight: 700;
	line-height: 1.05;
}

p { margin: 0 0 1rem; }

.screen-reader-text, .sr-only {
	position: absolute !important;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.skip-link:focus {
	clip: auto !important;
	clip-path: none;
	display: block;
	left: 1rem;
	top: 1rem;
	z-index: 99999;
	width: auto;
	height: auto;
	padding: 0.7rem 1rem;
	border-radius: 8px;
	background: var(--arch-gold);
	color: var(--arch-wine);
	font-weight: 800;
}

.arch-announcement {
	position: relative;
	z-index: 31;
	padding: 0.58rem 1rem;
	background: linear-gradient(90deg, #5e121d, #7c2230, #4b1117);
	color: #fff7e7;
	font-size: 0.84rem;
	font-weight: 750;
	letter-spacing: 0.01em;
	text-align: center;
}

.arch-cross { color: var(--arch-gold-light); margin-right: 0.35rem; }

.arch-site-header {
	position: sticky;
	top: 0;
	z-index: 30;
	border-bottom: 1px solid rgba(201, 154, 63, 0.28);
	background: rgba(255, 250, 240, 0.94);
	box-shadow: 0 8px 24px rgba(42, 15, 19, 0.05);
	backdrop-filter: blur(18px);
}

.arch-header-inner {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	gap: clamp(0.75rem, 2vw, 2rem);
	align-items: center;
	width: var(--arch-content);
	min-height: 96px;
	margin: 0 auto;
}

.arch-brand {
	display: inline-flex;
	gap: 0.85rem;
	align-items: center;
	min-width: 265px;
	color: var(--arch-wine);
	text-decoration: none;
}

.arch-brand-logo {
	width: auto;
	height: clamp(56px, 7vw, 76px);
	max-width: 110px;
	object-fit: contain;
	filter: drop-shadow(0 8px 14px rgba(42, 15, 19, 0.10));
}

.arch-brand-copy { display: grid; line-height: 1.08; }
.arch-brand-copy strong {
	color: #6b4828;
	font-family: Georgia, "Times New Roman", serif;
	font-size: clamp(1.05rem, 2vw, 1.7rem);
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
.arch-brand-copy small {
	margin-top: 0.18rem;
	color: #6d4b2d;
	font-size: clamp(0.68rem, 1vw, 0.82rem);
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.arch-primary-nav { justify-self: center; }
.arch-primary-nav ul {
	display: flex;
	gap: clamp(1rem, 2.2vw, 2.1rem);
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 0;
	list-style: none;
}
.arch-primary-nav li { position: relative; }
.arch-primary-nav a {
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	color: var(--arch-wine);
	font-size: 0.86rem;
	font-weight: 850;
	letter-spacing: 0.045em;
	text-decoration: none;
	text-transform: uppercase;
}
.arch-primary-nav .current-menu-item > a,
.arch-primary-nav a:hover,
.arch-primary-nav a:focus { color: var(--arch-gold); }
.arch-primary-nav .menu-item-has-children > a::after {
	content: "⌄";
	margin-left: 0.35rem;
	font-size: 0.88rem;
}
.arch-primary-nav .sub-menu {
	position: absolute;
	top: calc(100% + 12px);
	left: 50%;
	display: grid;
	min-width: 290px;
	padding: 0.55rem;
	border: 1px solid rgba(201, 154, 63, 0.30);
	border-radius: 14px;
	background: rgba(255, 250, 240, 0.98);
	box-shadow: var(--arch-shadow);
	opacity: 0;
	transform: translate(-50%, 10px);
	pointer-events: none;
	transition: opacity 160ms ease, transform 160ms ease;
}
.arch-primary-nav li:hover > .sub-menu,
.arch-primary-nav li:focus-within > .sub-menu {
	opacity: 1;
	transform: translate(-50%, 0);
	pointer-events: auto;
}
.arch-primary-nav .sub-menu a {
	display: flex;
	min-height: auto;
	padding: 0.75rem 0.85rem;
	border-radius: 10px;
	font-size: 0.82rem;
	letter-spacing: 0.02em;
	text-transform: none;
}
.arch-primary-nav .sub-menu a:hover { background: var(--arch-cream); color: var(--arch-burgundy); }

.arch-header-tools {
	display: flex;
	gap: 0.5rem;
	align-items: center;
	justify-content: end;
}
.arch-tool-button {
	position: relative;
	display: inline-grid;
	place-items: center;
	width: 44px;
	height: 44px;
	border: 1px solid rgba(201, 154, 63, 0.28);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.55);
	color: var(--arch-wine);
	font-size: 1.2rem;
	text-decoration: none;
	transition: transform 160ms ease, background 160ms ease, color 160ms ease;
}
.arch-tool-button:hover { transform: translateY(-1px); background: var(--arch-wine); color: var(--arch-gold-light); }
.arch-cart-count {
	position: absolute;
	top: -5px;
	right: -3px;
	display: inline-grid;
	place-items: center;
	min-width: 20px;
	height: 20px;
	padding: 0 0.25rem;
	border-radius: 999px;
	background: var(--arch-gold);
	color: var(--arch-wine);
	font-size: 0.68rem;
	font-weight: 900;
}
.arch-mobile-toggle { display: none; }
.arch-header-search {
	border-top: 1px solid rgba(201, 154, 63, 0.22);
	background: rgba(255, 250, 240, 0.98);
}
.arch-header-search-inner { width: var(--arch-content); margin: 0 auto; padding: 1rem 0; }

.search-form,
.woocommerce-product-search {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0.4rem;
	align-items: center;
	max-width: 760px;
	padding: 0.38rem;
	border: 1px solid rgba(111, 29, 44, 0.16);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.9);
	box-shadow: var(--arch-shadow-soft);
}
.search-field,
.search-form input[type="search"],
.woocommerce-product-search input[type="search"] {
	width: 100%;
	min-height: 52px;
	padding: 0 1.1rem;
	border: 0;
	background: transparent;
	color: var(--arch-ink);
	font: inherit;
	outline: none;
}
.search-submit,
.search-form button,
.woocommerce-product-search button {
	min-height: 48px;
	padding: 0 1.35rem;
	border: 0;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--arch-gold-light), var(--arch-gold));
	color: var(--arch-wine);
	font-weight: 900;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	cursor: pointer;
}

.arch-homepage { overflow: hidden; }
.arch-hero {
	position: relative;
	min-height: clamp(680px, 82vh, 850px);
	background:
		radial-gradient(circle at 76% 36%, rgba(201, 154, 63, 0.18), transparent 28%),
		linear-gradient(90deg, rgba(42, 15, 19, 0.94) 0%, rgba(42, 15, 19, 0.90) 43%, rgba(82, 25, 32, 0.86) 100%),
		linear-gradient(135deg, #2a0f13, #6f1d2c);
	color: #fff8e8;
}
.arch-hero::before,
.arch-hero::after {
	content: "";
	position: absolute;
	pointer-events: none;
}
.arch-hero::before {
	inset: 0;
	background:
		radial-gradient(circle at 14% 72%, rgba(242, 208, 131, 0.22) 0 2px, transparent 3px),
		radial-gradient(circle at 18% 76%, rgba(242, 208, 131, 0.18) 0 2px, transparent 3px),
		linear-gradient(120deg, rgba(255, 250, 240, 0.04), transparent 34%);
	background-size: auto, auto, auto;
}
.arch-hero::after {
	left: 0;
	right: 0;
	bottom: 0;
	height: 18px;
	background: repeating-linear-gradient(90deg, var(--arch-gold) 0 16px, #6f4822 16px 21px, var(--arch-wine) 21px 30px);
	opacity: 0.82;
}
.arch-hero-inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(330px, 520px);
	gap: clamp(2rem, 5vw, 5rem);
	align-items: center;
	width: var(--arch-content);
	min-height: inherit;
	margin: 0 auto;
	padding: clamp(4.5rem, 8vw, 7.2rem) 0;
}
.arch-eyebrow,
.arch-mini-title {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	width: fit-content;
	margin: 0 0 1.1rem;
	color: var(--arch-gold-light);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}
.arch-eyebrow::before,
.arch-mini-title::before,
.arch-mini-title::after { content: ""; width: 34px; height: 1px; background: currentColor; opacity: 0.9; }
.arch-hero h1 {
	max-width: 760px;
	margin: 0;
	color: #f7d98a;
	font-size: clamp(3.4rem, 7vw, 6.8rem);
	line-height: 0.92;
	letter-spacing: -0.045em;
	text-wrap: balance;
}
.arch-lead {
	max-width: 620px;
	margin: 1.25rem 0 0;
	color: #fff3db;
	font-size: clamp(1.05rem, 1.5vw, 1.22rem);
}
.arch-hero-actions { display: flex; flex-wrap: wrap; gap: 0.85rem; margin-top: 2.1rem; }
.arch-button,
.button,
.wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 0.82rem 1.25rem;
	border-radius: 999px;
	font-size: 0.82rem;
	font-weight: 900;
	letter-spacing: 0.06em;
	line-height: 1;
	text-decoration: none;
	text-transform: uppercase;
	transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease;
}
.arch-button:hover { transform: translateY(-1px); }
.arch-button-gold,
.wp-block-button__link {
	border: 1px solid rgba(242, 208, 131, 0.66);
	background: linear-gradient(135deg, var(--arch-gold-light), var(--arch-gold));
	box-shadow: 0 18px 40px rgba(201, 154, 63, 0.20);
	color: var(--arch-wine);
}
.arch-button-outline {
	border: 1px solid rgba(242, 208, 131, 0.46);
	background: rgba(255, 255, 255, 0.05);
	color: #fff3db;
}
.arch-button-outline:hover { background: rgba(255, 255, 255, 0.12); }
.arch-hero-search { margin-top: 1.35rem; max-width: 640px; }
.arch-hero-search .woocommerce-product-search,
.arch-hero-search .search-form { max-width: 100%; }

.arch-hero-emblem {
	display: grid;
	gap: 1.2rem;
	justify-items: center;
	align-self: center;
}
.arch-hero-emblem > img {
	width: min(92%, 460px);
	max-height: 470px;
	object-fit: contain;
	filter: drop-shadow(0 24px 50px rgba(0, 0, 0, 0.34));
}
.arch-emblem-card {
	width: min(100%, 420px);
	padding: 1.2rem;
	border: 1px solid rgba(242, 208, 131, 0.42);
	border-radius: 20px;
	background: rgba(42, 15, 19, 0.76);
	box-shadow: 0 20px 55px rgba(0, 0, 0, 0.24);
	backdrop-filter: blur(14px);
}
.arch-emblem-card h2 { color: #fff3db; font-size: 1.35rem; }
.arch-emblem-card ul { display: grid; gap: 0.45rem; margin: 0; padding: 0; list-style: none; }
.arch-emblem-card li { position: relative; padding-left: 1.3rem; color: #fff3db; font-weight: 700; }
.arch-emblem-card li::before { content: "✣"; position: absolute; left: 0; color: var(--arch-gold-light); }

.arch-section {
	padding: clamp(4rem, 7vw, 6rem) max(20px, calc((100vw - 1200px) / 2));
	background: var(--arch-white);
}
.arch-section-cream { background: linear-gradient(180deg, var(--arch-ivory), var(--arch-cream)); }
.arch-section-heading { max-width: 780px; margin: 0 auto 2rem; text-align: center; }
.arch-section-heading .arch-mini-title { justify-content: center; margin-left: auto; margin-right: auto; color: var(--arch-burgundy); }
.arch-section-heading h2,
.arch-mission-copy h2,
.arch-newsletter-section h2 {
	font-size: clamp(2.1rem, 4vw, 3.65rem);
	letter-spacing: -0.025em;
}

.arch-category-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.15rem;
	width: var(--arch-content);
	margin: 0 auto;
}
.arch-category-card {
	position: relative;
	display: grid;
	min-height: 330px;
	overflow: hidden;
	padding: 1.1rem;
	border: 1px solid rgba(201, 154, 63, 0.27);
	border-radius: 22px;
	background: var(--arch-white);
	box-shadow: var(--arch-shadow-soft);
	text-decoration: none;
	isolation: isolate;
	transition: transform 180ms ease, box-shadow 180ms ease;
}
.arch-category-card:hover { transform: translateY(-4px); box-shadow: var(--arch-shadow); }
.arch-category-art {
	position: absolute;
	inset: 0 0 auto;
	height: 190px;
	background:
		linear-gradient(0deg, rgba(42, 15, 19, 0.48), rgba(42, 15, 19, 0.16)),
		linear-gradient(135deg, rgba(201, 154, 63, 0.46), rgba(111, 29, 44, 0.82));
	z-index: -1;
}
.arch-category-card::before {
	content: "✣";
	position: absolute;
	top: 54px;
	left: 50%;
	z-index: 0;
	transform: translateX(-50%);
	color: rgba(255, 250, 240, 0.82);
	font-size: 4rem;
	text-shadow: 0 10px 30px rgba(0,0,0,0.25);
}
.arch-category-books .arch-category-art { background: linear-gradient(0deg, rgba(42,15,19,.62), rgba(42,15,19,.18)), linear-gradient(135deg, #25140e, #7a4d28); }
.arch-category-icons .arch-category-art { background: radial-gradient(circle at 50% 44%, rgba(242,208,131,.9) 0 17%, transparent 18%), linear-gradient(135deg, #3b1718, #97592f); }
.arch-category-children .arch-category-art { background: radial-gradient(circle at 24% 28%, #2b8582 0 10%, transparent 11%), radial-gradient(circle at 75% 68%, #d9af57 0 12%, transparent 13%), linear-gradient(135deg, #402225, #8c6436); }
.arch-category-food .arch-category-art { background: radial-gradient(circle at 30% 70%, rgba(116,85,44,.85) 0 18%, transparent 19%), linear-gradient(135deg, #22120e, #766634); }
.arch-category-bazaar .arch-category-art { background: repeating-linear-gradient(45deg, #7d1e2e 0 12px, #c99a3f 12px 15px, #4a121c 15px 27px); }
.arch-category-seasonal .arch-category-art { background: radial-gradient(circle at 50% 45%, rgba(242,208,131,.95) 0 12%, transparent 13%), linear-gradient(135deg, #2b120f, #5e7839); }
.arch-category-card strong {
	align-self: end;
	margin-top: 185px;
	color: var(--arch-wine);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.35rem;
	line-height: 1.1;
}
.arch-category-card span:not(.arch-category-art) { color: var(--arch-muted); }
.arch-category-card em {
	align-self: end;
	color: var(--arch-burgundy);
	font-style: normal;
	font-weight: 900;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.arch-woo-shortcode,
.arch-placeholder-products { width: var(--arch-content); margin: 0 auto; }
.arch-centered-action { margin-top: 1.4rem; text-align: center; }
.arch-placeholder-products {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 1rem;
}
.arch-four-placeholders { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.arch-product-placeholder {
	overflow: hidden;
	border: 1px solid rgba(201, 154, 63, 0.24);
	border-radius: 18px;
	background: var(--arch-white);
	box-shadow: var(--arch-shadow-soft);
}
.arch-product-placeholder span { display: block; aspect-ratio: 1 / 0.78; background: linear-gradient(135deg, rgba(111,29,44,.18), rgba(201,154,63,.28)); }
.arch-product-placeholder h3,
.arch-product-placeholder p { padding: 0 1rem; }
.arch-product-placeholder h3 { margin-top: 1rem; font-size: 1.05rem; }
.arch-product-placeholder p { color: var(--arch-muted); font-size: 0.9rem; }

.woocommerce ul.products {
	display: grid !important;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 1.2rem !important;
	margin: 0 !important;
}
.arch-featured-products .woocommerce ul.products { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	float: none !important;
	width: auto !important;
	margin: 0 !important;
	border: 1px solid rgba(201, 154, 63, 0.24);
	border-radius: 18px;
	background: var(--arch-white);
	box-shadow: var(--arch-shadow-soft);
	overflow: hidden;
	transition: transform 180ms ease, box-shadow 180ms ease;
}
.woocommerce ul.products li.product:hover { transform: translateY(-3px); box-shadow: var(--arch-shadow); }
.woocommerce ul.products li.product a img { width: 100%; margin: 0 !important; aspect-ratio: 1 / 0.78; object-fit: cover; background: var(--arch-cream); }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	padding: 1rem 1rem 0 !important;
	color: var(--arch-wine);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1rem !important;
}
.woocommerce ul.products li.product .price { display: block; padding: 0 1rem; color: var(--arch-burgundy) !important; font-weight: 900; }
.woocommerce ul.products li.product .button {
	margin: 1rem !important;
	border: 0;
	background: linear-gradient(135deg, var(--arch-gold-light), var(--arch-gold));
	color: var(--arch-wine);
}
.woocommerce span.onsale {
	min-height: auto;
	min-width: auto;
	padding: 0.35rem 0.55rem;
	border-radius: 999px;
	background: var(--arch-burgundy);
	color: #fff7e7;
	font-weight: 900;
}

.arch-service-band {
	padding: clamp(3.5rem, 7vw, 5.5rem) max(20px, calc((100vw - 1200px) / 2));
	background:
		linear-gradient(135deg, rgba(42, 15, 19, 0.96), rgba(111, 29, 44, 0.92)),
		repeating-linear-gradient(45deg, rgba(201,154,63,.16) 0 1px, transparent 1px 18px);
}
.arch-service-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
	width: var(--arch-content);
	margin: 0 auto;
}
.arch-service-grid article {
	padding: clamp(1.2rem, 3vw, 2rem);
	border: 1px solid rgba(242, 208, 131, 0.25);
	border-radius: 20px;
	background: rgba(255, 255, 255, 0.05);
	color: #fff3db;
}
.arch-service-grid span { color: var(--arch-gold-light); font-size: 2rem; }
.arch-service-grid h3 { color: #fff7e7; font-size: 1.45rem; }
.arch-service-grid p { margin-bottom: 0; color: rgba(255, 247, 231, 0.83); }

.arch-mission-section {
	display: grid;
	grid-template-columns: minmax(240px, 330px) minmax(0, 1fr) minmax(260px, 340px);
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: center;
	padding: clamp(4rem, 7vw, 6rem) max(20px, calc((100vw - 1200px) / 2));
	background:
		radial-gradient(circle at 8% 20%, rgba(201,154,63,.12), transparent 20%),
		linear-gradient(180deg, var(--arch-cream), var(--arch-ivory));
}
.arch-mission-image {
	display: grid;
	place-items: center;
	min-height: 260px;
	border: 1px solid rgba(201,154,63,.26);
	border-radius: 24px;
	background: linear-gradient(135deg, rgba(42,15,19,.94), rgba(111,29,44,.80));
	box-shadow: var(--arch-shadow-soft);
}
.arch-mission-image img { width: min(88%, 240px); max-height: 230px; object-fit: contain; filter: drop-shadow(0 20px 40px rgba(0,0,0,.25)); }
.arch-mission-copy .arch-mini-title { color: var(--arch-burgundy); }
.arch-mission-copy p { max-width: 640px; color: var(--arch-muted); font-size: 1.05rem; }
.arch-mission-copy a { color: var(--arch-burgundy); font-weight: 900; letter-spacing: 0.05em; text-decoration: none; text-transform: uppercase; }
.arch-support-card {
	padding: 1.4rem;
	border: 1px solid rgba(201,154,63,.32);
	border-radius: 20px;
	background: var(--arch-white);
	box-shadow: var(--arch-shadow-soft);
}
.arch-support-card h3 { font-size: 1.35rem; }
.arch-support-card p { margin: 0 0 0.7rem; color: var(--arch-muted); }
.arch-support-card a { color: var(--arch-burgundy); font-weight: 800; }

.arch-newsletter-section {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) minmax(320px, 560px);
	gap: clamp(1rem, 4vw, 3rem);
	align-items: center;
	padding: clamp(2.6rem, 5vw, 4rem) max(20px, calc((100vw - 1200px) / 2));
	background:
		linear-gradient(135deg, rgba(111, 29, 44, 0.95), rgba(42, 15, 19, 0.97)),
		repeating-linear-gradient(45deg, rgba(242,208,131,.11) 0 1px, transparent 1px 18px);
	color: #fff7e7;
}
.arch-newsletter-medallion {
	display: grid;
	place-items: center;
	width: 92px;
	height: 92px;
	border: 1px solid rgba(242,208,131,.45);
	border-radius: 50%;
	background: rgba(42, 15, 19, 0.44);
	color: var(--arch-gold-light);
	font-size: 2.2rem;
}
.arch-newsletter-section h2 { margin-bottom: 0.3rem; color: #fff7e7; font-size: clamp(1.8rem, 3vw, 2.8rem); }
.arch-newsletter-section p { margin-bottom: 0; color: rgba(255,247,231,.85); }
.arch-newsletter-form form { display: grid; grid-template-columns: 1fr auto; gap: 0; }
.arch-newsletter-form input[type="email"] {
	min-height: 52px;
	padding: 0 1rem;
	border: 1px solid rgba(242,208,131,.32);
	border-radius: 999px 0 0 999px;
	background: rgba(255,250,240,.96);
	color: var(--arch-ink);
	font: inherit;
}
.arch-newsletter-form button {
	min-height: 52px;
	padding: 0 1.2rem;
	border: 1px solid rgba(242,208,131,.32);
	border-radius: 0 999px 999px 0;
	background: linear-gradient(135deg, var(--arch-gold-light), var(--arch-gold));
	color: var(--arch-wine);
	font-weight: 900;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}
.arch-newsletter-form small { display: block; grid-column: 1 / -1; margin-top: 0.55rem; color: rgba(255,247,231,.72); }

.arch-site-footer {
	background:
		linear-gradient(180deg, #2a0f13, #16080b),
		repeating-linear-gradient(45deg, rgba(201,154,63,.08) 0 1px, transparent 1px 20px);
	color: rgba(255, 247, 231, 0.82);
}
.arch-footer-top {
	display: grid;
	grid-template-columns: 1.4fr repeat(3, 1fr);
	gap: clamp(1.2rem, 4vw, 3rem);
	width: var(--arch-content);
	margin: 0 auto;
	padding: clamp(3rem, 6vw, 4.5rem) 0;
}
.arch-footer-top h2 { color: #fff7e7; font-size: 1rem; letter-spacing: 0.07em; text-transform: uppercase; }
.arch-footer-top ul { display: grid; gap: 0.42rem; margin: 0; padding: 0; list-style: none; }
.arch-footer-top a { color: rgba(255,247,231,.86); text-decoration: none; }
.arch-footer-top a:hover { color: var(--arch-gold-light); }
.arch-footer-brand img { width: 130px; max-height: 110px; object-fit: contain; }
.arch-footer-brand h2 { margin-top: 1rem; font-size: 1.1rem; }
.arch-footer-bottom {
	border-top: 1px solid rgba(242,208,131,.16);
	border-bottom: 8px solid rgba(201,154,63,.7);
	padding: 1rem max(20px, calc((100vw - 1200px) / 2));
	text-align: center;
}
.arch-footer-bottom p { margin: 0; font-size: 0.85rem; }
.arch-footer-bottom a { color: var(--arch-gold-light); text-decoration: none; }

.arch-page-wrap { padding: clamp(3rem, 7vw, 5.5rem) 0; background: var(--arch-ivory); }
.arch-content-shell { width: var(--arch-content); margin: 0 auto; }
.arch-page-card,
.arch-entry-card {
	padding: clamp(1.4rem, 4vw, 3rem);
	border: 1px solid rgba(201,154,63,.26);
	border-radius: 24px;
	background: var(--arch-white);
	box-shadow: var(--arch-shadow-soft);
}
.arch-page-title-block { margin-bottom: 1.4rem; }
.arch-page-title-block h1,
.entry-title { font-size: clamp(2.2rem, 5vw, 4.2rem); }
.arch-readable-content { max-width: 900px; }
.arch-readable-content h2 { margin-top: 2rem; font-size: clamp(1.6rem, 3vw, 2.4rem); }
.arch-readable-content ul, .arch-readable-content ol { padding-left: 1.25rem; }
.arch-post-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1.2rem; }

input[type="text"], input[type="email"], input[type="tel"], input[type="url"], input[type="password"], input[type="number"], textarea, select {
	max-width: 100%;
	border: 1px solid rgba(111, 29, 44, 0.18);
	border-radius: 12px;
	background: #fff;
	color: var(--arch-ink);
	font: inherit;
}
textarea { padding: 0.9rem; }

.arch-contact-form { display: grid; gap: 1rem; max-width: 780px; }
.arch-contact-form .arch-field-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.arch-contact-form label { display: grid; gap: 0.35rem; font-weight: 800; color: var(--arch-wine); }
.arch-contact-form input,
.arch-contact-form select,
.arch-contact-form textarea { width: 100%; min-height: 48px; padding: 0.75rem 0.85rem; }
.arch-contact-form textarea { min-height: 150px; }
.arch-contact-form button { justify-self: start; border: 0; cursor: pointer; }
.arch-form-message { padding: 0.8rem 1rem; border-radius: 12px; font-weight: 800; }
.arch-form-success { background: #eef9ee; color: #1c6b2b; }
.arch-form-error { background: #fff1f1; color: #8a1c24; }

@media (max-width: 1180px) {
	.arch-header-inner { grid-template-columns: auto auto; }
	.arch-primary-nav {
		position: fixed;
		top: var(--arch-mobile-top, 96px);
		left: 0;
		right: 0;
		display: none;
		max-height: calc(100vh - var(--arch-mobile-top, 96px));
		overflow: auto;
		padding: 1rem 20px 1.4rem;
		border-top: 1px solid rgba(201,154,63,.25);
		background: rgba(255,250,240,.99);
		box-shadow: var(--arch-shadow);
	}
	body.arch-menu-open .arch-primary-nav { display: block; }
	.arch-primary-nav ul { display: grid; gap: 0.25rem; justify-content: stretch; }
	.arch-primary-nav a { justify-content: space-between; min-height: 48px; padding: 0 0.4rem; }
	.arch-primary-nav .sub-menu {
		position: static;
		display: none;
		min-width: 0;
		padding: 0.25rem 0 0.55rem 1rem;
		border: 0;
		box-shadow: none;
		opacity: 1;
		transform: none;
		pointer-events: auto;
		background: transparent;
	}
	.arch-primary-nav li:hover > .sub-menu,
	.arch-primary-nav li:focus-within > .sub-menu,
	.arch-primary-nav li.arch-submenu-open > .sub-menu { display: grid; }
	.arch-mobile-toggle {
		display: inline-flex;
		justify-self: end;
		gap: 0.28rem;
		align-items: center;
		padding: 0.65rem 0.7rem;
		border: 1px solid rgba(111,29,44,.18);
		border-radius: 999px;
		background: #fff;
		color: var(--arch-wine);
		font-weight: 900;
		cursor: pointer;
	}
	.arch-mobile-toggle span { display: block; width: 18px; height: 2px; border-radius: 9px; background: currentColor; }
	.arch-mobile-toggle b { margin-left: 0.28rem; font-size: 0.78rem; text-transform: uppercase; }
	.arch-header-tools { grid-column: 1 / -1; justify-content: center; padding-bottom: 0.8rem; }
}

@media (max-width: 900px) {
	body.admin-bar .arch-site-header { top: 46px; }
	.arch-header-inner { min-height: auto; padding: 0.75rem 0; }
	.arch-brand { min-width: 0; }
	.arch-brand-logo { height: 52px; max-width: 78px; }
	.arch-brand-copy strong { font-size: 1rem; letter-spacing: 0.04em; }
	.arch-brand-copy small { font-size: 0.62rem; }
	.arch-hero-inner,
	.arch-mission-section,
	.arch-newsletter-section { grid-template-columns: 1fr; }
	.arch-hero { min-height: auto; }
	.arch-hero-inner { padding: 4rem 0 5rem; }
	.arch-hero h1 { font-size: clamp(2.9rem, 16vw, 5rem); }
	.arch-hero-emblem { order: -1; }
	.arch-hero-emblem > img { width: min(72vw, 340px); }
	.arch-category-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.arch-featured-products .woocommerce ul.products,
	.woocommerce ul.products,
	.arch-placeholder-products,
	.arch-four-placeholders,
	.arch-service-grid,
	.arch-footer-top,
	.arch-post-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.arch-newsletter-medallion { width: 74px; height: 74px; }
}

@media (max-width: 620px) {
	:root { --arch-content: min(100% - 28px, 1200px); }
	.arch-announcement { font-size: 0.76rem; }
	.arch-header-inner { grid-template-columns: 1fr auto; }
	.arch-header-tools { justify-content: space-between; }
	.arch-tool-button { width: 42px; height: 42px; }
	.arch-brand-copy small { display: none; }
	.arch-hero-actions { display: grid; }
	.search-form,
	.woocommerce-product-search { grid-template-columns: 1fr; border-radius: 18px; }
	.search-submit,
	.search-form button,
	.woocommerce-product-search button { border-radius: 14px; }
	.arch-category-grid,
	.arch-featured-products .woocommerce ul.products,
	.woocommerce ul.products,
	.arch-placeholder-products,
	.arch-four-placeholders,
	.arch-service-grid,
	.arch-footer-top,
	.arch-contact-form .arch-field-row { grid-template-columns: 1fr; }
	.arch-category-card { min-height: 300px; }
	.arch-newsletter-form form { grid-template-columns: 1fr; gap: 0.5rem; }
	.arch-newsletter-form input[type="email"],
	.arch-newsletter-form button { border-radius: 999px; }
}

/* --------------------------------------------------------------------------
 * v2.2 visual repair: tighter navigation, real category art, safer images.
 * -------------------------------------------------------------------------- */
.arch-site-header {
	z-index: 1000;
}
.arch-header-inner {
	min-height: 82px;
}
.arch-brand {
	min-width: min(420px, 42vw);
}
.arch-brand-logo {
	height: clamp(48px, 5vw, 64px);
	max-width: 88px;
}
.arch-brand-copy strong {
	font-size: clamp(1.15rem, 1.8vw, 1.62rem);
	letter-spacing: 0.055em;
}
.arch-brand-copy small {
	font-size: clamp(0.66rem, .92vw, .8rem);
}
.arch-primary-nav ul {
	gap: clamp(.75rem, 2vw, 1.7rem);
}
.arch-primary-nav .sub-menu {
	display: block;
	min-width: 286px;
	max-width: 340px;
	height: auto !important;
	max-height: calc(100vh - 160px);
	overflow: auto;
	padding: .45rem;
	gap: 0 !important;
}
.arch-primary-nav .sub-menu li {
	margin: 0;
}
.arch-primary-nav .sub-menu a {
	min-height: 42px !important;
	padding: .62rem .78rem;
	font-size: .83rem;
	line-height: 1.25;
	white-space: normal;
}
.arch-primary-nav .sub-menu .sub-menu {
	left: calc(100% + 10px);
	top: 0;
	transform: translate(0, 10px);
}
.arch-primary-nav .sub-menu li:hover > .sub-menu,
.arch-primary-nav .sub-menu li:focus-within > .sub-menu {
	transform: translate(0, 0);
}
.arch-hero {
	min-height: clamp(590px, 72vh, 760px);
}
.arch-hero-inner {
	grid-template-columns: minmax(0, 1.04fr) minmax(300px, 470px);
	padding: clamp(3.4rem, 6vw, 5.6rem) 0;
}
.arch-hero h1 {
	max-width: 700px;
	font-size: clamp(3.05rem, 6.2vw, 6.15rem);
	line-height: .94;
}
.arch-hero-emblem > img {
	width: min(90%, 410px);
	max-height: 400px;
}
.arch-emblem-card {
	width: min(100%, 390px);
	padding: 1rem 1.1rem;
}
.arch-emblem-card h2 {
	font-size: 1.18rem;
}
.arch-emblem-card li {
	font-size: .94rem;
}
.arch-category-grid {
	gap: 1.25rem;
}
.arch-category-card {
	display: block;
	min-height: 0;
	padding: 0;
	border-radius: 18px;
	background: var(--arch-white);
}
.arch-category-card::before {
	content: none;
}
.arch-category-image-wrap {
	display: block;
	position: relative;
	height: 190px;
	overflow: hidden;
	background: var(--arch-wine);
}
.arch-category-image-wrap::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(42,15,19,.04), rgba(42,15,19,.18));
}
.arch-category-image-wrap img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.01);
	transition: transform 260ms ease;
}
.arch-category-card:hover .arch-category-image-wrap img {
	transform: scale(1.055);
}
.arch-category-body {
	display: grid;
	gap: .35rem;
	min-height: 170px;
	padding: 1rem 1.08rem 1.08rem;
}
.arch-category-card strong {
	align-self: auto;
	margin-top: 0;
	font-size: 1.28rem;
}
.arch-category-card span:not(.arch-category-art) {
	color: var(--arch-muted);
}
.arch-category-card em {
	align-self: end;
	margin-top: .35rem;
}
.arch-preview-note {
	width: var(--arch-content);
	margin: -0.5rem auto 1rem;
	color: var(--arch-muted);
	font-size: .92rem;
	font-weight: 700;
	text-align: center;
}
.arch-preview-product-grid {
	display: grid;
	gap: 1rem;
	width: var(--arch-content);
	margin: 0 auto;
}
.arch-preview-products-six {
	grid-template-columns: repeat(6, minmax(0, 1fr));
}
.arch-preview-products-four {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}
.arch-preview-product-card {
	overflow: hidden;
	border: 1px solid rgba(201,154,63,.24);
	border-radius: 18px;
	background: var(--arch-white);
	box-shadow: var(--arch-shadow-soft);
	transition: transform 180ms ease, box-shadow 180ms ease;
}
.arch-preview-product-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--arch-shadow);
}
.arch-preview-product-card a {
	display: block;
	color: inherit;
	text-decoration: none;
}
.arch-preview-product-card img {
	display: block;
	width: 100%;
	aspect-ratio: 1 / .82;
	height: auto;
	object-fit: cover;
	background: var(--arch-cream);
}
.arch-preview-product-body {
	display: grid;
	gap: .28rem;
	padding: .85rem .9rem 1rem;
}
.arch-preview-product-body small {
	color: var(--arch-gold);
	font-size: .68rem;
	font-weight: 900;
	letter-spacing: .06em;
	text-transform: uppercase;
}
.arch-preview-product-body strong {
	color: var(--arch-wine);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1rem;
	line-height: 1.15;
}
.arch-preview-product-body em {
	color: var(--arch-burgundy);
	font-size: .78rem;
	font-style: normal;
	font-weight: 800;
}
.arch-page-card,
.arch-entry-card {
	max-width: 100%;
}
.arch-readable-content {
	max-width: none;
}
.arch-readable-content > p,
.arch-readable-content > ul,
.arch-readable-content > ol,
.arch-readable-content > h2,
.arch-readable-content > h3,
.arch-readable-content > h4 {
	max-width: 900px;
}
.arch-readable-content img {
	display: block;
	width: auto;
	max-width: 100%;
	max-height: 560px;
	object-fit: contain;
	margin-left: auto;
	margin-right: auto;
}
.arch-readable-content .woocommerce,
.arch-readable-content .wp-block-shortcode {
	max-width: none;
}
.woocommerce-info,
.woocommerce-message,
.woocommerce-error {
	border-radius: 16px;
	background: var(--arch-ivory);
	border-top-color: var(--arch-gold);
	box-shadow: var(--arch-shadow-soft);
}

@media (min-width: 1181px) {
	.arch-primary-nav .sub-menu::before {
		content: "";
		position: absolute;
		left: 0;
		right: 0;
		top: -14px;
		height: 14px;
	}
}

@media (max-width: 1180px) {
	.arch-header-inner {
		grid-template-columns: minmax(0, 1fr) auto;
		min-height: auto;
		padding: .7rem 0;
	}
	.arch-brand {
		min-width: 0;
	}
	.arch-primary-nav .sub-menu {
		max-width: none;
		max-height: none;
		overflow: visible;
		padding: .25rem 0 .55rem 1rem;
	}
	.arch-header-tools {
		grid-column: 1 / -1;
		justify-content: center;
		padding-bottom: .65rem;
	}
}

@media (max-width: 980px) {
	.arch-hero-inner,
	.arch-mission-section,
	.arch-newsletter-section {
		grid-template-columns: 1fr;
	}
	.arch-hero-inner {
		padding: 3.3rem 0 4.5rem;
	}
	.arch-hero-emblem {
		order: -1;
	}
	.arch-hero-emblem > img {
		width: min(64vw, 330px);
	}
	.arch-category-grid,
	.arch-preview-products-six,
	.arch-preview-products-four,
	.arch-featured-products .woocommerce ul.products,
	.woocommerce ul.products,
	.arch-placeholder-products,
	.arch-four-placeholders,
	.arch-service-grid,
	.arch-footer-top,
	.arch-post-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.arch-brand-logo {
		height: 46px;
		max-width: 62px;
	}
	.arch-brand-copy strong {
		font-size: .98rem;
		line-height: 1;
	}
	.arch-brand-copy small {
		display: block;
		font-size: .56rem;
		letter-spacing: .06em;
	}
	.arch-hero h1 {
		font-size: clamp(2.65rem, 15vw, 4.4rem);
	}
	.arch-category-grid,
	.arch-preview-products-six,
	.arch-preview-products-four,
	.arch-featured-products .woocommerce ul.products,
	.woocommerce ul.products,
	.arch-placeholder-products,
	.arch-four-placeholders,
	.arch-service-grid,
	.arch-footer-top,
	.arch-contact-form .arch-field-row {
		grid-template-columns: 1fr;
	}
	.arch-category-image-wrap {
		height: 205px;
	}
	.arch-category-body {
		min-height: 0;
	}
}

/* --------------------------------------------------------------------------
 * v2.3/v2.4 hard visual repair: compact logo, cache-proof header sizing, and safer
 * WooCommerce/category empty states.
 * -------------------------------------------------------------------------- */
.arch-site-header {
	z-index: 9999 !important;
}
.arch-site-header .arch-header-inner {
	min-height: 82px !important;
}
.arch-site-header .arch-brand {
	min-width: 0 !important;
	max-width: 560px !important;
	overflow: visible !important;
}
.arch-site-header .arch-brand img.arch-brand-logo {
	display: block !important;
	width: 64px !important;
	min-width: 64px !important;
	max-width: 64px !important;
	height: 64px !important;
	min-height: 64px !important;
	max-height: 64px !important;
	object-fit: contain !important;
	flex: 0 0 64px !important;
	margin: 0 !important;
}
.arch-site-header .arch-brand-copy {
	min-width: 0;
	max-width: 430px;
}
.arch-site-header .arch-primary-nav,
.arch-site-header .arch-header-tools {
	position: static !important;
	transform: none !important;
}
.arch-hero-emblem > img {
	width: min(90%, 410px) !important;
	max-width: 410px !important;
	max-height: 400px !important;
	object-fit: contain !important;
}
.arch-mission-image img {
	width: min(100%, 300px) !important;
	max-height: 260px !important;
	object-fit: contain !important;
}
.arch-shop-intro-card {
	margin-bottom: 1.6rem;
	background:
		radial-gradient(circle at 88% 12%, rgba(201,154,63,.14), transparent 26%),
		#fff;
}
.arch-shop-intro-card .arch-mini-title {
	color: var(--arch-burgundy);
}
.arch-shop-intro-card h1 {
	font-size: clamp(2.4rem, 5vw, 4.6rem);
}
.arch-shop-intro-card p:not(.arch-mini-title) {
	max-width: 850px;
	color: var(--arch-muted);
	font-size: 1.05rem;
}
.arch-woocommerce-shell {
	padding: clamp(1.2rem, 3vw, 2rem);
	border: 1px solid rgba(201,154,63,.22);
	border-radius: 22px;
	background: rgba(255,255,255,.72);
	box-shadow: var(--arch-shadow-soft);
}
.arch-woo-empty-state,
.arch-empty-catalog {
	text-align: center;
}
.arch-woo-empty-state h2,
.arch-empty-catalog h2 {
	font-size: clamp(1.8rem, 3vw, 2.6rem);
}
.arch-woo-empty-state > p,
.arch-empty-catalog > p:not(.arch-preview-note) {
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
	color: var(--arch-muted);
}
.arch-page-card .arch-empty-catalog {
	margin-top: 1.5rem;
}
.arch-page-card .arch-preview-product-grid {
	width: 100%;
}
.arch-page-card .arch-preview-products-six,
.arch-page-card .arch-preview-products-four {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}
.arch-readable-content .arch-preview-note {
	width: 100%;
	margin: 0 0 1rem;
}
body:not(.home) .entry-content img,
body:not(.home) .arch-readable-content img,
body:not(.home) .site-main img {
	max-width: 100% !important;
	height: auto !important;
	object-fit: contain;
}
body:not(.home) .arch-brand img,
body:not(.home) .arch-footer-brand img,
body:not(.home) .arch-preview-product-card img,
body:not(.home) .woocommerce ul.products li.product a img {
	object-fit: cover;
}
body:not(.home) .arch-brand img.arch-brand-logo {
	object-fit: contain !important;
}
@media (max-width: 1180px) {
	.arch-site-header .arch-header-inner {
		grid-template-columns: minmax(0, 1fr) auto !important;
		min-height: auto !important;
		padding: .7rem 0 !important;
	}
	.arch-site-header .arch-primary-nav {
		position: fixed !important;
	}
	.arch-site-header .arch-header-tools {
		grid-column: 1 / -1 !important;
		justify-content: center !important;
	}
}
@media (max-width: 900px) {
	.arch-page-card .arch-preview-products-six,
	.arch-page-card .arch-preview-products-four {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
@media (max-width: 640px) {
	.arch-site-header .arch-brand img.arch-brand-logo {
		width: 48px !important;
		min-width: 48px !important;
		max-width: 48px !important;
		height: 48px !important;
		min-height: 48px !important;
		max-height: 48px !important;
		flex-basis: 48px !important;
	}
	.arch-site-header .arch-brand-copy strong {
		font-size: .98rem !important;
	}
	.arch-site-header .arch-brand-copy small {
		font-size: .56rem !important;
	}
	.arch-page-card .arch-preview-products-six,
	.arch-page-card .arch-preview-products-four {
		grid-template-columns: 1fr;
	}
	.arch-woocommerce-shell {
		padding: 1rem;
		border-radius: 18px;
	}
}

/* --------------------------------------------------------------------------
 * v2.4 luxury polish: screenshot-matched typography, click-safe menu,
 * fast no-plugin hero slider, main church button, and real contact form.
 * -------------------------------------------------------------------------- */
:root {
	--arch-serif: "Cormorant Garamond", "Iowan Old Style", Georgia, "Times New Roman", serif;
	--arch-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
body { font-family: var(--arch-sans); }
h1, h2, h3, h4, h5, h6,
.arch-brand-copy strong,
.arch-category-card strong,
.arch-preview-product-body strong,
.arch-footer h2 {
	font-family: var(--arch-serif);
}
.arch-announcement {
	padding: .5rem 1rem;
	font-size: .82rem;
	font-weight: 800;
	background: linear-gradient(90deg, #5d121c, #791d2b, #4c1016);
}
.arch-site-header {
	background: rgba(255, 250, 240, .97) !important;
	box-shadow: 0 10px 35px rgba(42, 15, 19, .045);
}
.arch-header-inner {
	min-height: 96px !important;
	grid-template-columns: minmax(250px, auto) minmax(320px, 1fr) auto;
	gap: clamp(1rem, 2.4vw, 2.25rem);
}
.arch-brand {
	gap: .95rem !important;
	max-width: 520px !important;
}
.arch-brand-logo {
	width: 74px !important;
	min-width: 74px !important;
	max-width: 74px !important;
	height: 74px !important;
	min-height: 74px !important;
	max-height: 74px !important;
}
.arch-brand-copy {
	line-height: 1 !important;
}
.arch-brand-copy strong {
	font-size: clamp(1.45rem, 2.35vw, 2.05rem) !important;
	font-weight: 800;
	letter-spacing: .07em !important;
	line-height: .92 !important;
	color: #6b4828 !important;
}
.arch-brand-copy small {
	margin-top: .32rem !important;
	font-size: clamp(.72rem, .98vw, .84rem) !important;
	letter-spacing: .09em !important;
	line-height: 1.05 !important;
	color: #5d3c23 !important;
}
.arch-brand-copy em {
	display: inline-flex !important;
	align-items: center;
	gap: .55rem;
	margin-top: .36rem;
	color: #8a6337;
	font-size: .62rem;
	font-style: normal;
	font-weight: 900;
	letter-spacing: .16em;
	line-height: 1;
	text-transform: uppercase;
}
.arch-brand-copy em::before,
.arch-brand-copy em::after {
	content: "";
	display: block;
	width: 26px;
	height: 1px;
	background: var(--arch-gold);
}
.arch-icon { display: block; }
.arch-header-tools { gap: .65rem !important; }
.arch-tool-button {
	width: 48px !important;
	height: 48px !important;
	min-width: 48px !important;
	min-height: 48px !important;
	font-size: 0 !important;
	background: rgba(255,255,255,.72) !important;
	border-color: rgba(201,154,63,.34) !important;
}
.arch-tool-button:hover { background: var(--arch-wine) !important; }
.arch-cart-count { font-size: .68rem !important; }

.arch-primary-nav .menu > li > a,
.arch-primary-nav > ul > li > a {
	font-size: .82rem !important;
	font-weight: 900 !important;
	letter-spacing: .045em !important;
}
.arch-primary-nav li { position: relative; }
.arch-primary-nav .sub-menu {
	top: 100% !important;
	margin-top: 0 !important;
	padding: .58rem !important;
	border-radius: 16px !important;
	visibility: hidden;
	transform: translate(-50%, 0) !important;
	transition: opacity 140ms ease, visibility 140ms ease !important;
	box-shadow: 0 24px 70px rgba(42, 15, 19, .16) !important;
}
.arch-primary-nav li:hover > .sub-menu,
.arch-primary-nav li:focus-within > .sub-menu,
.arch-primary-nav li.arch-desktop-submenu-open > .sub-menu,
.arch-primary-nav li.arch-click-submenu-open > .sub-menu {
	opacity: 1 !important;
	visibility: visible;
	pointer-events: auto !important;
}
.arch-primary-nav .sub-menu::before {
	top: -8px !important;
	height: 8px !important;
}
.arch-primary-nav .sub-menu a {
	min-height: 44px !important;
	padding: .72rem .85rem !important;
	font-weight: 850 !important;
}
.arch-main-site-menu-button > a,
.arch-menu-fallback .arch-main-site-menu-button > a {
	min-height: 42px !important;
	padding: .72rem 1rem !important;
	border: 1px solid rgba(201,154,63,.55);
	border-radius: 999px;
	background: linear-gradient(135deg, rgba(242,208,131,.95), rgba(201,154,63,.95));
	color: var(--arch-wine) !important;
	box-shadow: 0 12px 30px rgba(201,154,63,.14);
}
.arch-main-site-menu-button > a:hover { color: var(--arch-wine) !important; transform: translateY(-1px); }

.arch-hero-slider { overflow: hidden; }
.arch-hero-slides { position: relative; min-height: inherit; }
.arch-hero-slide {
	display: none;
	min-height: inherit;
	animation: archFadeIn 420ms ease both;
}
.arch-hero-slide.is-active { display: block; }
@keyframes archFadeIn { from { opacity: .72; } to { opacity: 1; } }
.arch-hero {
	background:
		radial-gradient(circle at 76% 40%, rgba(242, 208, 131, .17), transparent 28%),
		linear-gradient(90deg, rgba(27, 9, 13, .98) 0%, rgba(45, 14, 20, .95) 42%, rgba(102, 31, 42, .92) 100%),
		linear-gradient(135deg, #16090d, #711d2b) !important;
}
.arch-hero h1 {
	font-family: var(--arch-serif) !important;
	font-weight: 700 !important;
	letter-spacing: -.04em !important;
	color: #f6d886 !important;
}
.arch-hero .arch-lead { color: #fff2dc !important; }
.arch-slider-controls {
	position: absolute;
	left: 50%;
	bottom: 36px;
	z-index: 3;
	display: inline-flex;
	align-items: center;
	gap: .75rem;
	padding: .42rem .58rem;
	border: 1px solid rgba(242,208,131,.28);
	border-radius: 999px;
	background: rgba(42,15,19,.48);
	backdrop-filter: blur(12px);
	transform: translateX(-50%);
}
.arch-slider-arrow,
.arch-slider-dots button {
	appearance: none;
	border: 0;
	cursor: pointer;
}
.arch-slider-arrow {
	display: grid;
	place-items: center;
	width: 34px;
	height: 34px;
	border-radius: 999px;
	background: rgba(255,250,240,.12);
	color: var(--arch-gold-light);
	font-size: 1.4rem;
	line-height: 1;
}
.arch-slider-arrow:hover { background: var(--arch-gold); color: var(--arch-wine); }
.arch-slider-dots { display: inline-flex; gap: .45rem; align-items: center; }
.arch-slider-dots button {
	width: 8px;
	height: 8px;
	padding: 0;
	border-radius: 999px;
	background: rgba(255,250,240,.45);
}
.arch-slider-dots button.is-active { width: 26px; background: var(--arch-gold-light); }
.arch-category-card,
.arch-preview-product-card {
	border-radius: 14px !important;
}
.arch-category-image-wrap {
	height: 172px !important;
}
.arch-section-heading h2 {
	font-family: var(--arch-serif) !important;
	font-weight: 700 !important;
	letter-spacing: -.025em;
}

.arch-contact-layout {
	display: grid;
	grid-template-columns: minmax(260px, .78fr) minmax(0, 1.22fr);
	gap: clamp(1rem, 3vw, 2rem);
	align-items: start;
	margin-top: 1rem;
}
.arch-contact-info-card,
.arch-contact-form-card {
	border: 1px solid rgba(201,154,63,.26);
	border-radius: 22px;
	background: rgba(255,250,240,.92);
	box-shadow: var(--arch-shadow-soft);
}
.arch-contact-info-card {
	padding: clamp(1.25rem, 3vw, 2rem);
}
.arch-contact-info-card .arch-mini-title { color: var(--arch-burgundy); }
.arch-contact-info-card h2 {
	font-size: clamp(2rem, 4vw, 3.1rem);
	line-height: .96;
}
.arch-contact-info-card ul {
	display: grid;
	gap: .75rem;
	margin: 1.2rem 0 0;
	padding: 0;
	list-style: none;
}
.arch-contact-info-card a { color: var(--arch-burgundy); font-weight: 800; }
.arch-contact-form-card { padding: clamp(1.2rem, 3vw, 2rem); background: #fff; }
.arch-contact-form {
	max-width: none !important;
}
.arch-contact-form label {
	font-size: .88rem;
	letter-spacing: .01em;
}
.arch-contact-form input,
.arch-contact-form select,
.arch-contact-form textarea {
	border: 1px solid rgba(111,29,44,.18);
	border-radius: 14px;
	background: #fffaf0;
	transition: border-color 140ms ease, box-shadow 140ms ease;
}
.arch-contact-form input:focus,
.arch-contact-form select:focus,
.arch-contact-form textarea:focus {
	outline: none;
	border-color: rgba(201,154,63,.85);
	box-shadow: 0 0 0 4px rgba(201,154,63,.16);
}
.arch-contact-form .arch-check-label {
	display: flex;
	gap: .55rem;
	align-items: center;
	font-weight: 700;
}
.arch-contact-form .arch-check-label input { width: auto; min-height: 0; }
.arch-form-message { margin-bottom: 1rem; }

@media (max-width: 1180px) {
	.arch-header-inner { grid-template-columns: minmax(0,1fr) auto !important; }
	.arch-primary-nav .sub-menu { visibility: visible; }
	.arch-main-site-menu-button > a { width: fit-content; margin-top: .5rem; }
}
@media (max-width: 980px) {
	.arch-contact-layout { grid-template-columns: 1fr; }
	.arch-slider-controls { bottom: 18px; }
	.arch-hero-inner { padding-bottom: 5.2rem !important; }
}
@media (max-width: 640px) {
	.arch-brand-logo {
		width: 52px !important;
		min-width: 52px !important;
		max-width: 52px !important;
		height: 52px !important;
		min-height: 52px !important;
		max-height: 52px !important;
	}
	.arch-brand-copy strong { font-size: 1.02rem !important; }
	.arch-brand-copy small { font-size: .58rem !important; }
	.arch-brand-copy em { display: none !important; }
	.arch-slider-arrow { width: 30px; height: 30px; }
}

/* v3.0.4 luxury minimal polish inspired by the Kadence reference package. */
.arch-category-card,
.arch-preview-product-card,
.arch-emblem-card,
.arch-support-card,
.arch-contact-info-card,
.arch-contact-form-card,
.arch-woocommerce-shell,
.arch-shop-intro-card {
	border-radius: 8px !important;
}
.arch-live-product-grid {
	contain: layout paint;
}
.arch-live-product-card .arch-preview-product-body em,
.arch-live-product-card .arch-preview-product-body em .woocommerce-Price-amount {
	color: var(--arch-burgundy);
	font-weight: 900;
}

/* v3.0.6 fixed-search light luxury hero and faster slider polish. */
.arch-brand-logo,
.arch-brand-logo img,
.custom-logo-link,
.custom-logo-link img {
	object-fit: contain !important;
	overflow: visible !important;
}

.arch-homepage h1,
.arch-homepage h2,
.arch-section-heading h2 {
	letter-spacing: 0 !important;
}

.arch-hero-slider {
	min-height: clamp(620px, 74vh, 720px) !important;
	overflow: hidden !important;
	background: #fff8ec !important;
	color: #2a0710 !important;
}

.arch-hero::before {
	inset: 0 !important;
	z-index: 0;
	background:
		linear-gradient(90deg, #fff8ec 0%, rgba(255, 248, 236, .97) 33%, rgba(255, 248, 236, .66) 55%, rgba(255, 248, 236, .16) 78%, rgba(255, 248, 236, 0) 100%),
		url("../images/category-icons-gifts.webp") right center / min(50rem, 58vw) auto no-repeat !important;
	opacity: 1 !important;
}

.arch-hero::after {
	top: 0 !important;
	bottom: auto !important;
	z-index: 2;
	height: 18px !important;
	background: repeating-linear-gradient(90deg, #c99a3f 0 13px, #6b421f 13px 18px, #39111a 18px 27px) !important;
	opacity: 1 !important;
}

.arch-hero-slides {
	position: relative;
	z-index: 1;
	min-height: inherit !important;
}

.arch-hero-slide {
	min-height: inherit !important;
}

.arch-hero-inner {
	grid-template-columns: minmax(0, 680px) minmax(280px, 1fr) !important;
	gap: 2rem !important;
	align-items: center !important;
	min-height: inherit !important;
	padding: 5.8rem 0 9rem !important;
}

.arch-hero-copy {
	max-width: 690px;
}

.arch-eyebrow {
	gap: 0 !important;
	padding: .42rem .72rem !important;
	border: 1px solid rgba(201, 154, 63, .58);
	border-radius: 999px;
	background: rgba(255, 255, 255, .62);
	color: #761421 !important;
	font-size: .74rem !important;
	letter-spacing: 0 !important;
}

.arch-eyebrow::before {
	display: none !important;
}

.arch-hero h1 {
	max-width: 700px !important;
	color: #2a0710 !important;
	font-family: var(--arch-serif) !important;
	font-size: 5.65rem !important;
	font-weight: 700 !important;
	letter-spacing: 0 !important;
	line-height: .95 !important;
}

.arch-hero .arch-lead {
	max-width: 620px !important;
	color: #38212b !important;
	font-size: 1.16rem !important;
	line-height: 1.55 !important;
}

.arch-hero-actions {
	margin-top: 1.8rem !important;
}

.arch-hero .arch-button {
	min-height: 46px !important;
	border-radius: 8px !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
}

.arch-hero .arch-button-gold {
	border-color: rgba(201, 154, 63, .8) !important;
	background: #d9a73e !important;
	color: #240710 !important;
	box-shadow: none !important;
}

.arch-hero .arch-button-outline {
	border-color: rgba(113, 22, 33, .18) !important;
	background: rgba(255, 255, 255, .82) !important;
	color: #761421 !important;
	box-shadow: none !important;
}

.arch-hero-emblem {
	justify-items: end !important;
	align-self: end !important;
	padding-bottom: 2rem;
}

.arch-hero-emblem > img {
	display: none !important;
}

.arch-emblem-card {
	width: min(100%, 360px) !important;
	padding: 1.25rem 1.35rem !important;
	border: 1px solid rgba(201, 154, 63, .44) !important;
	border-radius: 8px !important;
	background: #3c121b !important;
	box-shadow: 0 18px 44px rgba(52, 18, 24, .18) !important;
}

.arch-emblem-card h2 {
	margin-bottom: .75rem !important;
	color: #fff8ec !important;
	font-size: 1.45rem !important;
	letter-spacing: 0 !important;
	line-height: 1.02 !important;
}

.arch-emblem-card li {
	color: #fff8ec !important;
	font-size: .94rem !important;
	font-weight: 600 !important;
	letter-spacing: 0 !important;
}

.arch-emblem-card li::before {
	content: "" !important;
	top: .46em !important;
	width: 8px;
	height: 8px;
	border-radius: 999px;
	background: #d9a73e;
}

.arch-hero-fixed-search {
	position: absolute;
	left: 50%;
	bottom: 58px;
	z-index: 4;
	width: var(--arch-content);
	transform: translateX(-50%);
}

.arch-hero-fixed-search .woocommerce-product-search,
.arch-hero-fixed-search .search-form {
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) 120px;
	gap: .5rem;
	max-width: 660px !important;
	margin: 0 !important;
	padding: .42rem;
	border: 1px solid rgba(113, 22, 33, .14);
	border-radius: 8px;
	background: rgba(255, 255, 255, .96);
	box-shadow: 0 16px 42px rgba(58, 29, 22, .12);
}

.arch-hero-fixed-search label {
	display: block;
	margin: 0 !important;
}

.arch-hero-fixed-search input[type="search"],
.arch-hero-fixed-search .search-field {
	width: 100% !important;
	min-height: 50px !important;
	padding: 0 .85rem !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	color: #38212b !important;
	font-size: .98rem !important;
}

.arch-hero-fixed-search button,
.arch-hero-fixed-search input[type="submit"] {
	min-height: 50px !important;
	padding: 0 1.1rem !important;
	border-radius: 7px !important;
	background: #761421 !important;
	color: #fff8ec !important;
	font-size: .96rem !important;
	font-weight: 900 !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
}

.arch-slider-controls {
	right: max(20px, calc((100vw - 1200px) / 2)) !important;
	bottom: 22px !important;
	left: auto !important;
	z-index: 5 !important;
	border-color: rgba(113, 22, 33, .14) !important;
	background: rgba(255, 255, 255, .82) !important;
	box-shadow: 0 12px 32px rgba(58, 29, 22, .10);
	transform: none !important;
}

.arch-slider-arrow {
	background: #761421 !important;
	color: #fff8ec !important;
}

.arch-slider-arrow:hover {
	background: #d9a73e !important;
	color: #240710 !important;
}

.arch-slider-dots button {
	background: rgba(118, 20, 33, .28) !important;
}

.arch-slider-dots button.is-active {
	background: #761421 !important;
}

.arch-categories-section {
	background: #f4eadb !important;
}

.arch-categories-section .arch-section-heading {
	margin-bottom: 1.9rem !important;
}

.arch-categories-section .arch-mini-title {
	justify-content: center !important;
	padding: .46rem .78rem !important;
	border: 1px solid rgba(201, 154, 63, .56);
	border-radius: 999px;
	color: #761421 !important;
	font-size: .72rem !important;
	letter-spacing: 0 !important;
}

.arch-categories-section .arch-mini-title::before,
.arch-categories-section .arch-mini-title::after {
	display: none !important;
}

.arch-categories-section .arch-section-heading h2 {
	color: #2a0710 !important;
	font-size: 3.35rem !important;
	letter-spacing: 0 !important;
	line-height: 1.05 !important;
}

.arch-categories-section .arch-category-grid {
	gap: 1rem !important;
	max-width: 1180px;
}

.arch-categories-section .arch-category-card {
	display: flex !important;
	min-height: 190px !important;
	padding: 1.35rem 1.4rem !important;
	border: 1px solid rgba(201, 154, 63, .26) !important;
	border-radius: 8px !important;
	background: #fff !important;
	box-shadow: 0 18px 38px rgba(58, 29, 22, .06) !important;
	transform: none !important;
}

.arch-categories-section .arch-category-card:hover {
	border-color: rgba(201, 154, 63, .46) !important;
	box-shadow: 0 22px 46px rgba(58, 29, 22, .10) !important;
}

.arch-categories-section .arch-category-card::before,
.arch-categories-section .arch-category-image-wrap {
	display: none !important;
}

.arch-categories-section .arch-category-body {
	display: grid !important;
	grid-template-rows: auto 1fr auto;
	gap: 1rem !important;
	min-height: 100% !important;
	padding: 0 !important;
}

.arch-categories-section .arch-category-card strong {
	margin: 0 !important;
	color: #2a0710 !important;
	font-size: 1.35rem !important;
	letter-spacing: 0 !important;
	line-height: 1.12 !important;
}

.arch-categories-section .arch-category-card span:not(.arch-category-art) {
	color: #4e3b43 !important;
	font-size: .96rem;
	line-height: 1.45;
}

.arch-categories-section .arch-category-card em {
	align-self: end !important;
	color: #761421 !important;
	font-size: .92rem !important;
	font-weight: 900 !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
}

@media (max-width: 1180px) {
	.arch-hero h1 {
		font-size: 4.55rem !important;
	}

	.arch-hero::before {
		background:
			linear-gradient(90deg, #fff8ec 0%, rgba(255, 248, 236, .96) 42%, rgba(255, 248, 236, .58) 70%, rgba(255, 248, 236, .22) 100%),
			url("../images/category-icons-gifts.webp") right center / 34rem auto no-repeat !important;
	}
}

@media (max-width: 900px) {
	.arch-hero-slider {
		min-height: auto !important;
	}

	.arch-hero::before {
		background:
			linear-gradient(180deg, rgba(255, 248, 236, .98) 0%, rgba(255, 248, 236, .91) 56%, rgba(255, 248, 236, .82) 100%),
			url("../images/category-icons-gifts.webp") center top / 100% auto no-repeat !important;
		opacity: .96 !important;
	}

	.arch-hero-inner {
		grid-template-columns: 1fr !important;
		padding: 12rem 0 6.4rem !important;
	}

	.arch-hero h1 {
		font-size: 3.45rem !important;
	}

	.arch-hero .arch-lead {
		font-size: 1.04rem !important;
	}

	.arch-hero-emblem {
		justify-items: start !important;
		padding-bottom: 0;
	}

	.arch-emblem-card {
		width: min(100%, 420px) !important;
	}

	.arch-hero-fixed-search {
		position: relative;
		left: auto;
		bottom: auto;
		width: var(--arch-content);
		margin: -4.8rem auto 4.7rem;
		transform: none;
	}

	.arch-slider-controls {
		right: 50% !important;
		bottom: 18px !important;
		transform: translateX(50%) !important;
	}

	.arch-categories-section .arch-category-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}
}

@media (max-width: 640px) {
	.arch-hero::before {
		background:
			linear-gradient(180deg, rgba(255, 248, 236, .96) 0%, rgba(255, 248, 236, .93) 48%, rgba(255, 248, 236, .88) 100%),
			url("../images/category-icons-gifts.webp") center top / 48rem auto no-repeat !important;
	}

	.arch-hero-inner {
		padding: 9.4rem 0 6.8rem !important;
	}

	.arch-hero h1 {
		font-size: 2.78rem !important;
		line-height: 1 !important;
	}

	.arch-hero-actions {
		display: grid !important;
		grid-template-columns: 1fr;
	}

	.arch-hero .arch-button {
		width: 100%;
	}

	.arch-hero-fixed-search .woocommerce-product-search,
	.arch-hero-fixed-search .search-form {
		grid-template-columns: 1fr;
		max-width: 100% !important;
	}

	.arch-categories-section .arch-section-heading h2 {
		font-size: 2.5rem !important;
	}

	.arch-categories-section .arch-category-grid {
		grid-template-columns: 1fr !important;
	}
}

/* v3.0.8 newsletter popup. */
body.arch-newsletter-open {
	overflow: hidden;
}

.arch-newsletter-pop-trigger {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 9990;
	min-height: 46px;
	padding: 0 1.05rem;
	border: 1px solid rgba(242, 208, 131, .72);
	border-radius: 999px;
	background: #761421;
	box-shadow: 0 16px 42px rgba(42, 15, 19, .18);
	color: #fff8ec;
	font-weight: 900;
	letter-spacing: 0;
	cursor: pointer;
}

.arch-newsletter-pop-trigger:hover {
	background: #d9a73e;
	color: #240710;
}

.arch-newsletter-popup[hidden] {
	display: none !important;
}

.arch-newsletter-popup {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: grid;
	place-items: center;
	padding: 20px;
}

.arch-newsletter-popup-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(26, 7, 12, .62);
	backdrop-filter: blur(8px);
}

.arch-newsletter-dialog {
	position: relative;
	z-index: 1;
	width: min(100%, 520px);
	padding: clamp(1.35rem, 4vw, 2.15rem);
	border: 1px solid rgba(201, 154, 63, .34);
	border-radius: 8px;
	background:
		linear-gradient(180deg, rgba(255, 248, 236, .98), rgba(255, 250, 244, .98)),
		#fff8ec;
	box-shadow: 0 30px 90px rgba(42, 15, 19, .34);
	color: #2a0710;
}

.arch-newsletter-dialog .arch-mini-title {
	margin-bottom: .7rem;
	padding: .38rem .68rem;
	border: 1px solid rgba(201, 154, 63, .58);
	border-radius: 999px;
	color: #761421;
	letter-spacing: 0;
}

.arch-newsletter-dialog .arch-mini-title::before,
.arch-newsletter-dialog .arch-mini-title::after {
	display: none;
}

.arch-newsletter-dialog h2 {
	margin: 0 2.2rem .6rem 0;
	color: #2a0710;
	font-size: clamp(2rem, 7vw, 3.15rem);
	letter-spacing: 0;
	line-height: 1;
}

.arch-newsletter-dialog p {
	color: #4e3b43;
}

.arch-newsletter-close {
	position: absolute;
	top: 14px;
	right: 14px;
	display: grid;
	place-items: center;
	width: 38px;
	height: 38px;
	border: 1px solid rgba(113, 22, 33, .18);
	border-radius: 999px;
	background: #fff;
	color: #761421;
	font-size: 1.45rem;
	line-height: 1;
	cursor: pointer;
}

.arch-newsletter-dialog .arch-newsletter-form {
	margin-top: 1.15rem;
}

.arch-newsletter-dialog .arch-newsletter-form form {
	grid-template-columns: 1fr;
	gap: .65rem;
}

.arch-newsletter-dialog .arch-newsletter-form input[type="email"],
.arch-newsletter-dialog .arch-newsletter-form button {
	border-radius: 8px;
}

.arch-newsletter-dialog .arch-newsletter-form button {
	background: #761421;
	color: #fff8ec;
	letter-spacing: 0;
	text-transform: none;
}

.arch-newsletter-dialog .arch-newsletter-form small {
	color: #6f5a61;
}

@media (max-width: 640px) {
	.arch-newsletter-pop-trigger {
		right: 14px;
		bottom: 14px;
	}

	.arch-newsletter-dialog {
		max-height: calc(100vh - 40px);
		overflow: auto;
	}
}

/* v3.0.8 compact logo header, generated hero image, and moving arrivals rail. */
.arch-announcement {
	display: none !important;
}

.arch-site-header.arch-site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	border-bottom: 1px solid rgba(201, 154, 63, .22) !important;
	background: rgba(255, 250, 240, .98) !important;
	box-shadow: 0 8px 22px rgba(58, 29, 22, .04) !important;
}

body.admin-bar .arch-site-header.arch-site-header {
	top: 32px;
}

.arch-site-header.arch-site-header .arch-header-inner {
	grid-template-columns: minmax(240px, auto) minmax(0, 1fr) auto auto !important;
	gap: clamp(.8rem, 2vw, 1.5rem) !important;
	width: min(1080px, calc(100vw - 32px)) !important;
	min-height: 58px !important;
	padding: 0 !important;
}

.arch-site-header.arch-site-header .arch-brand {
	gap: .62rem !important;
	max-width: 420px !important;
}

.arch-site-header.arch-site-header .arch-brand img.arch-brand-logo {
	width: 42px !important;
	min-width: 42px !important;
	max-width: 42px !important;
	height: 42px !important;
	min-height: 42px !important;
	max-height: 42px !important;
	flex-basis: 42px !important;
	padding: 2px !important;
	border: 1px solid rgba(201, 154, 63, .42);
	border-radius: 999px;
	background: #3c121b;
	object-fit: contain !important;
}

.arch-site-header.arch-site-header .arch-brand-copy strong {
	color: #2a0710 !important;
	font-size: 1.08rem !important;
	font-weight: 900 !important;
	letter-spacing: 0 !important;
	line-height: 1.05 !important;
	text-transform: none !important;
}

.arch-site-header.arch-site-header .arch-brand-copy small {
	margin-top: .12rem !important;
	color: #4e3b43 !important;
	font-size: .72rem !important;
	font-weight: 700 !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
}

.arch-site-header.arch-site-header .arch-brand-copy em {
	display: none !important;
}

.arch-site-header.arch-site-header .arch-primary-nav {
	justify-self: end !important;
}

.arch-site-header.arch-site-header .arch-primary-nav > ul,
.arch-site-header.arch-site-header .arch-primary-nav .menu {
	gap: 1.1rem !important;
}

.arch-site-header.arch-site-header .arch-primary-nav a {
	min-height: 38px !important;
	padding: .5rem 0 !important;
	color: #1f1215 !important;
	font-size: .84rem !important;
	font-weight: 900 !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
}

.arch-site-header.arch-site-header .arch-primary-nav .arch-main-site-menu-button {
	display: none !important;
}

.arch-header-main-church {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 36px;
	padding: .55rem .8rem;
	border: 1px solid rgba(201, 154, 63, .42);
	border-radius: 999px;
	background: #fff;
	color: #761421;
	font-size: .8rem;
	font-weight: 900;
	letter-spacing: 0;
	line-height: 1;
	text-decoration: none;
	white-space: nowrap;
}

.arch-header-main-church:hover {
	background: #d9a73e;
	color: #240710;
}

.arch-site-header.arch-site-header .arch-header-tools {
	gap: .38rem !important;
}

.arch-site-header.arch-site-header .arch-tool-button {
	width: 38px !important;
	min-width: 38px !important;
	height: 38px !important;
	min-height: 38px !important;
	background: #fff !important;
}

.arch-hero-slider.arch-hero-slider::before {
	background:
		linear-gradient(90deg, #fff8ec 0%, rgba(255, 248, 236, .98) 27%, rgba(255, 248, 236, .72) 47%, rgba(255, 248, 236, .18) 68%, rgba(255, 248, 236, 0) 100%),
		url("../images/approved-luxury-preview.jpg") center -163px / 1200px auto no-repeat !important;
}

.arch-hero-slider.arch-hero-slider {
	min-height: clamp(650px, 78vh, 760px) !important;
}

.arch-hero-slider.arch-hero-slider .arch-hero-inner {
	grid-template-columns: minmax(0, 620px) minmax(320px, 1fr) !important;
	width: min(1080px, calc(100vw - 32px)) !important;
	padding: 5.4rem 0 8.3rem !important;
}

.arch-hero-slider.arch-hero-slider .arch-hero-copy {
	max-width: 620px;
}

.arch-hero-slider.arch-hero-slider h1 {
	font-size: clamp(3.5rem, 5.8vw, 5.8rem) !important;
	line-height: .96 !important;
}

.arch-hero-slider.arch-hero-slider .arch-hero-fixed-search {
	width: min(1080px, calc(100vw - 32px)) !important;
	bottom: 62px !important;
}

.arch-new-arrivals-section {
	overflow: hidden;
}

.arch-new-arrivals-section .arch-section-heading {
	max-width: 820px;
}

.arch-new-arrivals-section .arch-section-heading h2 {
	color: #2a0710 !important;
	font-size: clamp(3rem, 6vw, 5rem) !important;
	letter-spacing: 0 !important;
	line-height: .95 !important;
}

.arch-new-arrivals-section .arch-preview-note {
	display: none;
}

.arch-product-carousel {
	display: flex !important;
	grid-template-columns: none !important;
	gap: 1rem !important;
	width: max-content !important;
	max-width: none !important;
	padding: .4rem 0 1rem;
	margin-left: max(20px, calc((100vw - 1200px) / 2)) !important;
	animation: archProductRail 28s linear infinite;
	will-change: transform;
}

.arch-product-carousel .arch-preview-product-card {
	flex: 0 0 clamp(240px, 22vw, 305px);
	width: clamp(240px, 22vw, 305px);
}

.arch-product-carousel .arch-preview-product-card img {
	aspect-ratio: 1.22 / .92;
	object-fit: cover;
}

@keyframes archProductRail {
	from { transform: translateX(0); }
	to { transform: translateX(-50%); }
}

@media (max-width: 1180px) {
	.arch-site-header.arch-site-header .arch-header-inner {
		grid-template-columns: minmax(0, 1fr) auto auto !important;
	}

	.arch-header-main-church {
		grid-column: 1 / -1;
		justify-self: center;
		margin-bottom: .55rem;
	}

	.arch-hero-slider.arch-hero-slider .arch-hero-inner {
		width: min(100% - 32px, 1080px) !important;
	}
}

@media (max-width: 900px) {
	.arch-site-header.arch-site-header .arch-header-inner {
		min-height: 64px !important;
	}

	.arch-hero-slider.arch-hero-slider::before {
		background:
			linear-gradient(180deg, rgba(255, 248, 236, .97) 0%, rgba(255, 248, 236, .9) 58%, rgba(255, 248, 236, .86) 100%),
			url("../images/approved-luxury-preview.jpg") center -163px / 1200px auto no-repeat !important;
	}

	.arch-hero-slider.arch-hero-slider .arch-hero-inner {
		padding-top: 14rem !important;
	}

	.arch-product-carousel .arch-preview-product-card {
		flex-basis: 260px;
		width: 260px;
	}
}

@media (max-width: 640px) {
	body.admin-bar .arch-site-header.arch-site-header {
		top: 46px;
	}

	.arch-site-header.arch-site-header .arch-brand img.arch-brand-logo {
		width: 40px !important;
		min-width: 40px !important;
		max-width: 40px !important;
		height: 40px !important;
		min-height: 40px !important;
		max-height: 40px !important;
		flex-basis: 40px !important;
	}

	.arch-site-header.arch-site-header .arch-brand-copy strong {
		font-size: .98rem !important;
	}

	.arch-site-header.arch-site-header .arch-brand-copy small {
		display: block !important;
		font-size: .62rem !important;
	}

	.arch-header-main-church {
		width: 100%;
	}

	.arch-hero-slider.arch-hero-slider .arch-hero-inner {
		padding-top: 12.5rem !important;
	}
}

/* Legacy approved dark luxury preview replication. */
.arch-announcement.arch-announcement {
	display: grid !important;
	grid-template-columns: 1fr auto;
	align-items: center;
	min-height: 31px;
	padding: .38rem 2.4rem .38rem 1rem;
	background: linear-gradient(90deg, #5b1018, #711923, #4a0e14) !important;
	color: #fff4df !important;
	font-size: .86rem;
	font-weight: 700;
}

.arch-announcement .arch-cross {
	color: #d9a73e;
	font-size: 0;
}

.arch-announcement .arch-cross::before {
	content: "+";
	font-size: .95rem;
}

.arch-announcement-close {
	position: absolute;
	right: 1rem;
	top: 50%;
	width: 28px;
	height: 28px;
	border: 0;
	background: transparent;
	color: #fff4df;
	font-size: 1.15rem;
	line-height: 1;
	transform: translateY(-50%);
	cursor: pointer;
}

.arch-site-header.arch-site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	border-bottom: 1px solid rgba(201, 154, 63, .2) !important;
	background: #fffaf0 !important;
	box-shadow: none !important;
	backdrop-filter: none !important;
}

body.admin-bar .arch-site-header.arch-site-header {
	top: 32px;
}

.arch-site-header.arch-site-header .arch-header-inner {
	grid-template-columns: minmax(270px, 345px) minmax(0, 1fr) auto !important;
	width: min(1070px, calc(100vw - 48px)) !important;
	min-height: 130px !important;
	gap: 2rem !important;
}

.arch-site-header.arch-site-header .arch-brand {
	max-width: 345px !important;
	gap: 0 !important;
}

.arch-site-header.arch-site-header .arch-brand img.arch-brand-logo {
	width: min(100%, 330px) !important;
	min-width: 0 !important;
	max-width: 330px !important;
	height: auto !important;
	min-height: 0 !important;
	max-height: 104px !important;
	flex: 0 1 330px !important;
	padding: 0 !important;
	border: 0 !important;
	border-radius: 0 !important;
	background: transparent !important;
	filter: none !important;
	object-fit: contain !important;
}

.arch-site-header.arch-site-header .arch-brand-copy {
	display: none !important;
}

.arch-site-header.arch-site-header .arch-primary-nav {
	justify-self: center !important;
}

.arch-site-header.arch-site-header .arch-primary-nav > ul,
.arch-site-header.arch-site-header .arch-primary-nav .menu {
	gap: clamp(1.45rem, 3vw, 2.55rem) !important;
}

.arch-site-header.arch-site-header .arch-primary-nav a {
	min-height: 44px !important;
	padding: .55rem 0 !important;
	color: #2a1718 !important;
	font-size: .83rem !important;
	font-weight: 900 !important;
	letter-spacing: .02em !important;
	text-transform: uppercase !important;
}

.arch-site-header.arch-site-header .arch-primary-nav .current-menu-item > a,
.arch-site-header.arch-site-header .arch-primary-nav a:hover {
	color: #8b5f21 !important;
}

.arch-site-header.arch-site-header .arch-primary-nav .current-menu-item > a::before,
.arch-site-header.arch-site-header .arch-primary-nav > ul > li:first-child > a::before,
.arch-site-header.arch-site-header .arch-primary-nav .menu > li:first-child > a::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: .25rem;
	width: 34px;
	height: 2px;
	background: #c99a3f;
	transform: translateX(-50%);
}

.arch-site-header.arch-site-header .arch-primary-nav .menu-item-has-children > a::after {
	content: "";
	width: 6px;
	height: 6px;
	margin-left: .5rem;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(45deg) translateY(-2px);
}

.arch-header-main-church {
	display: none !important;
}

.arch-site-header.arch-site-header .arch-header-tools {
	position: relative;
	gap: .85rem !important;
	padding-left: 2rem;
	border-left: 1px solid rgba(201, 154, 63, .28);
}

.arch-site-header.arch-site-header .arch-tool-button {
	width: 34px !important;
	min-width: 34px !important;
	height: 34px !important;
	min-height: 34px !important;
	border: 0 !important;
	background: transparent !important;
	color: #2a1718 !important;
}

.arch-site-header.arch-site-header .arch-tool-button:hover {
	color: #8b5f21 !important;
	transform: none !important;
}

.arch-hero-slider.arch-hero-slider {
	min-height: 447px !important;
	background: #1b0809 !important;
	color: #fff4df !important;
}

.arch-hero-slider.arch-hero-slider::before {
	inset: 0 !important;
	background:
		radial-gradient(circle at 12% 82%, rgba(216, 149, 53, .22) 0 5%, transparent 16%),
		linear-gradient(90deg, rgba(18, 6, 7, .22) 0%, rgba(27, 8, 9, .68) 42%, rgba(24, 7, 9, .9) 100%),
		url("../images/approved-luxury-preview.jpg") center -163px / 1200px auto no-repeat,
		linear-gradient(135deg, #1b0809, #3e1118) !important;
	opacity: 1 !important;
}

.arch-hero-slider.arch-hero-slider::after {
	top: auto !important;
	bottom: 0 !important;
	z-index: 3;
	height: 18px !important;
	background:
		repeating-linear-gradient(90deg, rgba(201,154,63,.8) 0 2px, transparent 2px 8px),
		linear-gradient(90deg, #2a0f13, #7a4d28, #2a0f13) !important;
	opacity: 1 !important;
}

.arch-hero-slider.arch-hero-slider .arch-hero-inner {
	grid-template-columns: minmax(0, 470px) minmax(360px, 1fr) !important;
	width: min(1070px, calc(100vw - 48px)) !important;
	min-height: 447px !important;
	padding: 3.5rem 0 4rem !important;
}

.arch-hero-slider.arch-hero-slider .arch-hero-copy {
	max-width: 470px;
}

.arch-hero-slider.arch-hero-slider .arch-eyebrow {
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	color: #d9a73e !important;
	font-size: .86rem !important;
	font-weight: 900 !important;
	letter-spacing: .13em !important;
	text-transform: uppercase !important;
}

.arch-hero-slider.arch-hero-slider h1 {
	max-width: 450px !important;
	color: #f1cf76 !important;
	font-size: clamp(3rem, 5.2vw, 4.75rem) !important;
	font-weight: 700 !important;
	letter-spacing: 0 !important;
	line-height: .98 !important;
	text-shadow: 0 2px 18px rgba(0,0,0,.22);
}

.arch-hero-slider.arch-hero-slider .arch-lead {
	max-width: 450px !important;
	margin-top: 1rem !important;
	color: rgba(255,244,223,.92) !important;
	font-size: 1.06rem !important;
	line-height: 1.48 !important;
}

.arch-hero-slider.arch-hero-slider .arch-hero-actions {
	margin-top: 1.7rem !important;
}

.arch-hero-slider.arch-hero-slider .arch-button {
	min-height: 42px !important;
	padding: .72rem 1.35rem !important;
	border-radius: 2px !important;
	font-size: .82rem !important;
	font-weight: 900 !important;
	letter-spacing: .04em !important;
	text-transform: uppercase !important;
}

.arch-hero-slider.arch-hero-slider .arch-button-gold {
	border-color: #d9a73e !important;
	background: linear-gradient(180deg, #efd084, #c99a3f) !important;
	color: #2a0f13 !important;
}

.arch-hero-slider.arch-hero-slider .arch-button-outline {
	border-color: rgba(239,208,132,.6) !important;
	background: rgba(42,15,19,.32) !important;
	color: #fff4df !important;
}

.arch-hero-slider.arch-hero-slider .arch-hero-emblem {
	display: grid !important;
	justify-items: center !important;
	align-self: center !important;
	padding: 0 !important;
}

.arch-hero-slider.arch-hero-slider .arch-hero-emblem > img {
	display: block !important;
	width: min(92%, 405px) !important;
	max-width: 405px !important;
	max-height: 384px !important;
	object-fit: contain !important;
	filter: drop-shadow(0 18px 40px rgba(0,0,0,.35));
}

.arch-hero-slider.arch-hero-slider .arch-emblem-card,
.arch-hero-fixed-search,
.arch-slider-controls {
	display: none !important;
}

.arch-categories-section.arch-categories-section {
	padding-top: 1.35rem !important;
	padding-bottom: 2.3rem !important;
	background: #fffaf0 !important;
}

.arch-categories-section .arch-section-heading {
	margin-bottom: 1.15rem !important;
}

.arch-categories-section .arch-mini-title {
	display: none !important;
}

.arch-categories-section .arch-section-heading h2 {
	position: relative;
	margin: 0 !important;
	color: #2a0f13 !important;
	font-family: Georgia, "Times New Roman", serif !important;
	font-size: 1.42rem !important;
	font-weight: 700 !important;
	letter-spacing: .16em !important;
	line-height: 1.2 !important;
	text-transform: uppercase !important;
}

.arch-categories-section .arch-section-heading h2::after {
	content: "";
	display: block;
	width: 92px;
	height: 16px;
	margin: .45rem auto 0;
	background:
		linear-gradient(#c99a3f, #c99a3f) left 50% / 38px 1px no-repeat,
		linear-gradient(#c99a3f, #c99a3f) right 50% / 38px 1px no-repeat,
		radial-gradient(circle, #c99a3f 0 3px, transparent 4px);
}

.arch-categories-section .arch-category-grid {
	grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
	gap: .9rem !important;
	width: min(1040px, calc(100vw - 48px)) !important;
	max-width: 1040px !important;
}

.arch-categories-section .arch-category-card {
	display: block !important;
	min-height: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
	border: 1px solid rgba(201,154,63,.28) !important;
	border-radius: 8px !important;
	background: #fffaf0 !important;
	box-shadow: 0 14px 32px rgba(42,15,19,.14) !important;
}

.arch-categories-section .arch-category-card::before {
	display: none !important;
}

.arch-categories-section .arch-category-image-wrap {
	display: block !important;
	height: 144px !important;
	overflow: hidden !important;
	background: #2a0f13 !important;
}

.arch-categories-section .arch-category-image-wrap img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.arch-categories-section .arch-category-body {
	display: grid !important;
	justify-items: center !important;
	gap: .55rem !important;
	min-height: 82px !important;
	padding: .8rem .5rem .85rem !important;
	text-align: center;
}

.arch-categories-section .arch-category-card strong {
	margin: 0 !important;
	color: #541521 !important;
	font-size: 1.03rem !important;
	line-height: 1.12 !important;
}

.arch-categories-section .arch-category-card span:not(.arch-category-art):not(.arch-category-body) {
	display: none !important;
}

.arch-categories-section .arch-category-image-wrap {
	display: block !important;
}

.arch-categories-section .arch-category-body > span {
	display: none !important;
}

.arch-categories-section .arch-category-card em {
	color: #7b2330 !important;
	font-size: .74rem !important;
	font-weight: 700 !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
}

@media (max-width: 1180px) {
	.arch-site-header.arch-site-header .arch-header-inner {
		grid-template-columns: minmax(0, 1fr) auto !important;
		min-height: auto !important;
		padding: .7rem 0 !important;
	}

	.arch-site-header.arch-site-header .arch-brand img.arch-brand-logo {
		width: 260px !important;
		max-width: min(60vw, 260px) !important;
	}

	.arch-site-header.arch-site-header .arch-header-tools {
		grid-column: 1 / -1;
		justify-content: center !important;
		padding: .25rem 0 .6rem;
		border-left: 0;
	}

	.arch-hero-slider.arch-hero-slider .arch-hero-inner {
		grid-template-columns: 1fr !important;
		text-align: left;
	}

	.arch-hero-slider.arch-hero-slider .arch-hero-emblem {
		display: none !important;
	}

	.arch-categories-section .arch-category-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	}
}

@media (max-width: 640px) {
	body.admin-bar .arch-site-header.arch-site-header {
		top: 46px;
	}

	.arch-site-header.arch-site-header .arch-brand img.arch-brand-logo {
		width: 210px !important;
		max-width: min(68vw, 210px) !important;
	}

	.arch-hero-slider.arch-hero-slider {
		min-height: 520px !important;
	}

	.arch-hero-slider.arch-hero-slider::before {
		background:
			linear-gradient(90deg, rgba(18, 6, 7, .2), rgba(27, 8, 9, .78)),
			linear-gradient(135deg, #1b0809, #3e1118) !important;
	}

	.arch-hero-slider.arch-hero-slider .arch-hero-inner {
		min-height: 520px !important;
		width: min(100% - 32px, 1070px) !important;
		padding: 3.3rem 0 3.6rem !important;
	}

	.arch-hero-slider.arch-hero-slider h1 {
		font-size: 3.05rem !important;
	}

	.arch-categories-section .arch-category-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		width: min(100% - 32px, 1040px) !important;
	}
}

/* v3.1.0 full approved luxury ecommerce homepage. */
body {
	background: #fffaf0 !important;
}

.arch-homepage {
	background: #fffaf0 !important;
}

.arch-announcement.arch-announcement {
	min-height: 31px !important;
	padding: 0 2.25rem !important;
	background: #5b1014 !important;
	color: #fff2dc !important;
	font-size: .78rem !important;
	font-weight: 700 !important;
	letter-spacing: .01em !important;
}

.arch-announcement .arch-cross {
	color: #d3a449 !important;
	font-size: 0 !important;
}

.arch-announcement .arch-cross::before {
	content: "+";
	font-size: .96rem;
}

.arch-site-header.arch-site-header {
	background: #fffaf0 !important;
	border-bottom: 1px solid rgba(73, 33, 22, .18) !important;
}

.arch-site-header.arch-site-header .arch-header-inner {
	width: min(1080px, calc(100vw - 48px)) !important;
	min-height: 132px !important;
	grid-template-columns: 350px minmax(0, 1fr) auto !important;
	gap: 2.25rem !important;
}

.arch-site-header.arch-site-header .arch-brand img.arch-brand-logo {
	width: 335px !important;
	max-width: 335px !important;
	max-height: 104px !important;
}

.arch-site-header.arch-site-header .arch-primary-nav > ul,
.arch-site-header.arch-site-header .arch-primary-nav .menu {
	gap: clamp(1.5rem, 3.05vw, 2.6rem) !important;
}

.arch-site-header.arch-site-header .arch-primary-nav a {
	font-size: .78rem !important;
}

.arch-site-header.arch-site-header .arch-header-tools {
	gap: .82rem !important;
}

.arch-hero-slider.arch-hero-slider {
	min-height: 447px !important;
	perspective: 1200px;
}

.arch-hero-slider.arch-hero-slider::before {
	background:
		linear-gradient(90deg, rgba(27, 8, 9, .05), rgba(27, 8, 9, .12)),
		url("../images/approved-luxury-homepage-concept.webp") center -163px / 1200px auto no-repeat,
		linear-gradient(135deg, #1b0809, #3d1118) !important;
}

.arch-hero-slider.arch-hero-slider .arch-hero-inner {
	grid-template-columns: 470px 1fr !important;
	width: min(1080px, calc(100vw - 48px)) !important;
	min-height: 447px !important;
	padding: 3.7rem 0 4.05rem !important;
}

.arch-hero-slider.arch-hero-slider .arch-hero-copy {
	transform: translateZ(28px);
}

.arch-hero-slider.arch-hero-slider .arch-hero-emblem > img {
	width: min(94%, 408px) !important;
	max-height: 390px !important;
	transform: translateZ(44px);
}

.arch-hero-slider.arch-hero-slider .arch-slider-controls {
	display: none !important;
}

.arch-categories-section.arch-categories-section {
	padding-top: 1.1rem !important;
	padding-bottom: 1.35rem !important;
}

.arch-categories-section .arch-category-card {
	transform-style: preserve-3d;
	transition: transform .24s ease, box-shadow .24s ease;
}

.arch-categories-section .arch-category-card:hover {
	box-shadow: 0 20px 44px rgba(42, 15, 19, .2) !important;
	transform: translateY(-5px) rotateX(2deg) !important;
}

.arch-featured-products-section.arch-products-section {
	padding: .4rem 0 2.1rem !important;
	background: #fffaf0 !important;
	overflow: hidden;
}

.arch-featured-products-section .arch-section-heading {
	margin-bottom: 1.05rem !important;
}

.arch-featured-products-section .arch-mini-title {
	display: none !important;
}

.arch-featured-products-section .arch-section-heading h2,
.arch-categories-section .arch-section-heading h2 {
	position: relative;
	color: #2a0f13 !important;
	font-family: Georgia, "Times New Roman", serif !important;
	font-size: 1.36rem !important;
	font-weight: 700 !important;
	letter-spacing: .18em !important;
	text-transform: uppercase !important;
}

.arch-featured-products-section .arch-section-heading h2::after,
.arch-categories-section .arch-section-heading h2::after {
	content: "";
	display: block;
	width: 92px;
	height: 16px;
	margin: .42rem auto 0;
	background:
		linear-gradient(#c99a3f, #c99a3f) left 50% / 38px 1px no-repeat,
		linear-gradient(#c99a3f, #c99a3f) right 50% / 38px 1px no-repeat,
		radial-gradient(circle, #c99a3f 0 3px, transparent 4px);
}

.arch-featured-carousel-frame {
	position: relative;
	width: min(1080px, calc(100vw - 76px));
	margin: 0 auto;
	overflow: hidden;
}

.arch-featured-carousel-frame::before,
.arch-featured-carousel-frame::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	z-index: 4;
	width: 34px;
	pointer-events: none;
}

.arch-featured-carousel-frame::before {
	left: 0;
	background: linear-gradient(90deg, #fffaf0, rgba(255,250,240,0));
}

.arch-featured-carousel-frame::after {
	right: 0;
	background: linear-gradient(270deg, #fffaf0, rgba(255,250,240,0));
}

.arch-featured-carousel-frame .arch-product-carousel {
	display: flex !important;
	grid-template-columns: none !important;
	width: max-content !important;
	max-width: none !important;
	gap: .85rem !important;
	margin: 0 !important;
	animation: arch-product-glide 36s linear infinite !important;
}

.arch-featured-carousel-frame .arch-product-carousel:hover {
	animation-play-state: paused !important;
}

.arch-featured-carousel-frame .arch-preview-product-card {
	width: 166px !important;
	min-width: 166px !important;
	max-width: 166px !important;
	min-height: 204px !important;
	border: 1px solid rgba(201,154,63,.22) !important;
	border-radius: 7px !important;
	background: #fffaf0 !important;
	box-shadow: 0 11px 25px rgba(42, 15, 19, .1) !important;
	overflow: hidden !important;
	transform-style: preserve-3d;
	transition: transform .24s ease, box-shadow .24s ease;
}

.arch-featured-carousel-frame .arch-preview-product-card:hover {
	box-shadow: 0 20px 40px rgba(42, 15, 19, .18) !important;
	transform: translateY(-5px) rotateX(2deg) !important;
}

.arch-featured-carousel-frame .arch-preview-product-card img {
	width: 100% !important;
	height: 142px !important;
	object-fit: cover !important;
}

.arch-featured-carousel-frame .arch-preview-product-body {
	min-height: 70px !important;
	padding: .55rem .62rem .62rem !important;
	gap: .2rem !important;
	background: #fffaf0 !important;
}

.arch-featured-carousel-frame .arch-preview-product-body small {
	display: none !important;
}

.arch-featured-carousel-frame .arch-preview-product-body strong {
	min-height: 2.1em;
	color: #361014 !important;
	font-family: Georgia, "Times New Roman", serif !important;
	font-size: .86rem !important;
	line-height: 1.1 !important;
}

.arch-featured-carousel-frame .arch-preview-product-body em {
	position: relative;
	display: block !important;
	min-height: 24px;
	padding-right: 32px;
	color: #5b1014 !important;
	font-size: .78rem !important;
	font-style: normal !important;
	font-weight: 800 !important;
}

.arch-featured-carousel-frame .arch-preview-product-body em::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: -2px;
	width: 25px;
	height: 25px;
	border-radius: 50%;
	background:
		linear-gradient(90deg, #fff 8px, transparent 8px 17px, #fff 17px) 50% 53% / 15px 10px no-repeat,
		#c09536;
	box-shadow: inset 0 -2px 0 rgba(0,0,0,.12);
}

.arch-product-rail-arrow {
	position: absolute;
	top: 43%;
	z-index: 6;
	display: grid;
	place-items: center;
	width: 28px;
	height: 28px;
	border: 0;
	border-radius: 999px;
	background: #c09536;
	color: #fffaf0;
	font-size: 1.5rem;
	line-height: 1;
	box-shadow: 0 10px 20px rgba(42, 15, 19, .18);
	cursor: default;
}

.arch-product-rail-prev {
	left: 4px;
}

.arch-product-rail-next {
	right: 4px;
}

.arch-featured-products-section .arch-centered-action {
	margin-top: 1rem !important;
}

.arch-featured-products-section .arch-centered-action .arch-button {
	min-height: 30px !important;
	padding: .47rem 1.8rem !important;
	border-radius: 4px !important;
	background: #c09536 !important;
	color: #fffaf0 !important;
	font-size: .72rem !important;
	letter-spacing: .08em !important;
}

@keyframes arch-product-glide {
	0% {
		transform: translate3d(0, 0, 0);
	}
	100% {
		transform: translate3d(calc(-50% - .425rem), 0, 0);
	}
}

.arch-impact-section {
	padding: 1.05rem 0 1.25rem !important;
	background:
		linear-gradient(90deg, rgba(255,250,240,.95), rgba(255,250,240,.95)),
		radial-gradient(circle at 4% 12%, rgba(201,154,63,.16), transparent 22%);
}

.arch-impact-inner {
	display: grid;
	grid-template-columns: 230px minmax(260px, 1.35fr) repeat(3, minmax(120px, 1fr));
	align-items: center;
	gap: 1.6rem;
	width: min(1080px, calc(100vw - 48px));
	margin: 0 auto;
}

.arch-impact-image {
	min-height: 150px;
	border-radius: 8px;
	background-image: url("../images/approved-luxury-homepage-concept.webp");
	background-size: 1200px auto;
	background-position: 7% 73.4%;
	box-shadow: 0 16px 34px rgba(42, 15, 19, .18);
}

.arch-impact-copy h2 {
	margin: 0 0 .45rem;
	color: #46131a;
	font-family: Georgia, "Times New Roman", serif;
	font-size: clamp(1.7rem, 3vw, 2.35rem);
	line-height: .98;
}

.arch-impact-copy p,
.arch-impact-point p {
	margin: 0;
	color: #5d5148;
	font-size: .83rem;
	line-height: 1.42;
}

.arch-impact-copy a {
	display: inline-block;
	margin-top: .8rem;
	color: #5b1014;
	font-size: .76rem;
	font-weight: 900;
	letter-spacing: .05em;
	text-decoration: none;
	text-transform: uppercase;
}

.arch-impact-point {
	min-height: 128px;
	padding-left: 1.35rem;
	border-left: 1px solid rgba(201,154,63,.3);
	text-align: center;
}

.arch-line-icon {
	display: block;
	color: #9f7a31;
	font-size: 2.45rem;
	line-height: 1;
}

.arch-impact-point h3 {
	margin: .6rem 0 .35rem;
	color: #5b1014;
	font-family: Georgia, "Times New Roman", serif;
	font-size: .98rem;
}

.arch-newsletter-section.arch-newsletter-section {
	grid-template-columns: 130px minmax(260px, 1fr) minmax(360px, 500px) !important;
	gap: 1.7rem !important;
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 1.15rem max(2rem, calc((100vw - 1080px) / 2)) !important;
	border-radius: 0 !important;
	background:
		radial-gradient(circle at 11% 24%, rgba(201,154,63,.16), transparent 19%),
		linear-gradient(135deg, #5b1014, #2b0909) !important;
}

.arch-newsletter-medallion {
	width: 94px !important;
	height: 94px !important;
	background: rgba(255,250,240,.05) !important;
	color: #d2a24c !important;
}

.arch-newsletter-section h2 {
	color: #fff4df !important;
	font-family: Georgia, "Times New Roman", serif !important;
	font-size: 2rem !important;
}

.arch-newsletter-section p {
	color: rgba(255,244,223,.84) !important;
	font-size: .86rem !important;
}

.arch-newsletter-form form {
	grid-template-columns: 1fr auto !important;
}

.arch-newsletter-form input[type="email"] {
	min-height: 42px !important;
	border: 1px solid rgba(201,154,63,.42) !important;
	border-radius: 4px 0 0 4px !important;
	background: #fffaf0 !important;
	color: #2a0f13 !important;
}

.arch-newsletter-form button {
	min-height: 42px !important;
	border-radius: 0 4px 4px 0 !important;
	background: linear-gradient(180deg, #efd084, #c09536) !important;
	color: #451017 !important;
	font-size: .75rem !important;
	letter-spacing: .05em !important;
}

.arch-newsletter-form small,
.arch-newsletter-message {
	grid-column: 1 / -1;
	color: rgba(255,244,223,.78) !important;
	font-size: .74rem !important;
}

.arch-site-footer.arch-site-footer {
	background: #25100c !important;
	color: rgba(255,244,223,.82) !important;
}

.arch-site-footer.arch-site-footer::after {
	content: "";
	display: block;
	height: 18px;
	background:
		repeating-linear-gradient(90deg, rgba(201,154,63,.8) 0 2px, transparent 2px 8px),
		linear-gradient(90deg, #2a0f13, #7a4d28, #2a0f13);
}

.arch-footer-top {
	grid-template-columns: 1.45fr repeat(4, minmax(120px, 1fr)) !important;
	width: min(1080px, calc(100vw - 48px)) !important;
	gap: 2.4rem !important;
	padding: 2rem 0 1.7rem !important;
}

.arch-footer-brand img {
	width: min(100%, 260px) !important;
	max-width: 260px !important;
	max-height: 96px !important;
	object-fit: contain !important;
}

.arch-footer-social {
	display: flex;
	gap: .58rem;
	margin-top: 1.2rem;
}

.arch-footer-social a {
	display: grid;
	place-items: center;
	width: 27px;
	height: 27px;
	border: 1px solid rgba(201,154,63,.28);
	border-radius: 50%;
	color: #fff4df !important;
	font-size: .75rem;
	font-weight: 800;
	text-decoration: none;
}

.arch-footer-top h2 {
	margin: 0 0 .72rem !important;
	color: #fff4df !important;
	font-size: .76rem !important;
	font-weight: 900 !important;
	letter-spacing: .08em !important;
	text-transform: uppercase !important;
}

.arch-footer-top ul {
	gap: .24rem !important;
}

.arch-footer-top a,
.arch-footer-top p {
	color: rgba(255,244,223,.78) !important;
	font-size: .78rem !important;
	line-height: 1.35 !important;
}

.arch-footer-contact p {
	margin: 0 0 .48rem;
}

.arch-footer-bottom {
	display: grid !important;
	grid-template-columns: 1fr auto;
	align-items: center;
	width: min(1080px, calc(100vw - 48px));
	margin: 0 auto;
	padding: .55rem 0 !important;
	border-top: 1px solid rgba(201,154,63,.18) !important;
	background: transparent !important;
	color: rgba(255,244,223,.72) !important;
}

.arch-footer-bottom nav {
	display: flex;
	gap: .6rem;
}

.arch-footer-bottom a {
	color: rgba(255,244,223,.78) !important;
	text-decoration: none;
}

@media (max-width: 1180px) {
	.arch-site-header.arch-site-header .arch-header-inner {
		grid-template-columns: minmax(0, 1fr) auto !important;
	}

	.arch-impact-inner,
	.arch-footer-top {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	.arch-newsletter-section.arch-newsletter-section {
		grid-template-columns: 90px 1fr !important;
	}

	.arch-newsletter-form {
		grid-column: 1 / -1;
	}
}

@media (max-width: 720px) {
	.arch-site-header.arch-site-header .arch-header-inner,
	.arch-hero-slider.arch-hero-slider .arch-hero-inner,
	.arch-category-grid,
	.arch-impact-inner,
	.arch-footer-top,
	.arch-footer-bottom {
		width: min(100% - 28px, 1080px) !important;
	}

	.arch-hero-slider.arch-hero-slider::before {
		background: linear-gradient(135deg, #1b0809, #3d1118) !important;
	}

	.arch-hero-slider.arch-hero-slider .arch-hero-inner,
	.arch-impact-inner,
	.arch-newsletter-section.arch-newsletter-section,
	.arch-footer-top,
	.arch-footer-bottom {
		grid-template-columns: 1fr !important;
	}

	.arch-featured-carousel-frame {
		width: min(100% - 36px, 1080px);
	}

	.arch-newsletter-form form {
		grid-template-columns: 1fr !important;
		gap: .55rem !important;
	}

	.arch-newsletter-form input[type="email"],
	.arch-newsletter-form button {
		border-radius: 4px !important;
	}
}
