/* ==========================================================================
   Melanie Author Theme — Mode System
   ========================================================================== */

:root,
:root.mode-mosaic {
	--melanie-bg: #211d19;
	--melanie-surface: #2a251f;
	--melanie-surface-2: #3a3028;
	--melanie-ink: #fff3e5;
	--melanie-muted: #d0bca9;
	--melanie-border: #504236;
	--melanie-accent: #ff5a62;
	--melanie-accent-2: #9bb0bf;
	--melanie-yellow: #f0bf58;
	--melanie-blue: #4aa0a0;
	--melanie-button: #fff3e5;
	--melanie-button-ink: #1f1711;
	--melanie-shadow: rgba(0, 0, 0, 0.34);
	--melanie-header: rgba(33, 29, 25, 0.86);
	--melanie-font-body: 'DM Sans', 'Inter', system-ui, sans-serif;
	--melanie-font-heading: Georgia, serif;
	--melanie-font-storybook: Nunito, ui-rounded, system-ui, sans-serif;
	--melanie-radius: 1rem;
	--melanie-radius-pill: 999px;
	--melanie-content-width: 800px;
	--melanie-wide-width: 1320px;
}

:root.mode-mosaic[data-theme='dark'] {
	--melanie-bg: #090908;
	--melanie-surface: #141312;
	--melanie-surface-2: #1d1a18;
	--melanie-ink: #fff8ed;
	--melanie-muted: #cfc3b7;
	--melanie-border: #332d27;
	--melanie-accent: #ff5c66;
	--melanie-accent-2: #88a5c0;
	--melanie-yellow: #ffd166;
	--melanie-blue: #4fb7b8;
	--melanie-button: #fff8ed;
	--melanie-button-ink: #111111;
	--melanie-shadow: rgba(0, 0, 0, 0.5);
	--melanie-header: rgba(9, 9, 8, 0.86);
}

:root.mode-mosaic[data-theme='light'] {
	--melanie-bg: #fbf8f4;
	--melanie-surface: #ffffff;
	--melanie-surface-2: #f2e8dc;
	--melanie-ink: #151515;
	--melanie-muted: #5f5852;
	--melanie-border: #e8ded2;
	--melanie-accent: #ff4f57;
	--melanie-accent-2: #243447;
	--melanie-yellow: #ffd166;
	--melanie-blue: #34a0a4;
	--melanie-button: #111111;
	--melanie-button-ink: #ffffff;
	--melanie-shadow: rgba(0, 0, 0, 0.1);
	--melanie-header: rgba(251, 248, 244, 0.86);
}

:root.mode-cinematic {
	--melanie-bg: #08070a;
	--melanie-bg-2: #161018;
	--melanie-surface: #1d1114;
	--melanie-surface-2: #2b1716;
	--melanie-ink: #f8eee3;
	--melanie-muted: #dac8b7;
	--melanie-subtle: #a88f7d;
	--melanie-border: rgba(255, 255, 255, 0.16);
	--melanie-accent: #e7a15e;
	--melanie-accent-2: #8f3c29;
	--melanie-button: #f1c27d;
	--melanie-button-ink: #1a0f0a;
	--melanie-shadow: rgba(0, 0, 0, 0.48);
	--melanie-grain-opacity: 0.26;
	--melanie-header: rgba(8, 7, 10, 0.86);
	--melanie-radius: 28px;
	--melanie-radius-pill: 999px;
	--melanie-font-body: 'Inter', ui-sans-serif, system-ui, sans-serif;
	--melanie-font-heading: Georgia, serif;
	--melanie-content-width: 800px;
	--melanie-wide-width: 1240px;
}

:root.mode-cinematic[data-theme='dark'] {
	--melanie-bg: #020203;
	--melanie-bg-2: #09070a;
	--melanie-surface: #10090d;
	--melanie-surface-2: #1c0d10;
	--melanie-ink: #fff8ef;
	--melanie-muted: #d8c6b6;
	--melanie-subtle: #9a8170;
	--melanie-border: rgba(255, 255, 255, 0.14);
	--melanie-accent: #ff9b50;
	--melanie-accent-2: #69251d;
	--melanie-button: #ffb565;
	--melanie-button-ink: #120804;
	--melanie-shadow: rgba(0, 0, 0, 0.7);
	--melanie-grain-opacity: 0.34;
	--melanie-header: rgba(2, 2, 3, 0.86);
}

:root.mode-cinematic[data-theme='light'] {
	--melanie-bg: #fbf4ec;
	--melanie-bg-2: #efe1d2;
	--melanie-surface: #fffaf5;
	--melanie-surface-2: #f2dfcf;
	--melanie-ink: #1e130e;
	--melanie-muted: #5f4a3c;
	--melanie-subtle: #7a6250;
	--melanie-border: rgba(74, 42, 24, 0.18);
	--melanie-accent: #9e4e23;
	--melanie-accent-2: #d79a61;
	--melanie-button: #3b1a10;
	--melanie-button-ink: #fff7ed;
	--melanie-shadow: rgba(89, 47, 22, 0.18);
	--melanie-grain-opacity: 0.08;
	--melanie-header: rgba(251, 244, 236, 0.86);
}

:root.mode-storybook {
	--melanie-sky: #426f88;
	--melanie-ground: #4b5526;
	--melanie-paper: #f8f1d8;
	--melanie-paper-2: #e9d7a5;
	--melanie-bg: #426f88;
	--melanie-bg-2: #4b5526;
	--melanie-surface: #f8f1d8;
	--melanie-surface-2: #e9d7a5;
	--melanie-ink: #20331f;
	--melanie-muted: #365437;
	--melanie-border: #20331f;
	--melanie-accent: #ffcf33;
	--melanie-accent-2: #ef7d62;
	--melanie-green: #559453;
	--melanie-blue: #3998c1;
	--melanie-shadow: rgba(23, 34, 20, 0.35);
	--melanie-soft: rgba(255, 255, 255, 0.22);
	--melanie-button: #ffcf33;
	--melanie-button-ink: #20331f;
	--melanie-header: rgba(255, 255, 255, 0.22);
	--melanie-font-body: Nunito, ui-rounded, system-ui, sans-serif;
	--melanie-font-heading: Georgia, serif;
	--melanie-radius: 26px;
	--melanie-radius-pill: 999px;
	--melanie-content-width: 800px;
	--melanie-wide-width: 1180px;
}

:root.mode-storybook[data-theme='dark'] {
	--melanie-sky: #091922;
	--melanie-ground: #182212;
	--melanie-paper: #101f19;
	--melanie-paper-2: #173125;
	--melanie-bg: #091922;
	--melanie-bg-2: #182212;
	--melanie-surface: #101f19;
	--melanie-surface-2: #173125;
	--melanie-ink: #f5ffe9;
	--melanie-muted: #c8dfba;
	--melanie-border: #f5ffe9;
	--melanie-accent: #ffd84d;
	--melanie-accent-2: #ff846b;
	--melanie-green: #317047;
	--melanie-blue: #2d84a7;
	--melanie-shadow: rgba(2, 5, 4, 0.5);
	--melanie-soft: rgba(255, 255, 255, 0.08);
	--melanie-button: #ffd84d;
	--melanie-button-ink: #20331f;
	--melanie-header: rgba(255, 255, 255, 0.08);
}

:root.mode-storybook[data-theme='light'] {
	--melanie-sky: #a9e4ff;
	--melanie-ground: #fff3b0;
	--melanie-paper: #fffdf4;
	--melanie-paper-2: #fff6d7;
	--melanie-bg: #a9e4ff;
	--melanie-bg-2: #fff3b0;
	--melanie-surface: #fffdf4;
	--melanie-surface-2: #fff6d7;
	--melanie-ink: #20331f;
	--melanie-muted: #476b47;
	--melanie-border: #20331f;
	--melanie-accent: #ffcf33;
	--melanie-accent-2: #ff8f6b;
	--melanie-green: #68b765;
	--melanie-blue: #4db6e8;
	--melanie-shadow: rgba(32, 51, 31, 0.22);
	--melanie-soft: rgba(255, 255, 255, 0.72);
	--melanie-button: #ffcf33;
	--melanie-button-ink: #20331f;
	--melanie-header: rgba(255, 255, 255, 0.72);
}

/* Components */
body {
	background-color: var(--melanie-bg) !important;
	color: var(--melanie-ink) !important;
	font-family: var(--melanie-font-body) !important;
	transition: background-color 0.25s ease, color 0.25s ease;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--melanie-font-heading) !important;
	color: var(--melanie-ink) !important;
}

a { color: var(--melanie-accent) !important; }
a:hover { opacity: 0.85; }

.site-header,
header.wp-block-template-part {
	background: var(--melanie-header) !important;
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	border-bottom: 1px solid var(--melanie-border) !important;
}

.wp-block-site-title a,
.wp-block-site-title {
	color: var(--melanie-ink) !important;
	font-family: var(--melanie-font-heading) !important;
	font-weight: 700 !important;
	text-decoration: none !important;
}

.wp-block-site-tagline,
.wp-block-navigation-item a,
.wp-block-post-date,
.wp-block-post-excerpt {
	color: var(--melanie-muted) !important;
}

.wp-block-navigation-item a:hover,
.wp-block-navigation-item.current-menu-item a { color: var(--melanie-ink) !important; }

.mode-switcher {
	display: inline-flex !important;
	gap: 4px !important;
	padding: 5px !important;
	border: 1px solid var(--melanie-border) !important;
	border-radius: var(--melanie-radius-pill) !important;
	background: color-mix(in srgb, var(--melanie-surface) 84%, transparent) !important;
	box-shadow: 0 10px 30px var(--melanie-shadow) !important;
	flex-wrap: wrap;
	align-items: center;
}

.mode-switcher button,
.mode-switcher .wp-block-button__link {
	border: 0 !important;
	border-radius: var(--melanie-radius-pill) !important;
	background: transparent !important;
	color: var(--melanie-muted) !important;
	padding: 9px 13px !important;
	font: inherit !important;
	font-size: 0.85rem !important;
	font-weight: 900 !important;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	cursor: pointer !important;
	text-decoration: none !important;
	min-width: auto !important;
}

.mode-switcher button[aria-pressed='true'],
.mode-switcher button.is-active {
	background: var(--melanie-button) !important;
	color: var(--melanie-button-ink) !important;
	box-shadow: 0 4px 12px var(--melanie-shadow) !important;
}

.wp-block-button__link,
.wp-element-button {
	background: var(--melanie-button) !important;
	color: var(--melanie-button-ink) !important;
	border: 1px solid var(--melanie-border) !important;
	border-radius: var(--melanie-radius-pill) !important;
	padding: 12px 16px !important;
	font-weight: 900 !important;
	transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}

.wp-block-button__link:hover,
.wp-element-button:hover {
	transform: translateY(-2px);
	box-shadow: 0 16px 40px var(--melanie-shadow) !important;
	color: var(--melanie-button-ink) !important;
}

.wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent !important;
	color: var(--melanie-ink) !important;
	border: 1px solid var(--melanie-border) !important;
}

.wp-block-group.story-card,
.wp-block-group.archive-card,
.wp-block-group.front-page__hero-panel,
.wp-block-group.front-page__details,
.melanie-card {
	background: var(--melanie-surface) !important;
	border: 1px solid var(--melanie-border) !important;
	border-radius: var(--melanie-radius) !important;
	padding: 1.5rem !important;
	box-shadow: 0 16px 45px var(--melanie-shadow) !important;
	transition: transform 0.2s ease !important;
}

.wp-block-group.story-card:hover,
.wp-block-group.archive-card:hover { transform: translateY(-5px); }

.front-page__hero { padding: 3rem 0 !important; }
.front-page__eyebrow {
	color: var(--melanie-accent) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.18em !important;
	font-size: 12px !important;
	font-weight: 900 !important;
}
.front-page h1 {
	font-size: clamp(48px, 8vw, 96px) !important;
	line-height: 0.9 !important;
	letter-spacing: -0.05em !important;
}
.wp-block-post-title a { text-decoration: none !important; color: var(--melanie-ink) !important; }
.wp-block-post-title a:hover { color: var(--melanie-accent) !important; }
footer.wp-block-template-part,
.wp-block-template-part[data-area='footer'] {
	background: var(--melanie-surface) !important;
	border-top: 1px solid var(--melanie-border) !important;
	color: var(--melanie-muted) !important;
}
.error404 h1 { font-size: clamp(64px, 12vw, 128px) !important; }
body.mode-storybook { font-family: var(--melanie-font-body) !important; }
body.mode-cinematic .front-page__hero {
	background: radial-gradient(circle at 73% 24%, color-mix(in srgb, var(--melanie-accent) 35%, transparent), transparent 28%),
	linear-gradient(115deg, var(--melanie-bg) 0%, var(--melanie-bg-2) 45%, color-mix(in srgb, var(--melanie-accent-2) 55%, var(--melanie-bg)) 100%) !important;
}
/* Homepage landing page */
.front-home__hero {
	padding: clamp(3.25rem, 6vw, 5.75rem) 1.25rem clamp(2.5rem, 5vw, 4.25rem) !important;
	background:
		radial-gradient(circle at 12% 18%, color-mix(in srgb, var(--melanie-accent) 18%, transparent), transparent 26%),
		radial-gradient(circle at 86% 12%, color-mix(in srgb, var(--melanie-blue, var(--melanie-accent-2)) 16%, transparent), transparent 24%),
		linear-gradient(180deg, color-mix(in srgb, var(--melanie-surface) 42%, transparent), transparent 72%);
}
.front-home__hero-grid { gap: clamp(2rem, 5vw, 4.5rem) !important; }
.front-home__eyebrow,
.front-home__card-kicker,
.front-home__book-label {
	color: var(--melanie-accent) !important;
	font-size: 0.76rem !important;
	font-weight: 900 !important;
	letter-spacing: 0.17em !important;
	text-transform: uppercase !important;
}
.front-home__title {
	font-size: clamp(3.1rem, 8.4vw, 6.8rem) !important;
	line-height: 0.88 !important;
	letter-spacing: -0.065em !important;
	max-width: 12ch;
	margin-top: 0.45rem !important;
	margin-bottom: 1.2rem !important;
}
.front-home__lede {
	color: var(--melanie-muted) !important;
	font-size: clamp(1.08rem, 1.6vw, 1.32rem) !important;
	line-height: 1.58 !important;
	max-width: 62ch;
}
.front-home__actions { margin-top: 1.75rem !important; }
.front-home__reader-card,
.front-home__path-card,
.front-home__book-placeholder,
.front-home__note-card,
.front-home__newsletter-card,
.front-home__mini-card {
	background: color-mix(in srgb, var(--melanie-surface) 94%, transparent) !important;
	border: 1px solid var(--melanie-border) !important;
	border-radius: calc(var(--melanie-radius) * 1.25) !important;
	box-shadow: 0 20px 60px var(--melanie-shadow) !important;
}
.front-home__reader-card { padding: clamp(1.5rem, 3vw, 2.4rem) !important; }
.front-home__reader-card h2 { font-size: clamp(2rem, 4vw, 3.1rem) !important; line-height: 0.95 !important; }
.front-home__checklist { padding-left: 1.15rem !important; color: var(--melanie-muted) !important; }
.front-home__checklist li { margin: 0.7rem 0 !important; }
.front-home__section {
	padding: clamp(2.75rem, 5.5vw, 4.75rem) 1.25rem !important;
}
.front-home__paths,
.front-home__about,
.front-home__faq {
	background: color-mix(in srgb, var(--melanie-surface) 36%, transparent) !important;
}
.front-home__section-heading {
	text-align: center;
	margin-bottom: clamp(1.8rem, 4vw, 3rem) !important;
}
.front-home__section-heading h2,
.front-home__featured h2,
.front-home__about h2,
.front-home__newsletter h2 {
	font-size: clamp(2.3rem, 5vw, 4.8rem) !important;
	line-height: 0.96 !important;
	letter-spacing: -0.045em !important;
}
.front-home__section-heading p:not(.front-home__eyebrow),
.front-home__featured p,
.front-home__about p,
.front-home__newsletter p,
.front-home__mini-card p,
.front-home__path-card p {
	color: var(--melanie-muted) !important;
}
.front-home__card-grid { gap: 1.2rem !important; }
.front-home__path-card,
.front-home__mini-card { padding: 1.55rem !important; min-height: 100%; }
.front-home__path-card h3,
.front-home__mini-card h3 { font-size: clamp(1.45rem, 2.4vw, 2rem) !important; line-height: 1.05 !important; }
.front-home__path-card a,
.front-home__mini-card a { font-weight: 900 !important; text-decoration: none !important; }
.front-home__path-card--storybook {
	background: linear-gradient(135deg, color-mix(in srgb, var(--melanie-yellow, var(--melanie-accent)) 28%, var(--melanie-surface)), var(--melanie-surface)) !important;
}
.front-home__featured .wp-block-columns,
.front-home__about .wp-block-columns { gap: clamp(2rem, 5vw, 4rem) !important; }
.front-home__book-placeholder {
	min-height: 430px;
	padding: 2rem !important;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	position: relative;
	overflow: hidden;
}
.front-home__book-placeholder::before {
	content: '';
	position: absolute;
	inset: 2rem 2rem auto;
	height: 55%;
	border-radius: calc(var(--melanie-radius) * 0.85);
	background: linear-gradient(145deg, var(--melanie-accent), var(--melanie-accent-2));
	opacity: 0.32;
	box-shadow: inset 0 0 0 1px var(--melanie-border);
}
.front-home__book-placeholder > * { position: relative; z-index: 1; }
.front-home__note-card { padding: clamp(1.5rem, 3vw, 2.4rem) !important; }
.front-home__note-card p:not(.front-home__muted) {
	font-family: var(--melanie-font-heading) !important;
	font-size: clamp(1.5rem, 3vw, 2.35rem) !important;
	line-height: 1.18 !important;
	color: var(--melanie-ink) !important;
}
.front-home__muted { color: var(--melanie-muted) !important; font-size: 0.95rem !important; }
.front-home__newsletter-card {
	text-align: center;
	padding: clamp(2.25rem, 6vw, 4.5rem) !important;
	background:
		radial-gradient(circle at 20% 20%, color-mix(in srgb, var(--melanie-accent) 18%, transparent), transparent 28%),
		color-mix(in srgb, var(--melanie-surface) 94%, transparent) !important;
}
.front-home__newsletter-card p:not(.front-home__eyebrow) {
	max-width: 760px;
	margin-left: auto !important;
	margin-right: auto !important;
}
@media (max-width: 782px) {
	.front-page h1,
	.front-home__title { font-size: clamp(3rem, 15vw, 5rem) !important; }
	.front-page__hero .wp-block-columns,
	.front-home .wp-block-columns { flex-wrap: wrap !important; }
	.front-page__hero .wp-block-column,
	.front-home .wp-block-column { flex-basis: 100% !important; }
	.front-home__book-placeholder { min-height: 320px; }
	.mode-switcher { order: 10; width: 100%; justify-content: center; }
}
