/**
 * GENE Blocks Studio — `warm` aesthetic (Hospitality).
 *
 * Inviting and generous: cream backgrounds, soft rounded cards, a serif
 * headline voice and a warm palette-driven accent. Used by hospitality-style
 * industries (restaurant / cafe / salon / spa / local business).
 * All rules scoped under `.gene-aesthetic--warm`.
 */

/* ============================================================
   Tokens & base.
   ============================================================ */
.gene-aesthetic--warm {
	--gw-paper: #fffaf4;
	--gw-surface: #f6ece1;
	--gw-card: #fffdfa;
	--gw-ink: #2e2620;
	--gw-ink-soft: #6f6358;
	--gw-line: #e7d9c9;
	/* Accent follows the chosen palette; a warm terracotta is the fallback. */
	--gw-accent: var(--gene-accent, #d97a45);
	--gw-accent-strong: var(--gene-accent-strong, #b85f30);
	--gw-on-accent: var(--gene-on-accent, #ffffff);

	color: var(--gw-ink);
}

.gene-aesthetic--warm :where(h1, h2, h3, h4).wp-block-heading {
	color: var(--gw-ink) !important;
	font-family: Georgia, "Times New Roman", serif !important;
	font-weight: 600 !important;
	letter-spacing: -0.01em !important;
	line-height: 1.15 !important;
}

.gene-aesthetic--warm p { color: var(--gw-ink); }

/* Eyebrow / kicker — warm accent, spaced caps. */
.gene-aesthetic--warm .gene-wm-eyebrow {
	margin: 0 0 0.9rem;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--gw-accent);
}

/* Buttons — soft pill. Solid accent or warm outline. */
.gene-aesthetic--warm .wp-block-button__link {
	border-radius: 999px !important;
	padding: 0.85em 1.9em !important;
	font-weight: 600;
	border: 1.5px solid transparent;
}
.gene-aesthetic--warm .gene-wm-btn--solid .wp-block-button__link {
	background: var(--gw-accent) !important;
	color: var(--gw-on-accent) !important;
	border-color: var(--gw-accent) !important;
}
.gene-aesthetic--warm .gene-wm-btn--solid .wp-block-button__link:hover {
	background: var(--gw-accent-strong) !important;
	border-color: var(--gw-accent-strong) !important;
}
.gene-aesthetic--warm .gene-wm-btn--outline .wp-block-button__link {
	background: transparent !important;
	color: var(--gw-ink) !important;
	border-color: var(--gw-line) !important;
}
.gene-aesthetic--warm .gene-wm-btn--outline .wp-block-button__link:hover {
	border-color: var(--gw-accent) !important;
	color: var(--gw-accent) !important;
}

/* ============================================================
   Hero — centered welcome + wide rounded image.
   ============================================================ */
.gene-aesthetic--warm.gene-wm-hero {
	background: var(--gw-paper);
	text-align: center;
}
.gene-aesthetic--warm .gene-wm-hero-inner { max-width: 760px; margin-inline: auto; }
.gene-aesthetic--warm .gene-wm-hero h1.wp-block-heading {
	font-size: clamp(2.4rem, 5.5vw, 4rem) !important;
}
.gene-aesthetic--warm .gene-wm-hero-lead {
	max-width: 560px;
	margin: 1.2rem auto 0;
	font-size: 1.1rem;
	line-height: 1.7;
	color: var(--gw-ink-soft);
}
.gene-aesthetic--warm .gene-wm-hero .wp-block-buttons { justify-content: center; margin-top: 1.8rem; gap: 0.8rem; }
.gene-aesthetic--warm .gene-wm-hero-img img {
	width: 100%;
	margin-top: 2.5rem;
	border-radius: 22px;
	display: block;
}

/* ============================================================
   Section base + shared headings.
   ============================================================ */
.gene-aesthetic--warm.gene-wm-services,
.gene-aesthetic--warm.gene-wm-team { background: var(--gw-paper); }
.gene-aesthetic--warm.gene-wm-pricing,
.gene-aesthetic--warm.gene-wm-quotes { background: var(--gw-surface); }
.gene-aesthetic--warm h2.wp-block-heading {
	font-size: clamp(1.8rem, 3.4vw, 2.6rem) !important;
}

/* Services — soft rounded cards. */
.gene-aesthetic--warm .gene-wm-cards { gap: 1.5rem; }
.gene-aesthetic--warm .gene-wm-card {
	height: 100%;
	background: var(--gw-card);
	border: 1px solid var(--gw-line);
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 14px 30px -22px rgba(46, 38, 32, 0.5);
}
.gene-aesthetic--warm .gene-wm-card img { width: 100%; display: block; }
.gene-aesthetic--warm .gene-wm-card-body { padding: 1.5rem 1.6rem 1.7rem; }
.gene-aesthetic--warm .gene-wm-card-body h3 { margin: 0 0 0.5rem !important; }
.gene-aesthetic--warm .gene-wm-card-body p { margin: 0; color: var(--gw-ink-soft); line-height: 1.6; }

/* Pricing — warm plan cards. */
.gene-aesthetic--warm .gene-wm-pricegrid { gap: 1.5rem; align-items: stretch; }
.gene-aesthetic--warm .gene-wm-plan {
	height: 100%;
	display: flex;
	flex-direction: column;
	background: var(--gw-card);
	border: 1px solid var(--gw-line);
	border-radius: 18px;
	padding: clamp(1.6rem, 3vw, 2.1rem);
	text-align: center;
}
.gene-aesthetic--warm .gene-wm-plan--featured {
	border-color: var(--gw-accent);
	box-shadow: 0 18px 40px -22px rgba(46, 38, 32, 0.55);
}
.gene-aesthetic--warm .gene-wm-plan-name {
	margin: 0 0 0.5rem;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--gw-ink-soft);
}
.gene-aesthetic--warm .gene-wm-price {
	margin: 0 0 0.8rem;
	font-family: Georgia, serif;
	font-size: 2.3rem;
	color: var(--gw-ink);
}
.gene-aesthetic--warm .gene-wm-plan-feat { margin: 0 0 1.3rem; color: var(--gw-ink-soft); line-height: 1.9; }
.gene-aesthetic--warm .gene-wm-plan .wp-block-buttons { justify-content: center; margin-top: auto; }

/* Testimonials — warm quote cards. */
.gene-aesthetic--warm .gene-wm-quotegrid { gap: 1.5rem; }
.gene-aesthetic--warm .gene-wm-quote {
	height: 100%;
	background: var(--gw-card);
	border: 1px solid var(--gw-line);
	border-radius: 18px;
	padding: 1.8rem;
}
.gene-aesthetic--warm .gene-wm-quote-text {
	margin: 0 0 1rem;
	font-family: Georgia, serif;
	font-size: 1.1rem;
	line-height: 1.5;
	color: var(--gw-ink);
}
.gene-aesthetic--warm .gene-wm-quote-name { margin: 0; font-weight: 600; color: var(--gw-ink); }

/* Team — rounded portraits. */
.gene-aesthetic--warm .gene-wm-roster { gap: 1.5rem; }
.gene-aesthetic--warm .gene-wm-member img { width: 100%; aspect-ratio: 1/1; object-fit: cover; border-radius: 16px; }
.gene-aesthetic--warm .gene-wm-name { margin: 0.9rem 0 0.1rem; font-weight: 600; }
.gene-aesthetic--warm .gene-wm-role { margin: 0; color: var(--gw-ink-soft); font-size: 0.9rem; }

/* CTA — warm band. */
.gene-aesthetic--warm.gene-wm-cta { background: var(--gw-surface); text-align: center; }
.gene-aesthetic--warm .gene-wm-cta-inner { max-width: 680px; margin-inline: auto; }
.gene-aesthetic--warm .gene-wm-cta p { color: var(--gw-ink-soft); font-size: 1.05rem; margin: 1rem auto 0; max-width: 520px; }
.gene-aesthetic--warm .gene-wm-cta .wp-block-buttons { justify-content: center; margin-top: 1.6rem; }

/* Footer — warm dark band. */
.gene-aesthetic--warm.gene-wm-footer { background: #2e2620; color: #f4ece2; }
.gene-aesthetic--warm .gene-wm-footer h2.wp-block-heading,
.gene-aesthetic--warm .gene-wm-foot-brand { color: #fffaf4 !important; }
.gene-aesthetic--warm .gene-wm-foot-brand { margin: 0 0 0.7rem; font-family: Georgia, serif; font-size: 1.3rem; }
.gene-aesthetic--warm .gene-wm-foot-note { max-width: 260px; color: rgba(244, 236, 226, 0.65); line-height: 1.6; }
.gene-aesthetic--warm .gene-wm-foot-h { margin: 0 0 0.9rem; font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(244, 236, 226, 0.5); }
.gene-aesthetic--warm .gene-wm-foot-link { margin: 0 0 0.5rem; color: rgba(244, 236, 226, 0.82); }

/* ============================================================
   Page-builder sections — About (story / values), Services
   (features) and Contact (contact / hours).
   ============================================================ */

/* About — story */
.gene-aesthetic--warm.gene-wm-story { background: var(--gw-paper); }
.gene-aesthetic--warm .gene-wm-story-img img { width: 100%; border-radius: 20px; display: block; }
.gene-aesthetic--warm .gene-wm-story-body p {
	margin: 0 0 1rem;
	color: var(--gw-ink-soft);
	font-size: 1.05rem;
	line-height: 1.7;
	max-width: 520px;
}

/* About — values */
.gene-aesthetic--warm.gene-wm-values { background: var(--gw-surface); }
.gene-aesthetic--warm .gene-wm-valgrid { gap: 1.5rem; }
.gene-aesthetic--warm .gene-wm-valcard {
	height: 100%;
	background: var(--gw-card);
	border: 1px solid var(--gw-line);
	border-radius: 18px;
	padding: clamp(1.5rem, 3vw, 2rem);
}
.gene-aesthetic--warm .gene-wm-valcard h3 { margin: 0 0 0.5rem !important; }
.gene-aesthetic--warm .gene-wm-valcard p { margin: 0; color: var(--gw-ink-soft); line-height: 1.65; }

/* Services — features */
.gene-aesthetic--warm.gene-wm-features { background: var(--gw-paper); }
.gene-aesthetic--warm .gene-wm-featgrid { gap: 1.5rem; }
.gene-aesthetic--warm .gene-wm-feat-k {
	margin: 0 0 0.4rem;
	font-family: Georgia, serif;
	font-size: 1.4rem;
	color: var(--gw-accent);
}
.gene-aesthetic--warm .gene-wm-feat h3 { margin: 0 0 0.4rem !important; }
.gene-aesthetic--warm .gene-wm-feat p { margin: 0; color: var(--gw-ink-soft); line-height: 1.6; }

/* Contact — intro + form */
.gene-aesthetic--warm.gene-wm-contact { background: var(--gw-paper); }
.gene-aesthetic--warm .gene-wm-contact-lead {
	margin: 0.5rem auto 2rem;
	max-width: 560px;
	color: var(--gw-ink-soft);
	font-size: 1.05rem;
}

/* Contact — hours / address */
.gene-aesthetic--warm.gene-wm-hours { background: var(--gw-surface); }
.gene-aesthetic--warm .gene-wm-hours-grid { gap: 2rem; }
.gene-aesthetic--warm .gene-wm-hours h3 { margin: 0 0 0.6rem !important; }
.gene-aesthetic--warm .gene-wm-hours-line { margin: 0; color: var(--gw-ink-soft); line-height: 1.9; }

/* Signature — food menu (categories + dishes). */
.gene-aesthetic--warm.gene-wm-menu { background: var(--gw-paper); }
.gene-aesthetic--warm .gene-wm-menu-cat h3 {
	margin: 0 0 0.5rem !important;
	padding-bottom: 0.5rem;
	border-bottom: 2px solid var(--gw-accent);
	color: var(--gw-accent) !important;
}
.gene-aesthetic--warm .gene-wm-dish {
	padding: 0.85rem 0;
	border-bottom: 1px dashed var(--gw-line);
}
.gene-aesthetic--warm .gene-wm-dish-head {
	align-items: baseline;
	gap: 1rem;
}
.gene-aesthetic--warm .gene-wm-dish-name { margin: 0; font-weight: 600; color: var(--gw-ink); }
.gene-aesthetic--warm .gene-wm-dish-price {
	margin: 0;
	font-family: Georgia, serif;
	font-weight: 600;
	color: var(--gw-accent);
	white-space: nowrap;
}
.gene-aesthetic--warm .gene-wm-dish-desc { margin: 0.2rem 0 0; color: var(--gw-ink-soft); font-size: 0.95rem; line-height: 1.5; }

@media (max-width: 781px) {
	.gene-aesthetic--warm .gene-wm-cards,
	.gene-aesthetic--warm .gene-wm-pricegrid,
	.gene-aesthetic--warm .gene-wm-quotegrid,
	.gene-aesthetic--warm .gene-wm-roster,
	.gene-aesthetic--warm .gene-wm-valgrid,
	.gene-aesthetic--warm .gene-wm-featgrid { gap: 1rem; }
}

/* Header — brand + nav + CTA */
.gene-aesthetic--warm.gene-wm-header { background: var(--gw-paper); border-bottom: 1px solid var(--gw-line); }
.gene-aesthetic--warm .gene-wm-header-row { align-items: center; gap: 1.5rem; }
.gene-aesthetic--warm .gene-wm-brand { margin: 0; font-family: Georgia, serif; font-size: 1.3rem; color: var(--gw-ink); }
.gene-aesthetic--warm .gene-wm-nav { gap: 1.6rem; align-items: center; flex-wrap: wrap; }
.gene-aesthetic--warm .gene-wm-navlink { margin: 0; font-size: 0.95rem; color: var(--gw-ink-soft); cursor: pointer; }
.gene-aesthetic--warm .gene-wm-navlink:hover { color: var(--gw-accent); }
.gene-aesthetic--warm .gene-wm-header .wp-block-button__link { padding: 0.6em 1.4em !important; }

/* ============================================================
   Split section — center the About story text block beside the image.
   ============================================================ */
.gene-aesthetic--warm .gene-wm-story-body {
	text-align: center;
}
.gene-aesthetic--warm .gene-wm-story-body p {
	margin-left: auto;
	margin-right: auto;
}
.gene-aesthetic--warm .gene-wm-story-body .wp-block-buttons {
	justify-content: center;
}

/* ============================================================
   Sections added for "all sections in every industry" (s24):
   logos / stats / compare(spotlight) / qa(faq) / portfolio(work).
   Cream, soft, terracotta accent.
   ============================================================ */
.gene-aesthetic--warm.gene-wm-logos,
.gene-aesthetic--warm.gene-wm-spotlight,
.gene-aesthetic--warm.gene-wm-work { background: var(--gw-surface); }
.gene-aesthetic--warm.gene-wm-stats,
.gene-aesthetic--warm.gene-wm-faq { background: var(--gw-paper); }

/* Logos */
.gene-aesthetic--warm .gene-wm-logo-row { align-items: center; }
.gene-aesthetic--warm .gene-wm-logo {
	height: 32px;
	background: var(--gw-line);
	border-radius: 6px;
}

/* Stats */
.gene-aesthetic--warm .gene-wm-stat-num {
	margin: 0;
	font-size: clamp(2.2rem, 4vw, 3rem);
	font-weight: 800;
	letter-spacing: -0.02em;
	color: var(--gw-accent);
}
.gene-aesthetic--warm .gene-wm-stat-label {
	margin: 0.35rem 0 0;
	font-size: 0.9rem;
	color: var(--gw-ink-soft);
}

/* Compare — split image + claim */
.gene-aesthetic--warm.gene-wm-spotlight img {
	width: 100%;
	border-radius: 12px;
	display: block;
}
.gene-aesthetic--warm .gene-wm-spot-body {
	text-align: center;
	padding: clamp(2rem, 5vw, 4rem);
}
.gene-aesthetic--warm .gene-wm-spot-body p {
	margin-inline: auto;
	max-width: 460px;
	color: var(--gw-ink-soft);
	line-height: 1.7;
}
.gene-aesthetic--warm .gene-wm-spot-body .wp-block-buttons { justify-content: center; }

/* FAQ */
.gene-aesthetic--warm .gene-wm-q {
	margin: 0 0 0.7rem;
	padding: 0.95rem 1.3rem;
	background: var(--gw-card);
	border: 1px solid var(--gw-line);
	border-radius: 10px;
}
.gene-aesthetic--warm .gene-wm-q summary {
	cursor: pointer;
	font-weight: 700;
	color: var(--gw-ink);
	list-style: none;
}
.gene-aesthetic--warm .gene-wm-q summary::-webkit-details-marker { display: none; }
.gene-aesthetic--warm .gene-wm-q p {
	margin: 0.7rem 0 0;
	color: var(--gw-ink-soft);
	line-height: 1.6;
}

/* Portfolio — work grid */
.gene-aesthetic--warm .gene-wm-workgrid { gap: 1.25rem !important; }
.gene-aesthetic--warm .gene-wm-work-item {
	background: var(--gw-card);
	border: 1px solid var(--gw-line);
	border-radius: 12px;
	overflow: hidden;
}
.gene-aesthetic--warm .gene-wm-work-item img {
	width: 100%;
	height: 180px;
	object-fit: cover;
	display: block;
}
.gene-aesthetic--warm .gene-wm-work-title {
	margin: 1rem 1.2rem 0.2rem;
	font-weight: 700;
	font-size: 1.1rem;
	color: var(--gw-ink);
}
.gene-aesthetic--warm .gene-wm-work-cat {
	margin: 0 1.2rem 1.2rem;
	font-size: 0.85rem;
	color: var(--gw-accent);
}

/* Page intro — slim sub-page header band (eyebrow + H1 + one line). */
.gene-aesthetic--warm.gene-wm-pageintro {
	background: var(--gw-paper);
	border-bottom: 1px solid var(--gw-line, rgba(0, 0, 0, 0.08));
}
.gene-aesthetic--warm .gene-wm-pageintro-sub {
	margin: 0.9rem auto 0;
	max-width: 60ch;
	color: var(--gw-ink-soft);
	line-height: 1.7;
}

/* ---- polish (chunk 5): keyboard focus, smoother interactions, card lift ---- */
.gene-aesthetic--warm a:focus-visible,
.gene-aesthetic--warm .wp-block-button__link:focus-visible {
	outline: 2px solid var(--gw-accent);
	outline-offset: 3px;
	border-radius: 4px;
}
.gene-aesthetic--warm .wp-block-button__link {
	transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}
.gene-aesthetic--warm .gene-wm-navlink { transition: color 0.16s ease; }
.gene-aesthetic--warm .gene-wm-card,
.gene-aesthetic--warm .gene-wm-member img {
	transition: transform 0.22s ease, box-shadow 0.22s ease;
}
.gene-aesthetic--warm .gene-wm-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 22px 44px -24px rgba(46, 38, 32, 0.6);
}
@media (prefers-reduced-motion: reduce) {
	.gene-aesthetic--warm .wp-block-button__link,
	.gene-aesthetic--warm .gene-wm-navlink,
	.gene-aesthetic--warm .gene-wm-card,
	.gene-aesthetic--warm .gene-wm-member img { transition: none; }
	.gene-aesthetic--warm .gene-wm-card:hover { transform: none; }
}

/* Posts — latest articles band (core/latest-posts). Warm cards. */
.gene-aesthetic--warm.gene-wm-posts { background: var(--gw-paper); }
.gene-aesthetic--warm .wp-block-latest-posts.is-grid {
	list-style: none; padding: 0; margin: 2.5rem 0 0;
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem;
}
.gene-aesthetic--warm .wp-block-latest-posts.is-grid > li {
	margin: 0; background: var(--gw-card); border-radius: 18px; overflow: hidden;
	box-shadow: 0 14px 30px -22px rgba(46, 38, 32, 0.5);
	transition: transform 0.22s ease, box-shadow 0.22s ease;
}
.gene-aesthetic--warm .wp-block-latest-posts.is-grid > li:hover {
	transform: translateY(-4px); box-shadow: 0 22px 44px -24px rgba(46, 38, 32, 0.6);
}
.gene-aesthetic--warm .wp-block-latest-posts__featured-image img { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; display: block; }
.gene-aesthetic--warm .wp-block-latest-posts__post-title { display: block; padding: 1.2rem 1.4rem 0; color: var(--gw-ink); font-weight: 700; font-size: 1.12rem; text-decoration: none; line-height: 1.3; }
.gene-aesthetic--warm .wp-block-latest-posts__post-title:hover { color: var(--gw-accent); }
.gene-aesthetic--warm .wp-block-latest-posts__post-date { display: block; padding: 0.4rem 1.4rem 0; font-size: 0.78rem; color: var(--gw-accent); }
.gene-aesthetic--warm .wp-block-latest-posts__post-excerpt { padding: 0.5rem 1.4rem 1.4rem; margin: 0; color: var(--gw-ink-soft); font-size: 0.92rem; line-height: 1.6; }
@media (prefers-reduced-motion: reduce) {
	.gene-aesthetic--warm .wp-block-latest-posts.is-grid > li { transition: none; }
	.gene-aesthetic--warm .wp-block-latest-posts.is-grid > li:hover { transform: none; }
}
@media (max-width: 781px) {
	.gene-aesthetic--warm .wp-block-latest-posts.is-grid { grid-template-columns: 1fr; gap: 1.5rem; }
}

/* Internal links inside nav / footer / brand inherit their text styling. */
.gene-aesthetic--warm .gene-wm-brand a, .gene-aesthetic--warm .gene-wm-navlink a, .gene-aesthetic--warm .gene-wm-foot-link a { color: inherit; text-decoration: none; }
/* Mobile: long emails / URLs in footer & contact lines wrap instead of overflowing. */
.gene-aesthetic--warm .gene-wm-foot-link, .gene-aesthetic--warm .gene-wm-foot-link a, .gene-aesthetic--warm .gene-wm-hours-line { overflow-wrap: break-word; }
.gene-aesthetic--warm .gene-wm-navlink a:hover, .gene-aesthetic--warm .gene-wm-foot-link a:hover { color: var(--gw-accent); }

/* ============================================================
   Header utility bar + footer bottom bar (built-out chrome)
   ============================================================ */
.gene-aesthetic--warm .gene-wm-topbar { align-items: center; gap: 1rem; padding: 0.5rem 0; border-bottom: 1px solid var(--gw-line); }
.gene-aesthetic--warm .gene-wm-topbar-info { margin: 0; font-size: 0.84rem; color: var(--gw-ink-soft); letter-spacing: 0.01em; }
.gene-aesthetic--warm .gene-wm-social { gap: 1.1rem; align-items: center; }
.gene-aesthetic--warm .gene-wm-social-link { margin: 0; font-size: 0.8rem; letter-spacing: 0.02em; }
.gene-aesthetic--warm .gene-wm-social-link a { color: var(--gw-ink-soft); text-decoration: none; }
.gene-aesthetic--warm .gene-wm-social-link a:hover { color: var(--gw-accent); }
.gene-aesthetic--warm .gene-wm-header-row { padding: 0.85rem 0; }

.gene-aesthetic--warm .gene-wm-foot-bottom { margin-top: 2.5rem; padding-top: 1.4rem; border-top: 1px solid rgba(244, 236, 226, 0.14); align-items: center; gap: 1rem; }
.gene-aesthetic--warm .gene-wm-foot-copy { margin: 0; font-size: 0.84rem; color: rgba(244, 236, 226, 0.55); }
.gene-aesthetic--warm .gene-wm-foot-legal { gap: 1.4rem; align-items: center; }
.gene-aesthetic--warm .gene-wm-foot-legal .gene-wm-foot-link { margin: 0; font-size: 0.84rem; }
@media (max-width: 600px) {
	.gene-aesthetic--warm .gene-wm-topbar, .gene-aesthetic--warm .gene-wm-foot-bottom { justify-content: center; text-align: center; }
}
