:root {
	--wb-faq-ink: #332b27;
	--wb-faq-muted: #716660;
	--wb-faq-accent: #9b6f55;
	--wb-faq-accent-dark: #74503d;
	--wb-faq-ivory: #f7f1e9;
	--wb-faq-soft: #fcfaf7;
	--wb-faq-line: #e8ddd3;
	--wb-faq-white: #fff;
	--wb-faq-shadow: 0 18px 52px rgba(68, 49, 38, 0.09);
}

.wb-faq-page {
	color: var(--wb-faq-ink);
	overflow: clip;
}

.wb-faq-page > * {
	margin-block-start: 0;
}

.wb-faq-hero {
	background: var(--wb-faq-ivory);
	min-height: clamp(500px, 36vw, 680px);
	position: relative;
}

.wb-faq-hero__media,
.wb-faq-hero__media img {
	display: block;
	height: 100%;
	inset: 0;
	object-fit: cover;
	position: absolute;
	width: 100%;
}

.wb-faq-hero__inner {
	align-items: center;
	display: grid;
	grid-template-columns: minmax(0, 45%) minmax(0, 55%);
	margin: 0 auto;
	max-width: 1440px;
	min-height: inherit;
	padding: clamp(44px, 5vw, 82px);
	position: relative;
	z-index: 1;
}

.wb-faq-hero__copy {
	grid-column: 1;
	max-width: 580px;
}

.wb-faq-eyebrow,
.wb-faq-kicker {
	color: var(--wb-faq-accent-dark);
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.17em;
	text-transform: uppercase;
}

.wb-faq-hero h1,
.wb-faq-intro h2,
.wb-faq-group h2,
.wb-faq-separation h2,
.wb-faq-final h2 {
	font-family: "Noto Serif JP", "Yu Mincho", serif;
	font-weight: 500;
	letter-spacing: 0.03em;
}

.wb-faq-hero h1 {
	font-size: clamp(2.8rem, 4.5vw, 4.5rem);
	line-height: 1.2;
	margin: 0.2em 0 0.4em;
}

.wb-faq-hero__copy > p:not(.wb-faq-eyebrow) {
	font-size: clamp(1rem, 1.3vw, 1.14rem);
	line-height: 1.9;
}

.wb-faq-button {
	align-items: center;
	border: 1px solid var(--wb-faq-accent);
	border-radius: 999px;
	display: inline-flex;
	font-weight: 700;
	justify-content: center;
	min-height: 54px;
	padding: 0.8rem 1.7rem;
	text-decoration: none;
}

.wb-faq-button--primary {
	background: var(--wb-faq-accent);
	color: var(--wb-faq-white);
	margin-top: 14px;
}

.wb-faq-summary {
	background: var(--wb-faq-white);
	border: 1px solid var(--wb-faq-line);
	border-radius: 20px;
	box-shadow: var(--wb-faq-shadow);
	margin: clamp(42px, 6vw, 76px) auto;
	max-width: 1080px;
	padding: clamp(28px, 4vw, 50px);
}

.wb-faq-summary h2 {
	font-size: clamp(1.55rem, 2.5vw, 2rem);
	margin-top: 0;
}

.wb-faq-summary h3 {
	font-size: 1rem;
	margin-bottom: 0.35rem;
}

.wb-faq-summary__verified {
	color: var(--wb-faq-muted);
	font-size: 0.86rem;
}

.wb-faq-intro {
	margin: 0 auto;
	max-width: 920px;
	padding: clamp(56px, 7vw, 92px) 24px;
	text-align: center;
}

.wb-faq-intro h2,
.wb-faq-group h2,
.wb-faq-separation h2 {
	font-size: clamp(2rem, 3.2vw, 3rem);
	line-height: 1.4;
	margin: 0.25em 0 0.6em;
}

.wb-faq-categories {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(4, 1fr);
	margin: 0 auto clamp(64px, 8vw, 104px);
	max-width: 1100px;
	padding: 0 24px;
}

.wb-faq-categories a {
	background: var(--wb-faq-soft);
	border: 1px solid var(--wb-faq-line);
	border-radius: 999px;
	color: var(--wb-faq-ink);
	font-weight: 700;
	padding: 14px 12px;
	text-align: center;
	text-decoration: none;
}

.wb-faq-groups {
	margin: 0 auto;
	max-width: 1100px;
	padding: 0 24px clamp(72px, 9vw, 128px);
}

.wb-faq-group {
	scroll-margin-top: 100px;
}

.wb-faq-group + .wb-faq-group {
	border-top: 1px solid var(--wb-faq-line);
	margin-top: clamp(60px, 8vw, 96px);
	padding-top: clamp(60px, 8vw, 96px);
}

.wb-faq-list {
	border-top: 1px solid var(--wb-faq-line);
}

.wb-faq-list details {
	border-bottom: 1px solid var(--wb-faq-line);
}

.wb-faq-list summary {
	align-items: flex-start;
	cursor: pointer;
	display: flex;
	font-size: 1.05rem;
	font-weight: 700;
	gap: 16px;
	list-style: none;
	padding: 24px 8px;
}

.wb-faq-list summary::-webkit-details-marker {
	display: none;
}

.wb-faq-list summary::after {
	color: var(--wb-faq-accent);
	content: "+";
	font-size: 1.5rem;
	line-height: 1;
	margin-left: auto;
}

.wb-faq-list details[open] summary::after {
	content: "−";
}

.wb-faq-list summary span,
.wb-faq-answer > span {
	color: var(--wb-faq-accent-dark);
	font-family: Georgia, serif;
	font-size: 1.3rem;
	font-weight: 700;
}

.wb-faq-answer {
	display: flex;
	gap: 16px;
	padding: 0 48px 26px 8px;
}

.wb-faq-answer p {
	color: var(--wb-faq-muted);
	margin: 0;
}

.wb-faq-separation {
	background: var(--wb-faq-soft);
	padding: clamp(72px, 8vw, 116px) 24px;
}

.wb-faq-separation > div {
	margin: 0 auto;
	max-width: 1100px;
}

.wb-faq-separation .wp-block-columns {
	display: grid;
	gap: 20px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-top: 36px;
}

.wb-faq-separation .wp-block-column {
	background: var(--wb-faq-white);
	border: 1px solid var(--wb-faq-line);
	border-radius: 16px;
	box-shadow: var(--wb-faq-shadow);
	padding: 30px;
}

.wb-faq-final {
	background: linear-gradient(135deg, #76503c, #a77b60);
	color: var(--wb-faq-white);
	padding: clamp(76px, 9vw, 124px) 24px;
	text-align: center;
}

.wb-faq-final > div {
	margin: 0 auto;
	max-width: 820px;
}

.wb-faq-final .wb-faq-eyebrow {
	color: #f3e9df;
}

.wb-faq-final h2 {
	font-size: clamp(2.2rem, 4vw, 3.5rem);
	margin: 0.2em 0 0.35em;
}

.wb-faq-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: center;
	margin-top: 28px;
}

.wb-faq-button--light {
	background: var(--wb-faq-white);
	border-color: var(--wb-faq-white);
	color: var(--wb-faq-accent-dark);
}

.wb-faq-button--outline-light {
	border-color: rgba(255, 255, 255, 0.7);
	color: var(--wb-faq-white);
}

.wb-faq-mobile-cta {
	display: none;
}

@media (max-width: 900px) {
	.wb-faq-categories {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 767px) {
	.wb-faq-page {
		padding-bottom: calc(76px + env(safe-area-inset-bottom));
	}

	.wb-faq-hero {
		display: flex;
		flex-direction: column;
		min-height: 0;
	}

	.wb-faq-hero__media {
		aspect-ratio: 13 / 10;
		height: auto;
		inset: auto;
		position: relative;
	}

	.wb-faq-hero__media img {
		height: 100%;
		object-position: center 28%;
		position: absolute;
	}

	.wb-faq-hero__inner {
		display: block;
		min-height: 0;
		padding: 30px 22px 44px;
		width: 100%;
	}

	.wb-faq-hero h1 {
		font-size: clamp(2.35rem, 12vw, 3.2rem);
	}

	.wb-faq-summary {
		border-radius: 0;
		border-width: 1px 0;
		box-shadow: none;
		margin: 0;
	}

	.wb-faq-categories {
		grid-template-columns: 1fr 1fr;
		padding: 0 18px;
	}

	.wb-faq-categories a {
		font-size: 0.88rem;
		padding: 12px 8px;
	}

	.wb-faq-groups {
		padding-left: 20px;
		padding-right: 20px;
	}

	.wb-faq-list summary {
		font-size: 1rem;
		gap: 12px;
		padding: 20px 2px;
	}

	.wb-faq-answer {
		gap: 12px;
		padding: 0 4px 22px 2px;
	}

	.wb-faq-separation .wp-block-columns {
		grid-template-columns: 1fr;
	}

	.wb-faq-actions {
		align-items: stretch;
		flex-direction: column;
	}

	.wb-faq-mobile-cta {
		align-items: center;
		background: var(--wb-faq-accent);
		border-radius: 999px;
		bottom: calc(10px + var(--wb-cookie-offset, 0px) + env(safe-area-inset-bottom));
		box-shadow: 0 8px 24px rgba(51, 43, 39, 0.28);
		color: var(--wb-faq-white);
		display: flex;
		font-weight: 700;
		justify-content: center;
		left: 16px;
		min-height: 54px;
		position: fixed;
		right: 16px;
		text-decoration: none;
		z-index: 9997;
	}
}
