/* ==========================================================================
   Bill Hicks Modern — main stylesheet
   ========================================================================== */

/* ---------- 1. Tokens & resets --------------------------------------------- */
:root {
	--bh-burgundy: #813a64;
	--bh-burgundy-dark: #5d2849;
	--bh-wine: #ab2e31;
	--bh-gold: #c8a064;
	--bh-gold-soft: #e7d4af;
	--bh-rose: #e9beaf;
	--bh-blush: #f9e2da;
	--bh-mist: #f5f1ee;
	--bh-paper: #ffffff;
	--bh-ink: #282828;
	--bh-smoke: #58585a;
	--bh-haze: #888;
	--bh-line: #e7e1dc;

	--bh-font-display: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
	--bh-font-body:    'Inter', system-ui, -apple-system, 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;

	--bh-radius: 4px;
	--bh-radius-lg: 14px;
	--bh-shadow: 0 14px 30px -14px rgba(40,40,40,.18);
	--bh-shadow-lg: 0 30px 60px -20px rgba(40,40,40,.25);

	--bh-container: 1280px;
	--bh-container-narrow: 780px;
	--bh-gutter: clamp(20px, 4vw, 48px);

	--bh-ease: cubic-bezier(.2,.7,.2,1);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: var(--bh-font-body);
	color: var(--bh-ink);
	background: var(--bh-paper);
	font-size: 16px;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--bh-burgundy); text-decoration: none; transition: color .25s var(--bh-ease); }
a:hover, a:focus { color: var(--bh-burgundy-dark); }
button { font-family: inherit; cursor: pointer; }

h1, h2, h3, h4, h5 {
	font-family: var(--bh-font-display);
	font-weight: 500;
	color: var(--bh-ink);
	letter-spacing: .005em;
	margin: 0 0 .4em;
	line-height: 1.18;
}
h1 { font-size: clamp(2.4rem, 4vw + .3rem, 3.6rem); }
h2 { font-size: clamp(2rem, 3vw + .3rem, 2.8rem); }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.2rem; }
p  { margin: 0 0 1em; }

::selection { background: var(--bh-blush); color: var(--bh-burgundy-dark); }

/* ---------- 2. Layout helpers ---------------------------------------------- */
.container {
	width: 100%;
	max-width: var(--bh-container);
	margin: 0 auto;
	padding-left: var(--bh-gutter);
	padding-right: var(--bh-gutter);
}
.container--narrow { max-width: var(--bh-container-narrow); }

.eyebrow {
	font-family: var(--bh-font-body);
	font-size: .7rem;
	font-weight: 600;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--bh-burgundy);
	margin: 0 0 .8em;
	display: inline-block;
}
.eyebrow--light { color: var(--bh-gold-soft); }

.section-header { margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.section-header--center { text-align: center; max-width: 760px; margin-left: auto; margin-right: auto; }
.section-title { margin-bottom: .4em; }
.section-lead { color: var(--bh-smoke); font-size: 1.05rem; }

/* ---------- 3. Buttons ----------------------------------------------------- */
.btn {
	display: inline-flex; align-items: center; gap: .55em;
	padding: .9em 1.6em;
	border: 1px solid transparent;
	border-radius: var(--bh-radius);
	font-family: var(--bh-font-body);
	font-size: .85rem;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	cursor: pointer;
	transition: all .25s var(--bh-ease);
	background: transparent;
	color: var(--bh-ink);
	text-decoration: none;
}
.btn--primary { background: var(--bh-burgundy); color: #fff; border-color: var(--bh-burgundy); }
.btn--primary:hover, .btn--primary:focus { background: var(--bh-burgundy-dark); border-color: var(--bh-burgundy-dark); color: #fff; transform: translateY(-1px); }
.btn--ghost { color: var(--bh-ink); border-color: var(--bh-ink); background: transparent; }
.btn--ghost:hover, .btn--ghost:focus { background: var(--bh-ink); color: #fff; }
.btn--lg { padding: 1.05em 2em; font-size: .9rem; }
.btn .bh-icon { transition: transform .25s var(--bh-ease); }
.btn:hover .bh-icon { transform: translateX(3px); }

.bh-link {
	display: inline-flex; align-items: center; gap: .4em;
	color: var(--bh-burgundy);
	font-weight: 600;
	font-size: .85rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	text-decoration: none;
	border-bottom: 1px solid currentColor;
	padding-bottom: 2px;
}
.bh-link .bh-icon { transition: transform .25s var(--bh-ease); }
.bh-link:hover .bh-icon { transform: translateX(4px); }

/* ---------- 4. Skip link / a11y -------------------------------------------- */
.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px; padding: 0;
	overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.skip-link {
	position: absolute; top: -40px; left: 8px;
	background: #000; color: #fff; padding: 8px 14px;
	z-index: 1000;
}
.skip-link:focus { top: 8px; }

/* ---------- 5. Announce bar ------------------------------------------------ */
.announce-bar {
	background: var(--bh-ink);
	color: #fff;
	font-size: .8rem;
	letter-spacing: .08em;
}
.announce-bar__inner {
	display: flex; align-items: center; justify-content: space-between;
	padding: 10px 0; gap: 16px; flex-wrap: wrap;
}
.announce-bar a { color: #fff; display: inline-flex; align-items: center; gap: .4em; }
.announce-bar a:hover { color: var(--bh-rose); }
.announce-bar__msg { font-style: italic; opacity: .85; flex: 1; text-align: center; }
@media (max-width: 720px) {
	.announce-bar__msg { display: none; }
}

/* ---------- 6. Site header ------------------------------------------------- */
.site-header {
	background: var(--bh-paper);
	border-bottom: 1px solid var(--bh-line);
	position: sticky; top: 0; z-index: 50;
	transition: box-shadow .25s var(--bh-ease), padding .25s var(--bh-ease);
}
.site-header.is-scrolled { box-shadow: var(--bh-shadow); }
.site-header__inner {
	display: flex; align-items: center; justify-content: space-between;
	padding: 18px 0;
	gap: 24px;
}
.site-branding { flex: 0 0 auto; }
.site-title { font-family: var(--bh-font-display); font-size: 1.4rem; margin: 0; letter-spacing: .04em; }
.site-title a { color: var(--bh-ink); text-decoration: none; }
.has-custom-logo .custom-logo-link img { max-height: 56px; width: auto; }

.primary-nav { flex: 1 1 auto; }
.primary-nav__list {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; justify-content: center; gap: 2px;
}
.primary-nav__list > li { position: relative; }
.primary-nav__list > li > a {
	display: inline-flex; align-items: center; gap: .3em;
	padding: 14px 14px;
	color: var(--bh-ink);
	font-size: .82rem;
	font-weight: 500;
	letter-spacing: .14em;
	text-transform: uppercase;
	text-decoration: none;
}
.primary-nav__list > li > a:hover,
.primary-nav__list > li:focus-within > a { color: var(--bh-burgundy); }
.primary-nav__list .has-mega > a::after {
	display: none;
}
.primary-nav__list .sub-menu {
	position: absolute; top: 100%; left: 0; min-width: 240px;
	background: #fff; border: 1px solid var(--bh-line);
	box-shadow: var(--bh-shadow);
	list-style: none; padding: 14px 0; margin: 0;
	opacity: 0; visibility: hidden; transform: translateY(8px);
	transition: opacity .22s var(--bh-ease), transform .22s var(--bh-ease), visibility 0s linear .25s;
}
.primary-nav__list > li:hover > .sub-menu,
.primary-nav__list > li:focus-within > .sub-menu {
	opacity: 1; visibility: visible; transform: translateY(0);
	transition-delay: 0s;
}
.primary-nav__list .sub-menu a {
	display: block; padding: 8px 22px;
	color: var(--bh-ink);
	font-size: .82rem;
	letter-spacing: .08em;
	text-transform: none;
}
.primary-nav__list .sub-menu a:hover { background: var(--bh-mist); color: var(--bh-burgundy); }
.primary-nav__list .mega-menu { padding: 18px 0; }

.site-header__actions { display: flex; align-items: center; gap: 6px; }
.site-header__actions button {
	background: transparent; border: 0; color: var(--bh-ink);
	padding: 10px; border-radius: var(--bh-radius);
	display: inline-flex; align-items: center; justify-content: center;
}
.site-header__actions button:hover { background: var(--bh-mist); color: var(--bh-burgundy); }

.mobile-nav-toggle { display: none; }
@media (max-width: 1024px) {
	.primary-nav { display: none; }
	.mobile-nav-toggle { display: inline-flex; }
}

.search-drawer {
	border-top: 1px solid var(--bh-line);
	padding: 18px 0;
	background: var(--bh-mist);
}
.search-drawer .search-form { display: flex; gap: 10px; max-width: 640px; margin: 0 auto; }
.search-drawer input[type="search"] {
	flex: 1; padding: 12px 16px;
	border: 1px solid var(--bh-line); border-radius: var(--bh-radius);
	font: inherit;
}
.search-drawer .search-form__submit {
	background: var(--bh-burgundy); color: #fff; border: 0; padding: 0 16px; border-radius: var(--bh-radius);
}

/* ---------- 7. Mobile drawer ----------------------------------------------- */
.mobile-drawer {
	position: fixed; inset: 0 0 0 auto;
	width: min(360px, 92vw);
	background: var(--bh-paper);
	transform: translateX(110%);
	transition: transform .3s var(--bh-ease);
	z-index: 200;
	box-shadow: var(--bh-shadow-lg);
	display: flex; flex-direction: column;
	padding: 16px;
}
.mobile-drawer.is-open { transform: translateX(0); }
.mobile-drawer__head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 6px 4px 16px;
	border-bottom: 1px solid var(--bh-line);
}
.mobile-drawer__brand { font-family: var(--bh-font-display); font-size: 1.2rem; }
.mobile-drawer__close {
	background: transparent; border: 0; padding: 8px; color: var(--bh-ink);
}
.mobile-drawer__list {
	list-style: none; padding: 12px 0; margin: 0;
	flex: 1; overflow-y: auto;
}
.mobile-drawer__list a {
	display: block; padding: 12px 4px;
	color: var(--bh-ink);
	font-size: .95rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	border-bottom: 1px solid var(--bh-line);
	text-decoration: none;
}
.mobile-drawer__list a:hover { color: var(--bh-burgundy); }
.mobile-drawer__list .sub-menu { list-style: none; padding-left: 14px; margin: 0; }
.mobile-drawer__list .sub-menu a { font-size: .85rem; text-transform: none; letter-spacing: .04em; }
.mobile-drawer__contact {
	padding-top: 16px; border-top: 1px solid var(--bh-line);
	display: flex; flex-direction: column; gap: 8px;
}
.mobile-drawer__contact a { display: inline-flex; align-items: center; gap: .5em; color: var(--bh-smoke); }

.body-locked { overflow: hidden; }
.scrim {
	position: fixed; inset: 0; background: rgba(0,0,0,.4);
	opacity: 0; pointer-events: none; transition: opacity .25s var(--bh-ease);
	z-index: 150;
}
.scrim.is-visible { opacity: 1; pointer-events: auto; }

/* ---------- 8. Hero slider ------------------------------------------------- */
.hero-slider {
	position: relative;
	overflow: hidden;
	background: var(--bh-ink);
	color: #fff;
}
.hero-slider__track {
	display: flex; width: 100%;
	transition: transform .6s var(--bh-ease);
}
.hero-slide {
	flex: 0 0 100%;
	min-height: clamp(420px, 70vh, 760px);
	background: #2c2421 center / cover no-repeat;
	display: flex; align-items: center;
	position: relative;
}
.hero-slide__overlay {
	position: absolute; inset: 0;
	background: linear-gradient(120deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.25) 50%, rgba(0,0,0,.4) 100%);
}
.hero-slide:not([style*="background-image"]) {
	background: radial-gradient(circle at 30% 30%, #5e2c45, var(--bh-ink) 70%);
}
.hero-slide__content {
	position: relative; z-index: 2;
	max-width: 720px;
	padding-top: 4rem; padding-bottom: 4rem;
}
.hero-slide__title {
	color: #fff;
	font-size: clamp(2.5rem, 5vw, 4.4rem);
	line-height: 1.05;
	margin-bottom: .5em;
}
.hero-slide__cta { margin-top: 1.6em; }

.hero-slider__controls {
	position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%);
	display: flex; align-items: center; gap: 14px;
	z-index: 3;
}
.hero-slider__btn {
	width: 40px; height: 40px; border-radius: 999px;
	border: 1px solid rgba(255,255,255,.35);
	background: rgba(0,0,0,.18);
	color: #fff;
	display: inline-flex; align-items: center; justify-content: center;
	transition: background .25s var(--bh-ease);
}
.hero-slider__btn:hover { background: rgba(255,255,255,.18); }
.hero-slider__dots { display: flex; gap: 6px; }
.hero-slider__dot {
	width: 28px; height: 2px; padding: 0; border: 0;
	background: rgba(255,255,255,.35); cursor: pointer;
	transition: background .25s var(--bh-ease);
}
.hero-slider__dot.is-active { background: var(--bh-gold); }

.hero-slider__scroll {
	position: absolute; right: 28px; bottom: 28px; z-index: 3;
	display: inline-flex; align-items: center; gap: .5em;
	color: rgba(255,255,255,.85);
	font-size: .72rem; letter-spacing: .2em; text-transform: uppercase;
	text-decoration: none;
}
.hero-slider__scroll svg { animation: bh-bounce 2.4s var(--bh-ease) infinite; }
@keyframes bh-bounce { 0%,100% { transform: translateY(0); } 50% { transform: translateY(4px); } }
@media (max-width: 720px) { .hero-slider__scroll { display: none; } }

/* ---------- 9. Section: category grid -------------------------------------- */
.category-grid { padding: clamp(4rem, 8vw, 7rem) 0; background: var(--bh-paper); }
.category-grid__list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}
@media (max-width: 900px) { .category-grid__list { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .category-grid__list { grid-template-columns: 1fr; } }

.category-tile {
	display: block;
	background: var(--bh-mist);
	color: var(--bh-ink);
	text-decoration: none;
	border-radius: var(--bh-radius-lg);
	overflow: hidden;
	transition: transform .35s var(--bh-ease), box-shadow .35s var(--bh-ease);
}
.category-tile:hover { transform: translateY(-4px); box-shadow: var(--bh-shadow-lg); }
.category-tile__media { position: relative; aspect-ratio: 4/3; overflow: hidden; }
.category-tile__media img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .8s var(--bh-ease);
}
.category-tile:hover .category-tile__media img { transform: scale(1.06); }
.category-tile__placeholder {
	position: absolute; inset: 0;
	background:
		radial-gradient(circle at 30% 30%, var(--bh-blush) 0%, transparent 50%),
		radial-gradient(circle at 70% 70%, var(--bh-rose) 0%, transparent 60%),
		linear-gradient(135deg, #f6ebe5, #efd9cf);
}
.category-tile__caption { padding: 28px 30px 32px; }
.category-tile__title { margin: 0 0 .35em; font-size: 1.45rem; }
.category-tile__desc { color: var(--bh-smoke); font-size: .95rem; margin: 0 0 1em; }
.category-tile__cta {
	display: inline-flex; align-items: center; gap: .35em;
	color: var(--bh-burgundy);
	font-size: .8rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
}

/* ---------- 10. Value strip ------------------------------------------------ */
.value-strip {
	background: linear-gradient(180deg, var(--bh-mist), #fff);
	padding: clamp(3rem, 6vw, 5rem) 0;
}
.value-strip__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	text-align: center;
}
@media (max-width: 800px) { .value-strip__grid { grid-template-columns: 1fr; } }
.value-prop__icon {
	width: 72px; height: 72px;
	border-radius: 999px;
	background: #fff;
	display: flex; align-items: center; justify-content: center;
	color: var(--bh-burgundy);
	margin: 0 auto 18px;
	box-shadow: 0 12px 24px -16px rgba(129,58,100,.4);
}
.value-prop__title { font-size: 1.2rem; margin: 0 0 .35em; }
.value-prop__copy  { color: var(--bh-smoke); font-size: .96rem; max-width: 320px; margin: 0 auto; }

/* ---------- 11. Process band ----------------------------------------------- */
.process-band {
	padding: clamp(4rem, 8vw, 7rem) 0;
	background: var(--bh-ink);
	color: #fff;
	position: relative;
}
.process-band::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 1px;
	background: linear-gradient(90deg, transparent, var(--bh-gold) 50%, transparent);
	opacity: .35;
}
.process-band .section-title,
.process-band .eyebrow,
.process-band .section-lead { color: #fff; }
.process-band .eyebrow { color: var(--bh-gold-soft); }

.process-band__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 60px 40px;
	max-width: 1100px;
	margin: 0 auto;
}
@media (max-width: 800px) { .process-band__grid { grid-template-columns: 1fr; gap: 32px; } }
.process-step {
	border-left: 1px solid rgba(255,255,255,.18);
	padding: 8px 4px 8px 28px;
	position: relative;
}
.process-step__number {
	font-family: var(--bh-font-display);
	font-size: 4rem; line-height: 1;
	color: var(--bh-gold);
	display: block; margin-bottom: 12px;
	font-weight: 300;
}
.process-step__title { color: #fff; font-size: 1.4rem; margin: 0 0 .35em; }
.process-step__desc { color: rgba(255,255,255,.78); font-size: .98rem; margin: 0; }

/* ---------- 12. Collection feature ----------------------------------------- */
.collection-feature {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: clamp(420px, 60vh, 640px);
}
.collection-feature--reverse { direction: rtl; }
.collection-feature--reverse > * { direction: ltr; }
@media (max-width: 900px) { .collection-feature { grid-template-columns: 1fr; } }

.collection-feature__media {
	background: var(--bh-blush) center / cover no-repeat;
	position: relative;
	min-height: 360px;
}
.collection-feature__media--rose { background: var(--bh-rose); }
.collection-feature__placeholder {
	position: absolute; inset: 0;
	background:
		radial-gradient(circle at 30% 40%, rgba(255,255,255,.6) 0%, transparent 60%),
		radial-gradient(circle at 70% 70%, rgba(200,160,100,.35) 0%, transparent 60%);
}
.collection-feature__copy {
	display: flex; align-items: center;
	background: var(--bh-paper);
	padding: clamp(2rem, 6vw, 5rem);
}
.collection-feature__copy-inner { max-width: 460px; }

/* ---------- 13. Testimonial block ------------------------------------------ */
.testimonial-block {
	padding: clamp(4rem, 7vw, 6rem) 0;
	background: var(--bh-blush);
	color: var(--bh-burgundy-dark);
	position: relative;
	text-align: center;
}
.testimonial-block__inner { max-width: 780px; margin: 0 auto; position: relative; }
.testimonial-block__quote { color: var(--bh-burgundy); margin: 0 auto 8px; }
.testimonial-block__list { position: relative; min-height: 200px; }
.testimonial {
	margin: 0;
	position: absolute; inset: 0;
	opacity: 0; transform: translateY(8px);
	transition: opacity .5s var(--bh-ease), transform .5s var(--bh-ease);
	pointer-events: none;
}
.testimonial.is-active { opacity: 1; transform: translateY(0); pointer-events: auto; position: static; }
.testimonial__quote {
	font-family: var(--bh-font-display);
	font-size: clamp(1.4rem, 2.4vw, 1.85rem);
	line-height: 1.4;
	margin: 0 0 1.4em;
	color: var(--bh-ink);
	font-style: italic;
}
.testimonial__cite { font-size: .85rem; letter-spacing: .14em; text-transform: uppercase; color: var(--bh-burgundy); font-style: normal; }
.testimonial-block__dots { display: flex; gap: 8px; justify-content: center; margin-top: 2rem; }
.testimonial-block__dot {
	width: 8px; height: 8px; border-radius: 50%; padding: 0; border: 0;
	background: rgba(129,58,100,.25); cursor: pointer;
	transition: background .25s var(--bh-ease);
}
.testimonial-block__dot.is-active { background: var(--bh-burgundy); }

/* ---------- 14. Social feed ------------------------------------------------ */
.social-feed { padding: clamp(4rem, 7vw, 6rem) 0; }
.social-feed__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}
@media (max-width: 900px) { .social-feed__grid { grid-template-columns: repeat(2, 1fr); } }

.social-tile {
	display: block; position: relative; aspect-ratio: 1/1;
	overflow: hidden; border-radius: var(--bh-radius);
	background: var(--bh-mist);
}
.social-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--bh-ease); }
.social-tile:hover img { transform: scale(1.06); }
.social-tile__placeholder {
	position: absolute; inset: 0;
	background: linear-gradient(135deg, var(--bh-blush), var(--bh-rose));
}
.social-tile__overlay {
	position: absolute; inset: 0;
	background: rgba(40,40,40,.45);
	opacity: 0;
	display: flex; align-items: center; justify-content: center;
	color: #fff;
	transition: opacity .25s var(--bh-ease);
}
.social-tile:hover .social-tile__overlay,
.social-tile:focus-visible .social-tile__overlay { opacity: 1; }

/* ---------- 15. Newsletter ------------------------------------------------- */
.newsletter-block {
	padding: clamp(4rem, 7vw, 6rem) 0;
	background:
		linear-gradient(120deg, rgba(40,40,40,.85), rgba(40,40,40,.65)),
		linear-gradient(120deg, var(--bh-burgundy), var(--bh-ink));
	color: #fff;
}
.newsletter-block__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: center;
}
@media (max-width: 800px) { .newsletter-block__inner { grid-template-columns: 1fr; } }
.newsletter-block__copy h2,
.newsletter-block__copy .section-title { color: #fff; }
.newsletter-block__copy .section-lead { color: rgba(255,255,255,.78); }
.newsletter-block__form { display: flex; gap: 10px; flex-wrap: wrap; }
.newsletter-block__form input {
	flex: 1; min-width: 220px;
	padding: 14px 18px;
	border: 1px solid rgba(255,255,255,.3);
	border-radius: var(--bh-radius);
	background: rgba(255,255,255,.06);
	color: #fff;
	font: inherit;
}
.newsletter-block__form input::placeholder { color: rgba(255,255,255,.55); }
.newsletter-block__form input:focus { outline: 2px solid var(--bh-gold); border-color: var(--bh-gold); }

/* ---------- 16. Page hero -------------------------------------------------- */
.page-hero {
	background: var(--bh-mist);
	padding: clamp(4rem, 8vw, 7rem) 0 clamp(3rem, 6vw, 5rem);
	text-align: left;
}
.page-hero--center { text-align: center; padding: clamp(4rem, 8vw, 7rem) 0 clamp(4rem, 7vw, 5rem); }
.page-hero__title { margin: 0 0 .25em; }
.page-hero__lead { color: var(--bh-smoke); max-width: 620px; font-size: 1.05rem; }
.page-hero--center .page-hero__lead { margin-left: auto; margin-right: auto; }
.page-hero--image {
	background-position: center;
	background-size: cover;
	color: #fff;
	min-height: clamp(280px, 40vh, 480px);
	display: flex; align-items: flex-end;
	padding-bottom: clamp(2rem, 5vw, 4rem);
	position: relative;
}
.page-hero--image::before {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.1), rgba(0,0,0,.55));
}
.page-hero--image .container { position: relative; z-index: 1; }
.page-hero--image .page-hero__title { color: #fff; }
.page-hero--image .eyebrow { color: var(--bh-gold-soft); }
.page-hero--blog { background: linear-gradient(135deg, var(--bh-blush), #fff); }

.page-hero__actions { margin-top: 1.6em; }
.page-hero__search { margin-top: 1.6em; }

/* ---------- 17. Page content & blog ---------------------------------------- */
.page-article { padding: clamp(3rem, 6vw, 5rem) 0; }
.entry-content > * + * { margin-top: 1em; }
.entry-content h2 { margin-top: 1.6em; }
.entry-content blockquote {
	border-left: 3px solid var(--bh-burgundy);
	padding: 8px 0 8px 22px;
	margin: 1.6em 0;
	font-family: var(--bh-font-display);
	font-size: 1.3rem;
	color: var(--bh-ink);
	font-style: italic;
}
.entry-content img { border-radius: var(--bh-radius); }
.entry-content a { border-bottom: 1px solid currentColor; }
.entry-content ul, .entry-content ol { padding-left: 1.4em; }
.entry-content code {
	background: var(--bh-mist);
	padding: 2px 6px; border-radius: 4px;
	font-size: .9em;
}

.entry-meta { color: var(--bh-haze); font-size: .85rem; margin-top: -.4em; margin-bottom: 1.6em; }

.content-with-sidebar {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 60px;
	padding: clamp(3rem, 6vw, 5rem) 0;
}
@media (max-width: 900px) { .content-with-sidebar { grid-template-columns: 1fr; } }

.post-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 36px;
}
@media (max-width: 700px) { .post-grid { grid-template-columns: 1fr; } }
.post-card { background: #fff; border: 1px solid var(--bh-line); border-radius: var(--bh-radius-lg); overflow: hidden; transition: box-shadow .25s var(--bh-ease); }
.post-card:hover { box-shadow: var(--bh-shadow); }
.post-card__media { display: block; aspect-ratio: 16/10; overflow: hidden; }
.post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--bh-ease); }
.post-card:hover .post-card__media img { transform: scale(1.05); }
.post-card__body { padding: 24px 28px 28px; }
.post-card__title { font-size: 1.4rem; margin: 0 0 .35em; }
.post-card__title a { color: var(--bh-ink); text-decoration: none; }
.post-card__title a:hover { color: var(--bh-burgundy); }
.post-card__excerpt { color: var(--bh-smoke); font-size: .96rem; margin-bottom: 1em; }

.primary-sidebar { font-size: .94rem; }
.primary-sidebar .widget + .widget { margin-top: 2rem; }
.primary-sidebar .widget-title {
	font-size: 1rem; letter-spacing: .14em; text-transform: uppercase;
	font-family: var(--bh-font-body); font-weight: 600;
	margin-bottom: 1em; color: var(--bh-ink);
}
.primary-sidebar ul { list-style: none; padding: 0; margin: 0; }
.primary-sidebar li { padding: 6px 0; border-bottom: 1px solid var(--bh-line); }
.primary-sidebar a { color: var(--bh-smoke); }
.primary-sidebar a:hover { color: var(--bh-burgundy); }

.post-tags { list-style: none; padding: 0; margin: 2rem 0; display: flex; flex-wrap: wrap; gap: 8px; }
.post-tags li { background: var(--bh-mist); padding: 6px 12px; border-radius: 99px; font-size: .8rem; }

.post-nav {
	display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
	margin: 3rem 0; padding-top: 2rem; border-top: 1px solid var(--bh-line);
}
.post-nav__next { text-align: right; }
.post-nav a { font-family: var(--bh-font-display); font-size: 1.1rem; }

/* ---------- 18. Comments --------------------------------------------------- */
.comments-area { margin: 3rem 0; padding-top: 2rem; border-top: 1px solid var(--bh-line); }
.comment-list { list-style: none; padding: 0; margin: 0 0 2rem; }
.comment-list li { padding: 1.2rem 0; border-bottom: 1px solid var(--bh-line); }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--bh-line);
	border-radius: var(--bh-radius);
	font: inherit;
	margin-bottom: 1em;
}
.comment-form .submit { background: var(--bh-burgundy); color: #fff; border: 0; padding: 12px 22px; border-radius: var(--bh-radius); }

/* ---------- 19. Site footer ------------------------------------------------ */
.site-footer {
	background: var(--bh-ink);
	color: #cfc6c0;
	padding: clamp(3rem, 6vw, 5rem) 0 0;
	font-size: .92rem;
}
.site-footer__grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1.4fr;
	gap: 40px;
	padding-bottom: 3rem;
}
@media (max-width: 900px) { .site-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .site-footer__grid { grid-template-columns: 1fr; } }

.site-footer a { color: #cfc6c0; }
.site-footer a:hover { color: var(--bh-rose); }
.site-footer__title {
	font-family: var(--bh-font-display); font-size: 1.6rem; color: #fff;
	margin: 0 0 .4em;
}
.site-footer__tag { color: #9c948f; line-height: 1.6; margin-bottom: 1.5em; }
.site-footer__heading {
	color: #fff; font-family: var(--bh-font-body); font-weight: 600;
	font-size: .85rem; letter-spacing: .18em; text-transform: uppercase;
	margin: 0 0 1em;
}
.site-footer__list { list-style: none; padding: 0; margin: 0; }
.site-footer__list li { padding: 6px 0; }

.site-footer__address p { display: flex; gap: .55em; align-items: flex-start; margin: 0 0 .8em; line-height: 1.5; }
.site-footer__address .bh-icon { flex: 0 0 auto; margin-top: 3px; color: var(--bh-gold); }

.site-footer__social { list-style: none; padding: 0; margin: 0; display: flex; gap: 8px; }
.site-footer__social a {
	width: 38px; height: 38px; border-radius: 999px;
	display: inline-flex; align-items: center; justify-content: center;
	border: 1px solid rgba(255,255,255,.18);
	color: #fff;
	transition: background .25s var(--bh-ease), border-color .25s var(--bh-ease);
}
.site-footer__social a:hover { background: var(--bh-burgundy); border-color: var(--bh-burgundy); }

.site-footer__bar {
	border-top: 1px solid rgba(255,255,255,.1);
	padding: 1.4rem 0;
}
.site-footer__bar-inner {
	display: flex; justify-content: space-between; align-items: center;
	gap: 16px; flex-wrap: wrap;
	font-size: .8rem;
	color: #8c8480;
}
.site-footer__bar-inner p { margin: 0; }

/* ---------- 20. Misc / blocks compatibility -------------------------------- */
.alignwide { max-width: var(--bh-container); margin-left: auto; margin-right: auto; }
.alignfull { width: 100vw; margin-left: calc(50% - 50vw); }

.wp-block-quote {
	border-left: 3px solid var(--bh-burgundy);
	padding: 8px 0 8px 22px;
	margin: 2em 0;
	font-family: var(--bh-font-display);
	font-size: 1.3rem;
	font-style: italic;
}

.wp-block-button__link {
	background: var(--bh-burgundy);
	color: #fff;
	border-radius: var(--bh-radius);
	padding: .9em 1.6em;
	font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
	font-size: .85rem;
}

/* Page content block on front-page */
.page-content-block { padding: clamp(3rem, 6vw, 5rem) 0; }

/* Contact template */
.contact-grid {
	display: grid;
	grid-template-columns: 1fr 1.4fr;
	gap: 60px;
	align-items: start;
}
@media (max-width: 800px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-info p { margin-bottom: 1em; line-height: 1.5; color: var(--bh-smoke); }
.contact-info strong {
	display: block; color: var(--bh-ink);
	font-size: .8rem; letter-spacing: .14em; text-transform: uppercase;
	margin-bottom: 4px;
}
.contact-cta { margin-top: 1.5em; }

/* Reveal-on-scroll */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s var(--bh-ease), transform .7s var(--bh-ease); }
.reveal.is-revealed { opacity: 1; transform: translateY(0); }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: .01ms !important;
		transition-duration: .01ms !important;
	}
	.hero-slider__track { transition: none; }
}
