/*
Theme Name: Love Letters 411 (Twenty Twenty-Five child)
Template: twentytwentyfive
Description: Warm, conversion-focused block theme for the Love Letters 411 archive. Letter pages styled like real letters; category hubs styled for browsing across collections.
Version: 1.0.0
Author: Marketing the Change
Author URI: https://marketingthechange.com
Text Domain: ll411-2025
Tags: blog, full-site-editing, block-theme, accessibility-ready
*/

/* Letter paper effect */
.ll-letter__body {
	background: #FFFFFF;
	padding: 2.5rem 2.25rem;
	box-shadow: 0 1px 2px rgba(0,0,0,0.04), 0 4px 16px rgba(194,138,138,0.08);
	border-radius: 4px;
	margin: 1.5rem auto;
	max-width: 720px;
}
.ll-letter__body p { margin: 0 0 1.1rem; }
.ll-letter__body p:last-child { margin-bottom: 0; }

/* Sign-off italic */
.ll-letter__signoff,
.ll-letter__body em.ll-signoff {
	font-style: italic;
	display: block;
	margin-top: 1.5rem;
	color: var(--wp--preset--color--rose-dark);
}

/* Card */
.ll-card {
	background: var(--wp--preset--color--paper);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 6px;
	padding: 1.25rem;
	transition: transform .18s ease, box-shadow .18s ease;
	display: flex;
	flex-direction: column;
	gap: .6rem;
}
.ll-card:hover,
.ll-card:focus-within {
	transform: translateY(-3px);
	box-shadow: 0 6px 20px rgba(122,74,90,0.10);
}
.ll-card a { text-decoration: none; }
.ll-card a:hover { text-decoration: underline; }
.ll-card .ll-card__chip {
	display: inline-block;
	font-family: var(--wp--preset--font-family--sans);
	font-size: .75rem;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--wp--preset--color--plum);
	background: var(--wp--preset--color--rose-light);
	padding: .15rem .55rem;
	border-radius: 999px;
}

/* Meta row */
.ll-meta {
	font-family: var(--wp--preset--font-family--sans);
	font-size: .85rem;
	color: var(--wp--preset--color--mute);
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	align-items: center;
	margin: .5rem 0 1rem;
}
.ll-meta span + span::before {
	content: "·";
	margin-right: .75rem;
	color: var(--wp--preset--color--line);
}

/* Hero */
.ll-hero {
	background: linear-gradient(180deg, var(--wp--preset--color--rose-light) 0%, var(--wp--preset--color--base) 100%);
	padding: 4rem 1.5rem 3.5rem;
	text-align: center;
	border-radius: 6px;
}
.ll-hero h1 { margin-bottom: .75rem; }
.ll-hero p.lead {
	max-width: 620px;
	margin: 0 auto 1.5rem;
	font-size: 1.125rem;
	color: var(--wp--preset--color--plum);
}

/* Soft CTA */
.ll-cta {
	background: #FBF7F2;
	border-left: 3px solid #C28A8A;
	padding: 1.25rem;
	border-radius: 0 4px 4px 0;
	margin: 2rem 0;
}
.ll-cta p:last-child { margin-bottom: 0; }

/* Category grid */
.ll-category-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 1.25rem;
}

/* FAQ */
.ll-faq summary {
	cursor: pointer;
	font-weight: 600;
	padding: .75rem 0;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.ll-faq summary::after {
	content: "›";
	transform: rotate(90deg);
	transition: transform .18s ease;
	color: var(--wp--preset--color--rose);
	font-size: 1.25rem;
}
.ll-faq details[open] summary::after { transform: rotate(-90deg); }

/* Focus-visible */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
summary:focus-visible {
	outline: 2px solid var(--wp--preset--color--rose-dark);
	outline-offset: 2px;
	border-radius: 2px;
}

/* Skip link */
.skip-link {
	position: absolute;
	left: -9999px;
	top: 8px;
	background: var(--wp--preset--color--contrast);
	color: var(--wp--preset--color--paper);
	padding: .5rem 1rem;
	z-index: 9999;
	border-radius: 4px;
}
.skip-link:focus { left: 8px; }

/* Print */
@media print {
	.wp-block-template-part[data-area="header"],
	.wp-block-template-part[data-area="footer"],
	.wp-block-navigation,
	.comments-area,
	.ll-cta,
	.wp-block-search { display: none !important; }
	.ll-letter__body { box-shadow: none; padding: 0; }
	body { background: #fff; color: #000; }
	a { color: #000; text-decoration: underline; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.ll-card,
	.ll-card:hover,
	.ll-faq summary::after { transition: none; transform: none; }
}
