/*
Theme Name: Good Girl Romance
Theme URI: https://goodgirlromance.com
Author: Good Girl Romance
Author URI: https://goodgirlromance.com
Description: A dark, moody, luxe block theme for a dark-romance publishing house. Near-black, oxblood, and antique gold with elegant serif display type. Ships custom patterns for book grids, listicles, author bios, and affiliate buy buttons.
Requires at least: 6.5
Tested up to: 6.7
Requires PHP: 8.0
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: goodgirl
Tags: block-theme, full-site-editing, blog, portfolio, custom-colors
*/

/* -------------------------------------------------------------
   Component styles (things theme.json can't express cleanly).
   Enqueued via functions.php on the front end and in the editor.
   ------------------------------------------------------------- */

:root {
	--ggr-shadow: 0 18px 40px -18px rgba(0, 0, 0, 0.8);
	--ggr-shadow-gold: 0 0 0 1px rgba(200, 164, 93, 0.35), 0 18px 40px -18px rgba(0, 0, 0, 0.85);
}

/* Smooth, premium feel */
html {
	scroll-behavior: smooth;
}

body {
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

/* Gold gradient text accent (use class .ggr-gradient-text on a heading) */
.ggr-gradient-text {
	background: linear-gradient(95deg, var(--wp--preset--color--accent) 0%, var(--wp--preset--color--accent-soft) 60%, var(--wp--preset--color--accent) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

/* Eyebrow / kicker label */
.ggr-eyebrow {
	text-transform: uppercase;
	letter-spacing: 0.28em;
	font-size: 0.72rem;
	font-weight: 600;
	color: var(--wp--preset--color--accent);
}

/* ---------- Book cards ---------- */
.ggr-book-card {
	position: relative;
	transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.ggr-book-card:hover {
	transform: translateY(-6px);
}
.ggr-book-card .wp-block-image img,
.ggr-book-cover img {
	border-radius: 6px;
	box-shadow: var(--ggr-shadow);
	transition: box-shadow 0.4s ease, transform 0.4s ease;
	aspect-ratio: 2 / 3;
	object-fit: cover;
	width: 100%;
}
.ggr-book-card:hover .wp-block-image img,
.ggr-book-card:hover .ggr-book-cover img {
	box-shadow: var(--ggr-shadow-gold);
}

/* ---------- Buy buttons (rendered by GGR_Affiliate::buttons) ---------- */
.ggr-buy-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	margin: 1.25rem 0;
}
.ggr-buy-button {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.7rem 1.3rem;
	border-radius: 4px;
	font-weight: 600;
	font-size: 0.95rem;
	letter-spacing: 0.02em;
	text-decoration: none;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--contrast);
	border: 1px solid transparent;
	transition: all 0.25s ease;
}
.ggr-buy-button:hover {
	background: var(--wp--preset--color--primary-deep);
	border-color: var(--wp--preset--color--accent);
	color: #fff;
	transform: translateY(-2px);
}
.ggr-buy-button.ggr-buy-amazon { background: #2a2018; border-color: rgba(200,164,93,.5); }
.ggr-buy-button.ggr-buy-amazon:hover { background: #3a2c1e; }

/* ---------- Affiliate disclosure ---------- */
.ggr-disclosure {
	font-size: 0.78rem;
	color: var(--wp--preset--color--muted);
	font-style: italic;
	opacity: 0.85;
}

/* ---------- Star rating ---------- */
.ggr-stars {
	--pct: 0%;
	display: inline-block;
	font-size: 1.05rem;
	line-height: 1;
	position: relative;
	font-family: Arial, sans-serif;
	white-space: nowrap;
}
.ggr-stars::before {
	content: "★★★★★";
	color: rgba(244, 236, 227, 0.18);
}
.ggr-stars::after {
	content: "★★★★★";
	color: var(--wp--preset--color--accent);
	position: absolute;
	inset: 0;
	width: var(--pct);
	overflow: hidden;
}

/* ---------- Hero overlay ---------- */
.ggr-hero {
	position: relative;
	isolation: isolate;
}
.ggr-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background: radial-gradient(120% 90% at 70% 10%, rgba(123, 30, 43, 0.45) 0%, transparent 55%),
		linear-gradient(180deg, rgba(14, 11, 13, 0.4) 0%, rgba(14, 11, 13, 0.92) 100%);
}

/* Thin gold divider */
.ggr-rule {
	width: 64px;
	height: 2px;
	border: 0;
	background: linear-gradient(90deg, var(--wp--preset--color--accent), transparent);
	margin: 1.25rem 0;
}

/* Card surfaces */
.ggr-surface {
	background: var(--wp--preset--color--surface);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 8px;
}

/* Nav link hover underline */
.wp-block-navigation .wp-block-navigation-item__content {
	transition: color 0.2s ease;
}
.wp-block-navigation a:hover {
	color: var(--wp--preset--color--accent);
}

/* Refined links inside content */
.entry-content a,
.ggr-prose a {
	text-underline-offset: 3px;
	text-decoration-color: rgba(200, 164, 93, 0.5);
}

/* ---------- Rating ---------- */
.ggr-rating {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}
.ggr-rating-num {
	font-weight: 600;
	color: var(--wp--preset--color--accent-soft);
	font-size: 0.95rem;
}

/* ---------- Book facts list ---------- */
.ggr-facts {
	margin: 1.5rem 0;
	border-top: 1px solid var(--wp--preset--color--line);
}
.ggr-fact {
	display: grid;
	grid-template-columns: 130px 1fr;
	gap: 1rem;
	padding: 0.7rem 0;
	border-bottom: 1px solid var(--wp--preset--color--line);
}
.ggr-fact dt {
	margin: 0;
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--wp--preset--color--muted);
	font-weight: 600;
}
.ggr-fact dd {
	margin: 0;
	color: var(--wp--preset--color--contrast);
}

/* ---------- Book card body (shortcode + listicles) ---------- */
.ggr-book-card { padding: 0; overflow: hidden; }
.ggr-book-card .ggr-book-cover { display: block; }
.ggr-book-card__body { padding: 1rem 1.1rem 1.3rem; }
.ggr-book-card__title { font-size: 1.15rem; margin: 0 0 0.3rem; line-height: 1.25; }
.ggr-book-card__title a { color: var(--wp--preset--color--contrast); text-decoration: none; }
.ggr-book-card__title a:hover { color: var(--wp--preset--color--accent); }
.ggr-book-card__tagline { color: var(--wp--preset--color--muted); font-size: 0.9rem; margin: 0 0 0.6rem; font-style: italic; }
.ggr-book-card__body .ggr-buy-button { margin-top: 0.8rem; }

/* Listicle numbered entries */
.ggr-listicle-item { position: relative; }
.ggr-rank {
	font-family: "Playfair Display", serif;
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	line-height: 1;
	color: var(--wp--preset--color--primary);
	-webkit-text-stroke: 1px var(--wp--preset--color--accent);
	font-weight: 800;
}

/* ---------- Book grids (shortcode output) ---------- */
.ggr-book-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: clamp(1rem, 2vw, 1.75rem);
	margin: 1.5rem 0;
}
.ggr-book-grid--4 {
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}
@media (min-width: 782px) {
	.ggr-book-grid--4 { grid-template-columns: repeat(4, 1fr); }
}

/* ---------- Trope cloud ---------- */
.ggr-trope-cloud {
	display: flex;
	flex-wrap: wrap;
	gap: 0.7rem;
	justify-content: center;
	max-width: 900px;
	margin: 0 auto;
}
.ggr-trope-pill {
	display: inline-block;
	padding: 0.55rem 1.15rem;
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 100px;
	color: var(--wp--preset--color--contrast);
	text-decoration: none;
	font-size: 0.9rem;
	letter-spacing: 0.02em;
	transition: all 0.25s ease;
	background: var(--wp--preset--color--surface);
}
.ggr-trope-pill:hover {
	border-color: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--accent-soft);
	transform: translateY(-2px);
}

/* ---------- Socials ---------- */
.ggr-socials { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-top: 1rem; }
.ggr-social {
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	padding: 0.35rem 0.9rem;
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 4px;
	text-decoration: none;
	color: var(--wp--preset--color--muted);
}
.ggr-social:hover { color: var(--wp--preset--color--accent); border-color: var(--wp--preset--color--accent); }

/* ---------- Misc ---------- */
.ggr-subtitle { font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 1.4rem; color: var(--wp--preset--color--accent-soft); margin: 0 0 0.75rem; }
.ggr-muted { color: var(--wp--preset--color--muted); }
.ggr-author-photo img { aspect-ratio: 1/1; object-fit: cover; border-radius: 500px; box-shadow: var(--ggr-shadow); }
.ggr-page-head { margin-bottom: var(--wp--preset--spacing--40); }

/* ---------- Header / Footer ---------- */
.ggr-site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	backdrop-filter: blur(10px);
	background: rgba(14, 11, 13, 0.82) !important;
	border-bottom: 1px solid var(--wp--preset--color--line);
}
.ggr-site-footer { border-top: 1px solid var(--wp--preset--color--line); }
.ggr-footer-list { list-style: none; padding: 0; margin: 0.5rem 0 0; }
.ggr-footer-list li { margin: 0.4rem 0; }
.ggr-footer-list a { color: var(--wp--preset--color--muted); text-decoration: none; font-size: 0.92rem; }
.ggr-footer-list a:hover { color: var(--wp--preset--color--accent); }

/* ---------- CTA band: force readable text on oxblood ---------- */
.ggr-cta, .ggr-cta h2, .ggr-cta p { color: var(--wp--preset--color--contrast); }

/* Featured-image link blocks shouldn't add underline */
.ggr-book-card a { text-decoration: none; }
