:root {
	--ink: #1d1c18;
	--muted: #6e6a60;
	--paper: #fffaf0;
	--surface: #fff5df;
	--sun: #ffce57;
	--coral: #ff7d67;
	--leaf: #4aa078;
	--sky: #8ec7d2;
	--line: #28231c;
	--shadow: 8px 8px 0 rgba(29, 28, 24, 0.9);
	--radius: 8px;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body.warmwhim-storefront {
	margin: 0;
	background:
		linear-gradient(90deg, rgba(29, 28, 24, 0.04) 1px, transparent 1px),
		linear-gradient(rgba(29, 28, 24, 0.04) 1px, transparent 1px),
		var(--paper);
	background-size: 28px 28px;
	color: var(--ink);
	cursor: none;
	font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	line-height: 1.5;
}

body.warmwhim-storefront a,
body.warmwhim-storefront button,
body.warmwhim-storefront summary,
body.warmwhim-storefront [role="button"] {
	cursor: none;
}

body.warmwhim-storefront::before {
	content: "";
	position: fixed;
	left: 0;
	top: 0;
	width: 18rem;
	height: 18rem;
	pointer-events: none;
	background:
		radial-gradient(circle,
			rgba(255, 255, 214, 0.98) 0%,
			rgba(255, 220, 72, 0.88) 9%,
			rgba(255, 204, 42, 0.52) 24%,
			rgba(255, 204, 42, 0.22) 43%,
			rgba(255, 204, 42, 0) 72%);
	border-radius: 50%;
	filter: blur(12px) saturate(1.28);
	mix-blend-mode: multiply;
	opacity: var(--cursor-glow-opacity, 0);
	transform: translate3d(var(--cursor-x, 50vw), var(--cursor-y, 50vh), 0) translate(-50%, -50%) scale(var(--cursor-glow-scale, 1));
	transition: opacity 180ms ease;
	z-index: 2;
}

body.warmwhim-storefront::after {
	content: "";
	position: fixed;
	left: 0;
	top: 0;
	width: 1rem;
	height: 1rem;
	pointer-events: none;
	background: #fff8a8;
	border: 2px solid rgba(255, 205, 48, 0.95);
	border-radius: 50%;
	box-shadow:
		0 0 10px rgba(255, 244, 122, 1),
		0 0 28px rgba(255, 211, 45, 0.86),
		0 0 64px rgba(255, 211, 45, 0.55);
	opacity: var(--cursor-glow-opacity, 0);
	transform: translate3d(var(--cursor-x, 50vw), var(--cursor-y, 50vh), 0) translate(-50%, -50%);
	transition: opacity 180ms ease;
	z-index: 999;
}

.site-header,
main,
.site-footer {
	position: relative;
	z-index: 3;
}

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

a {
	color: inherit;
	text-decoration: none;
}

.skip-link {
	position: absolute;
	left: 1rem;
	top: -4rem;
	z-index: 20;
	background: var(--ink);
	color: #fff;
	padding: 0.75rem 1rem;
}

.skip-link:focus {
	top: 1rem;
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 10;
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 1rem;
	padding: 1rem clamp(1rem, 4vw, 3rem);
	background: rgba(255, 250, 240, 0.88);
	border-bottom: 2px solid var(--line);
	backdrop-filter: blur(12px);
	transition: padding 220ms ease, background-color 220ms ease, box-shadow 220ms ease;
}

.site-header.is-scrolled {
	padding-block: 0.72rem;
	background: rgba(255, 250, 240, 0.94);
	box-shadow: 0 10px 30px rgba(29, 28, 24, 0.08);
}

.brand,
.header-cta,
.site-nav {
	display: flex;
	align-items: center;
}

.brand {
	gap: 0.65rem;
	font-weight: 850;
	font-size: clamp(1.1rem, 2vw, 1.35rem);
}

.brand-mark {
	display: grid;
	place-items: center;
	width: 2.35rem;
	height: 2.35rem;
	background: var(--sun);
	border: 2px solid var(--line);
	border-radius: 50%;
	box-shadow: 3px 3px 0 var(--line);
}

.site-nav {
	justify-content: center;
	gap: clamp(0.8rem, 3vw, 2rem);
	color: var(--muted);
	font-size: 0.95rem;
}

.site-nav a:hover {
	color: var(--ink);
}

.site-nav a {
	position: relative;
	padding-block: 0.25rem;
}

.site-nav a::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -0.12rem;
	height: 2px;
	background: var(--ink);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 220ms ease;
}

.site-nav a:hover::after,
.site-nav a:focus-visible::after {
	transform: scaleX(1);
}

.header-cta {
	gap: 0.5rem;
	padding: 0.55rem 0.75rem;
	border: 2px solid var(--line);
	border-radius: 999px;
	background: #fff;
	font-size: 0.9rem;
	font-weight: 850;
	box-shadow: 3px 3px 0 var(--line);
	transition: transform 160ms ease, box-shadow 160ms ease;
}

.header-cta:hover {
	transform: translate(2px, 2px);
	box-shadow: 1px 1px 0 var(--line);
}

.section-shell {
	width: min(1160px, calc(100% - 2rem));
	margin-inline: auto;
}

.hero {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 0.86fr);
	gap: clamp(2rem, 6vw, 5rem);
	align-items: center;
	min-height: calc(100svh - 5rem);
	padding-block: clamp(2.5rem, 8vw, 5rem);
}

.eyebrow {
	margin: 0 0 0.85rem;
	color: var(--leaf);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0;
	text-transform: uppercase;
}

h1,
h2,
h3,
p {
	margin-top: 0;
}

h1 {
	max-width: 12ch;
	margin-bottom: 1rem;
	font-size: clamp(3.15rem, 8vw, 7.5rem);
	line-height: 0.91;
	letter-spacing: 0;
}

h2 {
	margin-bottom: 1rem;
	font-size: clamp(2rem, 4.5vw, 4.2rem);
	line-height: 1;
	letter-spacing: 0;
}

h3 {
	margin-bottom: 0.55rem;
	font-size: 1.35rem;
	line-height: 1.1;
}

.hero-text {
	max-width: 42rem;
	color: var(--muted);
	font-size: clamp(1.05rem, 2vw, 1.3rem);
}

.hero-actions,
.trust-list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.8rem;
}

.hero-actions {
	margin-top: 2rem;
}

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.25rem;
	padding: 0.85rem 1.2rem;
	border: 2px solid var(--line);
	border-radius: var(--radius);
	box-shadow: 4px 4px 0 var(--line);
	font-weight: 850;
	transition: transform 160ms ease, box-shadow 160ms ease, background-color 160ms ease;
}

.button:hover {
	transform: translate(2px, 2px);
	box-shadow: 2px 2px 0 var(--line);
}

.button.is-pressed {
	transform: translate(4px, 4px) scale(0.98);
	box-shadow: 0 0 0 var(--line);
}

.button-primary {
	background: var(--coral);
	color: #fff;
}

.button-secondary {
	background: #fff;
}

.trust-list {
	margin: 1.4rem 0 0;
	padding: 0;
	list-style: none;
	color: var(--muted);
	font-size: 0.95rem;
}

.trust-list li {
	position: relative;
	padding-left: 1.2rem;
}

.trust-list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.55rem;
	width: 0.45rem;
	height: 0.45rem;
	background: var(--leaf);
	border-radius: 50%;
}

.hero-art {
	position: relative;
	min-height: 520px;
}

.product-card {
	position: relative;
	overflow: hidden;
	border: 2px solid var(--line);
	border-radius: 18px;
	background: #fff;
	box-shadow: var(--shadow);
}

.product-card-main {
	--tilt-x: 0deg;
	--tilt-y: 0deg;
	--float-x: 0px;
	--float-y: 0px;
	width: min(420px, 86vw);
	margin-left: auto;
	transform: translate3d(var(--float-x), var(--float-y), 0) rotate(2deg) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
	transform-style: preserve-3d;
	transition: transform 260ms ease;
}

.product-card-main video.product-video,
.product-card-main img {
	aspect-ratio: 1 / 1;
	object-fit: cover;
}

.product-video {
	width: 100%;
	height: auto;
	display: block;
}

.product-showcase {
	padding-block: clamp(2rem, 5vw, 4rem);
	background: var(--surface);
}

.showcase-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
	align-items: center;
}

.showcase-media {
	position: relative;
	border: 2px solid var(--line);
	border-radius: 18px;
	overflow: hidden;
	box-shadow: var(--shadow);
}

.showcase-media img,
.showcase-media video {
	width: 100%;
	display: block;
}

.showcase-content h2 {
	margin-bottom: 0.75rem;
}

.showcase-content p {
	color: var(--muted);
	margin-bottom: 1.25rem;
}

.demo-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1rem;
	background: var(--ink);
	color: #fff;
	border: 2px solid var(--line);
	border-radius: 999px;
	font-weight: 850;
	font-size: 0.9rem;
	box-shadow: 4px 4px 0 var(--line);
	transition: transform 160ms ease, box-shadow 160ms ease;
}

.demo-link:hover {
	transform: translate(2px, 2px);
	box-shadow: 2px 2px 0 var(--line);
}

.product-sticker {
	position: absolute;
	right: 1rem;
	top: 1rem;
	padding: 0.45rem 0.7rem;
	background: var(--sun);
	border: 2px solid var(--line);
	border-radius: 999px;
	font-size: 0.8rem;
	font-weight: 900;
	animation: sticker-wiggle 5s ease-in-out infinite;
}

.sketch-grid {
	position: absolute;
	left: 0;
	bottom: 0.7rem;
	display: grid;
	grid-template-columns: repeat(2, 7rem);
	gap: 0.8rem;
	transform: rotate(-4deg);
}

.sketch-tile {
	position: relative;
	aspect-ratio: 1;
	background: #fff;
	border: 2px solid var(--line);
	border-radius: 14px;
	box-shadow: 4px 4px 0 var(--line);
	transition: transform 220ms ease, box-shadow 220ms ease;
}

.sketch-tile:hover {
	transform: translate(-2px, -2px) rotate(2deg);
	box-shadow: 7px 7px 0 var(--line);
}

.sketch-tile::before,
.sketch-tile::after {
	content: "";
	position: absolute;
	inset: 28%;
	border: 3px solid var(--line);
}

.tile-sun::before {
	background: var(--sun);
	border-radius: 50%;
}

.tile-heart::before {
	background: var(--coral);
	transform: rotate(45deg);
}

.tile-home::before {
	inset: 36% 24% 22%;
	background: var(--sky);
}

.tile-home::after {
	inset: 19% 24% auto;
	height: 40%;
	background: var(--sky);
	transform: rotate(45deg);
}

.tile-star::before {
	background: var(--leaf);
	clip-path: polygon(50% 0, 61% 35%, 98% 35%, 68% 56%, 80% 94%, 50% 70%, 20% 94%, 32% 56%, 2% 35%, 39% 35%);
}

.detail-section,
.reviews-section,
.faq-section,
.final-cta {
	padding-block: clamp(3.5rem, 8vw, 6rem);
}

.section-heading {
	display: grid;
	grid-template-columns: 0.9fr 1.1fr;
	gap: 2rem;
	align-items: end;
	margin-bottom: 2rem;
}

.section-heading.compact {
	display: block;
	max-width: 640px;
}

.feature-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
}

.feature,
.review-list blockquote,
.faq-list details {
	background: #fff;
	border: 2px solid var(--line);
	border-radius: var(--radius);
	box-shadow: 5px 5px 0 var(--line);
}

.feature {
	padding: 1.25rem;
	transition: transform 220ms ease, box-shadow 220ms ease;
}

.feature:hover {
	transform: translate(-3px, -3px);
	box-shadow: 8px 8px 0 var(--line);
}

.feature p,
.faq-list p,
.review-list p {
	color: var(--muted);
}

.feature-icon {
	display: block;
	position: relative;
	width: 3rem;
	height: 3rem;
	margin-bottom: 1rem;
	background: var(--surface);
	border: 2px solid var(--line);
	border-radius: 50%;
}

.feature-icon::before {
	content: "";
	position: absolute;
	inset: 0.8rem;
	border: 3px solid var(--line);
}

.gift-icon::before {
	background: var(--coral);
	border-radius: 4px;
}

.note-icon::before {
	background: var(--sun);
	transform: rotate(-8deg);
}

.truck-icon::before {
	background: var(--sky);
	border-radius: 999px;
}

.gallery-band {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	width: min(1160px, calc(100% - 2rem));
	margin-inline: auto;
}

.occasion-card {
	position: relative;
	overflow: hidden;
	min-height: 280px;
	border: 2px solid var(--line);
	border-radius: 18px;
	background: #fff;
	box-shadow: 5px 5px 0 var(--line);
	transition: transform 240ms ease, box-shadow 240ms ease;
}

.occasion-card img {
	width: 100%;
	height: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	transition: transform 520ms ease;
}

.occasion-card:hover {
	transform: translate(-3px, -3px) rotate(-1deg);
	box-shadow: 9px 9px 0 var(--line);
}

.occasion-card:hover img {
	transform: scale(1.05);
}

.occasion-card span {
	position: absolute;
	left: 1rem;
	bottom: 1rem;
	padding: 0.5rem 0.7rem;
	background: #fff;
	border: 2px solid var(--line);
	border-radius: 999px;
	font-weight: 900;
}

.reviews-section {
	display: grid;
	grid-template-columns: 0.9fr 1.1fr;
	gap: 2rem;
}

.review-list {
	display: grid;
	gap: 1rem;
}

.review-list blockquote {
	margin: 0;
	padding: 1.5rem;
	transition: transform 220ms ease, box-shadow 220ms ease;
}

.review-list blockquote:hover {
	transform: translate(-3px, -3px);
	box-shadow: 8px 8px 0 var(--line);
}

.review-list p {
	margin-bottom: 1rem;
	font-size: 1.3rem;
}

.review-list cite {
	font-style: normal;
	font-weight: 850;
}

.faq-list {
	display: grid;
	gap: 0.9rem;
}

.faq-list details {
	padding: 1rem 1.1rem;
	transition: transform 180ms ease, box-shadow 180ms ease;
}

.faq-list details[open] {
	transform: translate(-2px, -2px);
	box-shadow: 7px 7px 0 var(--line);
}

.faq-list summary {
	font-size: 1.08rem;
	font-weight: 850;
}

.faq-list p {
	margin: 0.85rem 0 0;
	max-width: 58rem;
	animation: faq-in 180ms ease both;
}

.final-cta {
	position: relative;
	display: grid;
	justify-items: center;
	gap: 1.25rem;
	margin-bottom: 3rem;
	padding: clamp(2.4rem, 7vw, 5rem) clamp(1.2rem, 4vw, 3rem);
	text-align: center;
	background: #fff;
	border: 2px solid var(--line);
	border-radius: 22px;
	box-shadow: var(--shadow);
	overflow: hidden;
	transition: transform 260ms ease, box-shadow 260ms ease;
}

.final-cta:hover {
	transform: translate(-3px, -3px);
	box-shadow: 11px 11px 0 rgba(29, 28, 24, 0.9);
}

.final-cta::before,
.final-cta::after {
	content: "";
	position: absolute;
	width: 8rem;
	height: 8rem;
	border: 2px solid var(--line);
	border-radius: 50%;
	background: var(--sun);
	z-index: 0;
}

.final-cta::before {
	left: -3rem;
	top: -3rem;
}

.final-cta::after {
	right: -3rem;
	bottom: -3rem;
	background: var(--sky);
}

.final-sketches,
.final-copy,
.final-cta .button {
	position: relative;
	z-index: 1;
}

.final-sketches {
	display: grid;
	grid-template-columns: repeat(3, 4.9rem);
	gap: 0.65rem;
	margin-bottom: 0.25rem;
	transform: rotate(-2deg);
}

.final-sketches .sketch-tile:nth-child(1) {
	animation: gentle-float 4.8s ease-in-out infinite;
}

.final-sketches .sketch-tile:nth-child(2) {
	animation: gentle-float 5.4s ease-in-out 0.4s infinite reverse;
}

.final-sketches .sketch-tile:nth-child(3) {
	animation: gentle-float 5s ease-in-out 0.8s infinite;
}

.motion-ready .reveal-item {
	transition:
		opacity 680ms ease,
		filter 680ms ease,
		transform 680ms cubic-bezier(0.22, 1, 0.36, 1);
	transition-delay: var(--reveal-delay, 0ms);
}

.motion-ready .reveal-item:not(.is-visible) {
	opacity: 0;
	filter: blur(8px);
	transform: translate3d(0, 28px, 0);
}

.motion-ready .reveal-item.is-visible {
	opacity: 1;
	filter: blur(0);
}

@keyframes gentle-float {
	0%,
	100% {
		transform: translateY(0) rotate(0);
	}

	50% {
		transform: translateY(-8px) rotate(2deg);
	}
}

@keyframes sticker-wiggle {
	0%,
	92%,
	100% {
		transform: rotate(0);
	}

	95% {
		transform: rotate(3deg);
	}

	98% {
		transform: rotate(-2deg);
	}
}

@keyframes faq-in {
	from {
		opacity: 0;
		transform: translateY(-4px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.final-copy {
	max-width: 680px;
}

.brand-script {
	margin: 0 0 0.25rem;
	font-size: clamp(1.45rem, 3vw, 2.2rem);
	font-weight: 900;
	line-height: 1;
}

.final-cta h2 {
	margin-bottom: 0.6rem;
	font-size: clamp(4rem, 10vw, 8.5rem);
	line-height: 0.86;
}

.final-cta p:not(.brand-script) {
	margin: 0 auto;
	max-width: 30rem;
	color: var(--muted);
	font-size: clamp(1rem, 2vw, 1.2rem);
}

.site-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 1.4rem clamp(1rem, 4vw, 3rem);
	border-top: 2px solid var(--line);
	background: var(--ink);
	color: #fff;
}

.site-footer p {
	margin: 0;
}

.site-footer nav {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	color: rgba(255, 255, 255, 0.76);
}

.checkout-view {
	min-height: 100vh;
	background:
		linear-gradient(90deg, rgba(29, 28, 24, 0.045) 1px, transparent 1px),
		linear-gradient(rgba(29, 28, 24, 0.045) 1px, transparent 1px),
		#fffdf8;
	background-size: 32px 32px;
}

.checkout-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	width: min(1220px, calc(100% - 2rem));
	margin: 0 auto;
	padding: 1.2rem 0;
}

.checkout-back {
	display: inline-flex;
	align-items: center;
	min-height: 2.7rem;
	padding: 0.55rem 0.85rem;
	border: 2px solid var(--line);
	border-radius: 999px;
	background: #fff;
	font-size: 0.92rem;
	font-weight: 850;
	box-shadow: 3px 3px 0 var(--line);
	transition: transform 160ms ease, box-shadow 160ms ease;
}

.checkout-back:hover {
	transform: translate(2px, 2px);
	box-shadow: 1px 1px 0 var(--line);
}

.checkout-layout {
	width: min(1220px, calc(100% - 2rem));
	margin: 0 auto;
	padding: clamp(1rem, 4vw, 2.5rem) 0 4rem;
}

.checkout-intro {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.75fr);
	gap: 1.5rem;
	align-items: end;
	margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
}

.checkout-intro h1 {
	max-width: 9ch;
	margin-bottom: 0;
	font-size: clamp(4rem, 11vw, 9.5rem);
	line-height: 0.82;
}

.checkout-intro p:last-child {
	max-width: 34rem;
	margin-bottom: 0.4rem;
	color: var(--muted);
	font-size: clamp(1rem, 2vw, 1.18rem);
}

.checkout-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.62fr);
	gap: 1rem;
	align-items: start;
}

.checkout-panel {
	background: #fff;
	border: 2px solid var(--line);
	border-radius: 14px;
	box-shadow: var(--shadow);
}

.checkout-form-panel {
	padding: clamp(1rem, 3vw, 1.5rem);
}

.checkout-summary {
	position: sticky;
	top: 1rem;
	padding: clamp(1rem, 3vw, 1.4rem);
	background: var(--ink);
	color: #fff;
}

.checkout-panel-heading {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1rem;
	padding-bottom: 0.9rem;
	border-bottom: 2px solid currentColor;
}

.checkout-panel-heading span {
	display: grid;
	place-items: center;
	width: 2.25rem;
	height: 2.25rem;
	border: 2px solid currentColor;
	border-radius: 50%;
	font-size: 0.8rem;
	font-weight: 950;
}

.checkout-panel-heading h2 {
	margin: 0;
	font-size: clamp(1.65rem, 3vw, 2.4rem);
}

.summary-product {
	display: grid;
	grid-template-columns: 4.8rem minmax(0, 1fr) auto;
	gap: 0.85rem;
	align-items: center;
	padding: 0.8rem;
	background: rgba(255, 255, 255, 0.08);
	border: 2px solid rgba(255, 255, 255, 0.2);
	border-radius: 10px;
}

.summary-product img {
	width: 4.8rem;
	aspect-ratio: 1;
	object-fit: cover;
	border: 2px solid rgba(255, 255, 255, 0.42);
	border-radius: 8px;
}

.summary-product strong,
.summary-product span {
	display: block;
}

.summary-product span {
	margin-top: 0.16rem;
	color: rgba(255, 255, 255, 0.64);
	font-size: 0.88rem;
}

.summary-product b {
	font-size: 1.2rem;
}

.summary-lines {
	display: grid;
	gap: 0.8rem;
	margin-top: 1.2rem;
}

.summary-lines div {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	color: rgba(255, 255, 255, 0.72);
}

.summary-lines strong {
	color: #fff;
}

.summary-total {
	margin-top: 0.45rem;
	padding-top: 1rem;
	border-top: 2px solid rgba(255, 255, 255, 0.24);
	font-size: 1.35rem;
}

.summary-note {
	display: flex;
	gap: 0.75rem;
	margin-top: 1.35rem;
	padding: 0.9rem;
	background: rgba(255, 206, 87, 0.13);
	border: 2px solid rgba(255, 206, 87, 0.44);
	border-radius: 10px;
}

.summary-note p {
	margin: 0;
	color: rgba(255, 255, 255, 0.76);
	font-size: 0.92rem;
}

.note-dot {
	flex: 0 0 auto;
	width: 0.72rem;
	height: 0.72rem;
	margin-top: 0.36rem;
	background: var(--sun);
	border-radius: 50%;
	box-shadow: 0 0 18px rgba(255, 206, 87, 0.95);
}

.checkout-placeholder,
.payment-box {
	padding: 1rem;
	background: #fff;
	border: 1px solid rgba(29, 28, 24, 0.18);
	border-radius: 10px;
}

.checkout-placeholder p,
.payment-box p {
	margin: 0.35rem 0 0;
	color: var(--muted);
}

.payment-methods {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 0.55rem;
	margin-top: 0.95rem;
}

.payment-method {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.55rem;
	align-items: center;
	min-height: 8.2rem;
	padding: 0.85rem;
	background: #fff;
	border: 1px solid rgba(29, 28, 24, 0.2);
	border-radius: 8px;
	box-shadow: none;
	transition: transform 180ms ease, border-color 180ms ease, background-color 180ms ease;
}

.payment-method:hover,
.payment-method.is-selected {
	transform: translateY(-2px);
	background: #fffaf0;
	border-color: var(--line);
}

.payment-method input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.payment-method span,
.payment-method strong,
.payment-method small {
	display: block;
}

.payment-method small {
	margin-top: 0.12rem;
	color: var(--muted);
	font-size: 0.78rem;
	line-height: 1.25;
}

.payment-method i {
	display: inline-grid;
	place-items: center;
	width: 2.6rem;
	height: 2.6rem;
	background: #f7f1e5;
	border: 1px solid rgba(29, 28, 24, 0.22);
	border-radius: 50%;
	color: var(--ink);
	font-size: 0.72rem;
	font-style: normal;
	font-weight: 900;
}

.payment-method.is-selected i {
	background: var(--ink);
	border-color: var(--ink);
	color: #fff;
	box-shadow: 0 0 0 4px rgba(255, 206, 87, 0.36);
}

.payment-method.is-selected strong::after {
	content: "";
	display: inline-block;
	width: 0.42rem;
	height: 0.42rem;
	margin-left: 0.38rem;
	background: var(--coral);
	border-radius: 50%;
	vertical-align: middle;
}

.mock-checkout-form,
.woocommerce-checkout {
	display: grid;
	gap: 1rem;
}

.mock-checkout-form label,
.woocommerce-checkout .form-row {
	display: grid;
	gap: 0.35rem;
	margin: 0;
}

.mock-checkout-form span,
.woocommerce-checkout label {
	font-size: 0.86rem;
	font-weight: 900;
}

.mock-checkout-form input,
.woocommerce-checkout input.input-text,
.woocommerce-checkout textarea,
.woocommerce-checkout select {
	width: 100%;
	min-height: 3.2rem;
	padding: 0.75rem 0.85rem;
	background: #fffdf8;
	border: 2px solid var(--line);
	border-radius: 8px;
	color: var(--ink);
	font: inherit;
	box-shadow: 3px 3px 0 rgba(29, 28, 24, 0.16);
	transition: box-shadow 160ms ease, transform 160ms ease;
}

.mock-checkout-form input:focus,
.woocommerce-checkout input.input-text:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus {
	outline: none;
	transform: translate(-1px, -1px);
	box-shadow: 5px 5px 0 rgba(29, 28, 24, 0.25);
}

.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.8rem;
}

.woocommerce-checkout #customer_details,
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper,
.woocommerce-checkout .woocommerce-additional-fields__field-wrapper {
	display: grid;
	gap: 0.9rem;
}

.woocommerce-checkout h3 {
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 2px solid var(--line);
}

.woocommerce-checkout-review-order,
.woocommerce-checkout-payment {
	margin-top: 1rem;
	padding: 1rem;
	background: var(--surface);
	border: 2px solid var(--line);
	border-radius: 10px;
}

.woocommerce-checkout button.button,
.woocommerce-checkout #place_order {
	width: 100%;
	min-height: 3.35rem;
	background: var(--coral);
	border: 2px solid var(--line);
	border-radius: var(--radius);
	color: #fff;
	font-weight: 900;
	box-shadow: 4px 4px 0 var(--line);
}

@media (max-width: 880px) {
	.site-header {
		grid-template-columns: 1fr auto;
	}

	.site-nav {
		display: none;
	}

	.hero,
	.reviews-section,
	.section-heading {
		grid-template-columns: 1fr;
	}

	.hero {
		min-height: auto;
		padding-top: 2rem;
	}

	.hero-art {
		min-height: 410px;
	}

	.product-card-main {
		margin-inline: auto;
	}

	.sketch-grid {
		left: 50%;
		grid-template-columns: repeat(4, 4.7rem);
		transform: translateX(-50%) rotate(-3deg);
	}

	.feature-grid,
	.gallery-band {
		grid-template-columns: 1fr;
	}

	.site-footer {
		align-items: flex-start;
		flex-direction: column;
	}

	.checkout-intro,
	.checkout-grid {
		grid-template-columns: 1fr;
	}

	.checkout-summary {
		position: static;
	}
}

@media (max-width: 560px) {
	.site-header {
		padding-inline: 0.8rem;
	}

	.brand span:last-child {
		display: none;
	}

	h1 {
		font-size: clamp(3rem, 18vw, 4.5rem);
	}

	.hero-actions .button,
	.final-cta .button {
		width: 100%;
	}

	.final-sketches {
		grid-template-columns: repeat(3, minmax(3.7rem, 1fr));
		width: min(100%, 16rem);
	}

	.hero-art {
		min-height: 360px;
	}

	.sketch-grid {
		grid-template-columns: repeat(4, minmax(3.7rem, 1fr));
		width: 100%;
	}

	.checkout-header {
		align-items: flex-start;
		flex-direction: column;
	}

	.checkout-intro h1 {
		font-size: clamp(3.5rem, 19vw, 5.2rem);
	}

	.form-row,
	.summary-product,
	.payment-methods {
		grid-template-columns: 1fr;
	}

	.payment-method {
		min-height: auto;
		grid-template-columns: auto minmax(0, 1fr);
	}

	.summary-product b {
		justify-self: start;
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
		transition-duration: 0.01ms !important;
	}

	body.warmwhim-storefront::before {
		display: none;
	}

	body.warmwhim-storefront {
		cursor: auto;
	}

	body.warmwhim-storefront a,
	body.warmwhim-storefront button,
	body.warmwhim-storefront summary,
	body.warmwhim-storefront [role="button"] {
		cursor: auto;
	}

	body.warmwhim-storefront::after {
		display: none;
	}

	.motion-ready .reveal-item,
	.motion-ready .reveal-item.is-visible {
		opacity: 1;
		filter: none;
		transform: none;
	}
}

/* Visual refinement: lighter borders, softer elevation, less cartoon weight. */
:root {
	--line: #3a352e;
	--soft-line: rgba(58, 53, 46, 0.2);
	--shadow: 0 18px 46px rgba(61, 49, 30, 0.13);
	--lift-shadow: 0 22px 58px rgba(61, 49, 30, 0.18);
}

.site-header {
	border-bottom-width: 1px;
	border-bottom-color: var(--soft-line);
}

.brand-mark,
.header-cta,
.button,
.product-card,
.product-sticker,
.sketch-tile,
.feature,
.review-list blockquote,
.faq-list details,
.feature-icon,
.occasion-card,
.occasion-card span,
.final-cta,
.checkout-back,
.checkout-panel,
.summary-product,
.summary-product img,
.summary-note,
.mock-checkout-form input,
.woocommerce-checkout input.input-text,
.woocommerce-checkout textarea,
.woocommerce-checkout select,
.woocommerce-checkout-review-order,
.woocommerce-checkout-payment,
.woocommerce-checkout button.button,
.woocommerce-checkout #place_order {
	border-width: 1px;
}

.brand-mark,
.header-cta,
.button,
.sketch-tile,
.feature,
.review-list blockquote,
.faq-list details,
.occasion-card,
.final-cta,
.checkout-back,
.checkout-panel {
	box-shadow: var(--shadow);
}

.header-cta:hover,
.button:hover,
.sketch-tile:hover,
.feature:hover,
.review-list blockquote:hover,
.faq-list details[open],
.occasion-card:hover,
.final-cta:hover,
.checkout-back:hover {
	transform: translateY(-2px);
	box-shadow: var(--lift-shadow);
}

.button.is-pressed {
	transform: translateY(1px) scale(0.985);
	box-shadow: 0 8px 22px rgba(61, 49, 30, 0.12);
}

.sketch-tile::before,
.sketch-tile::after,
.feature-icon::before {
	border-width: 2px;
}

.checkout-panel-heading {
	border-bottom-width: 1px;
}

.checkout-panel-heading span {
	border-width: 1px;
}

.summary-total {
	border-top-width: 1px;
}

.mock-checkout-form input,
.woocommerce-checkout input.input-text,
.woocommerce-checkout textarea,
.woocommerce-checkout select {
	border-color: var(--soft-line);
	box-shadow: 0 8px 20px rgba(61, 49, 30, 0.08);
}

.mock-checkout-form input:focus,
.woocommerce-checkout input.input-text:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus {
	transform: translateY(-1px);
	border-color: rgba(58, 53, 46, 0.5);
	box-shadow: 0 12px 28px rgba(61, 49, 30, 0.13);
}

.summary-item-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 5.8rem;
	gap: 0.7rem;
	margin-top: 0.9rem;
	padding: 0.8rem;
	background: rgba(255, 255, 255, 0.065);
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 10px;
}

.summary-item-rows {
	display: grid;
	gap: 0.65rem;
	margin-top: 0.8rem;
}

.summary-item-row.is-clone {
	margin-top: 0;
}

.summary-item-row label {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
}

.summary-add {
	display: inline-flex;
	align-items: center;
	gap: 0.65rem;
	margin-top: 0.7rem;
	padding: 0.65rem 0.85rem;
	background: rgba(255, 255, 255, 0.08);
	border: 1px dashed rgba(255, 255, 255, 0.26);
	border-radius: 999px;
	color: rgba(255, 255, 255, 0.88);
	font-weight: 900;
	transition: transform 160ms ease, background-color 160ms ease, border-color 160ms ease;
}

.summary-add span {
	display: inline-grid;
	place-items: center;
	width: 1.75rem;
	height: 1.75rem;
	background: var(--sun);
	border-radius: 50%;
	color: var(--ink);
	font-size: 1rem;
	line-height: 1;
}

.summary-add:hover {
	transform: translateY(-1px);
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.36);
}

.summary-options label {
	display: grid;
	gap: 0.35rem;
}

.summary-options span {
	color: rgba(255, 255, 255, 0.58);
	font-size: 0.76rem;
	font-weight: 850;
}

.summary-options select,
.summary-options input {
	width: 100%;
	min-height: 2.65rem;
	padding: 0.58rem 0.65rem;
	background: rgba(255, 255, 255, 0.94);
	border: 1px solid rgba(255, 255, 255, 0.34);
	border-radius: 8px;
	color: var(--ink);
	font: inherit;
}

@media (max-width: 560px) {
	.summary-item-row {
		grid-template-columns: 1fr;
	}
}
