/* ==========================================================================
   Sonoma County Daily — Front Page (mosaic)
   Matches parent theme: Mulish body + EB Garamond display, white bg
   ========================================================================== */

:root {
	--sd-paper:        #ffffff;
	--sd-paper-2:      #f7f6f5;
	--sd-paper-deep:   #e5e3e1;
	--sd-ink:          #1c1b19;
	--sd-ink-2:        #31302f;
	--sd-ink-soft:     #494846;
	--sd-fog:          #8d8c8b;
	--sd-hairline:     rgba(28, 27, 25, .12);
	--sd-oxblood:      #c53f09;
	--sd-stamp:        #c53f09;

	--sd-head:    "EB Garamond", "Iowan Old Style", Georgia, serif;
	--sd-display: "EB Garamond", "Iowan Old Style", Georgia, serif;
	--sd-sans:    "Mulish", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--sd-mono:    "Fira Code", ui-monospace, SFMono-Regular, Menlo, monospace;

	--sd-max: 1400px;
}

html, body.sd-front {
	margin: 0;
	padding: 0;
	background: var(--sd-paper);
	color: var(--sd-ink);
	font-family: var(--sd-sans);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	font-feature-settings: "kern", "liga";
}

body.sd-front { background: var(--sd-paper); }

body.sd-front a { color: inherit; text-decoration: none; }
body.sd-front img { max-width: 100%; height: auto; display: block; }

.sd-skip {
	position: absolute; left: -9999px; top: auto;
	background: var(--sd-ink); color: var(--sd-paper); padding: .5rem .75rem; font-family: var(--sd-mono); font-size: .8rem;
}
.sd-skip:focus { left: 1rem; top: 1rem; z-index: 999; }

.sd-shell {
	max-width: var(--sd-max);
	margin: 0 auto;
	padding: 1.2rem clamp(1rem, 3vw, 2.5rem) 3rem;
}

/* ===================== MASTHEAD ===================== */

.sd-masthead { position: relative; padding-top: .25rem; margin-bottom: 2rem; }

.sd-dateline {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 1rem;
	font-family: var(--sd-mono);
	font-size: .72rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--sd-ink-soft);
	border-top: 1px solid var(--sd-ink);
	border-bottom: 1px solid var(--sd-ink);
	padding: .45rem .25rem;
}
.sd-dateline__left em { font-style: italic; font-family: var(--sd-display); font-weight: 500; text-transform: none; letter-spacing: 0; font-size: .95rem; color: var(--sd-ink); }
.sd-dateline__center { text-align: center; }
.sd-dateline__right { text-align: right; }

@media (max-width: 720px) {
	.sd-dateline { grid-template-columns: 1fr 1fr; row-gap: .25rem; font-size: .65rem; }
	.sd-dateline__center { grid-column: 1 / -1; text-align: center; order: 3; border-top: 1px dotted var(--sd-hairline); padding-top: .35rem; }
	.sd-dateline__right { text-align: right; }
}

.sd-logo {
	display: block;
	margin: clamp(1rem, 2.5vw, 1.8rem) auto 0;
	width: clamp(70px, 9vw, 104px);
	aspect-ratio: 1 / 1;
	transition: transform .3s ease;
}
.sd-logo:hover { transform: scale(1.04) rotate(-2deg); }
.sd-logo__img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	filter: drop-shadow(0 2px 6px rgba(20,18,16,.12));
}

.sd-nameplate {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: baseline;
	gap: clamp(.5rem, 2vw, 2rem);
	padding: clamp(.6rem, 1.5vw, 1rem) 0 .5rem;
}
.sd-nameplate__flourish {
	font-family: var(--sd-display);
	font-size: clamp(1.5rem, 4vw, 2.4rem);
	color: var(--sd-oxblood);
	font-weight: 400;
	font-style: italic;
	transform: translateY(-.3em);
	user-select: none;
}
.sd-nameplate__title {
	margin: 0;
	text-align: center;
	font-family: var(--sd-head);
	font-weight: 800;

	font-size: clamp(3rem, 12vw, 8.4rem);
	line-height: .88;
	letter-spacing: -.035em;
	color: var(--sd-ink);
}
.sd-nameplate__title a { display: block; color: inherit; }
.sd-nameplate__sonoma { display: block; }
.sd-nameplate__county {
	display: inline;
	font-family: var(--sd-display);
	font-style: italic;
	font-weight: 400;

	color: var(--sd-oxblood);
	padding-right: .15em;
	letter-spacing: -.02em;
}
.sd-nameplate__daily  { display: inline; }

.sd-subplate {
	display: flex; justify-content: center;
	font-family: var(--sd-display);
	font-style: italic;
	color: var(--sd-ink-soft);
	font-size: clamp(.95rem, 1.5vw, 1.15rem);
	padding: .25rem 0 .85rem;
}
.sd-subplate__motto::before,
.sd-subplate__motto::after {
	content: "";
	display: inline-block;
	width: 24px; height: 1px; background: var(--sd-ink-soft); vertical-align: middle; margin: 0 .7rem;
	opacity: .6;
}

.sd-nav {
	border-top: 3px double var(--sd-ink);
	border-bottom: 1px solid var(--sd-ink);
}
.sd-nav ul {
	display: flex; flex-wrap: wrap;
	justify-content: center;
	gap: clamp(.8rem, 2.5vw, 2.2rem);
	list-style: none;
	margin: 0; padding: .65rem 0;
}
.sd-nav a {
	font-family: var(--sd-sans);
	font-size: .82rem;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--sd-ink);
	padding: .15rem 0;
	position: relative;
	transition: color .2s;
}
.sd-nav a::after {
	content: "";
	position: absolute; left: 50%; right: 50%; bottom: -.4rem; height: 2px;
	background: var(--sd-oxblood);
	transition: left .25s, right .25s;
}
.sd-nav a:hover, .sd-nav a.is-active { color: var(--sd-oxblood); }
.sd-nav a:hover::after, .sd-nav a.is-active::after { left: 0; right: 0; }

/* ===================== HERO (most recent, full-width) ===================== */

.sd-hero {
	position: relative;
	margin: 0 0 clamp(.8rem, 1.6vw, 1.2rem);
	border: 1px solid var(--sd-ink);
	overflow: hidden;
	background: var(--sd-ink);
}

.sd-hero__link {
	display: block;
	position: relative;
	color: #fff;
	min-height: clamp(340px, 52vw, 560px);
}

.sd-hero__imgwrap {
	position: absolute;
	inset: 0;
	overflow: hidden;
	z-index: 0;
}
.sd-hero__img {
	position: absolute;
	inset: 0;
	width: 100% !important;
	height: 100% !important;
	object-fit: cover;
	transition: transform 1.2s cubic-bezier(.2,.7,.2,1), filter .6s;
	filter: contrast(1.03) saturate(.95);
}
.sd-hero:hover .sd-hero__img { transform: scale(1.03); filter: contrast(1.07) saturate(1.05); }

.sd-hero__veil {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(100deg, rgba(20,18,16,.82) 0%, rgba(20,18,16,.55) 42%, rgba(20,18,16,.15) 72%, rgba(20,18,16,.05) 100%),
		linear-gradient(180deg, rgba(20,18,16,0) 45%, rgba(20,18,16,.6) 100%);
	z-index: 1;
	pointer-events: none;
}

.sd-hero__body {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: clamp(.55rem, 1vw, .9rem);
	padding: clamp(1.4rem, 4vw, 3rem);
	max-width: min(64ch, 72%);
	min-height: inherit;
	justify-content: flex-end;
}

.sd-hero__kicker {
	--kcolor: #fff;
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	align-self: flex-start;
	font-family: var(--sd-sans);
	font-weight: 600;
	font-size: .72rem;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: #fff;
	background: rgba(0,0,0,.35);
	backdrop-filter: blur(6px);
	padding: .4rem .7rem;
	border: 1px solid rgba(255,255,255,.22);
	border-radius: 999px;
}
.sd-hero__dot {
	width: 8px; height: 8px; border-radius: 50%;
	background: var(--kcolor);
	box-shadow: 0 0 0 2px color-mix(in oklab, var(--kcolor), white 60%);
}
.sd-hero__kicker-slug { font-family: var(--sd-mono); font-size: .68rem; color: rgba(255,255,255,.7); letter-spacing: .08em; }

.sd-hero__title {
	font-family: var(--sd-head);
	font-weight: 800;

	font-size: clamp(1.9rem, 5.2vw, 4.2rem);
	line-height: .98;
	letter-spacing: -.035em;
	margin: 0;
	color: #fff;
	text-wrap: balance;
	text-shadow: 0 2px 6px rgba(0,0,0,.35);
}

.sd-hero__dek {
	font-family: var(--sd-display);
	font-size: clamp(1.02rem, 1.4vw, 1.25rem);
	line-height: 1.45;
	color: rgba(255,255,255,.9);
	margin: 0;
	max-width: 52ch;
}

.sd-hero__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .5rem;
	font-family: var(--sd-mono);
	font-size: .74rem;
	color: rgba(255,255,255,.78);
	letter-spacing: .03em;
	margin-top: .2rem;
}
.sd-hero__sep { color: rgba(255,255,255,.38); }
.sd-hero__readmore { color: #fff; font-weight: 500; }
.sd-hero:hover .sd-hero__readmore { color: color-mix(in oklab, var(--sd-stamp), white 30%); }

@media (max-width: 720px) {
	.sd-hero__body { max-width: 100%; }
}

/* ===================== MOSAIC GRID ===================== */

.sd-mosaic {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-auto-rows: 220px;
	grid-auto-flow: dense;
	gap: clamp(.6rem, 1.2vw, 1rem);
	margin: 0 0 2.5rem;
}

.sd-tile {
	position: relative;
	grid-column: span 1;
	grid-row: span 1;
	overflow: hidden;
	background: var(--sd-ink);
	isolation: isolate;
	border: 1px solid var(--sd-ink);
}
.sd-tile--big  { grid-column: span 2; grid-row: span 2; }
.sd-tile--wide { grid-column: span 2; grid-row: span 1; }
.sd-tile--tall { grid-column: span 1; grid-row: span 2; }

.sd-tile__link {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	color: #fff;
	padding: clamp(.75rem, 1.4vw, 1.4rem);
	z-index: 1;
}

.sd-tile__imgwrap {
	position: absolute;
	inset: 0;
	overflow: hidden;
	z-index: -1;
}
.sd-tile__img {
	position: absolute;
	inset: 0;
	width: 100% !important;
	height: 100% !important;
	object-fit: cover;
	transition: transform .8s cubic-bezier(.2,.7,.2,1), filter .5s;
	filter: contrast(1.02) saturate(.95);
}
.sd-tile:hover .sd-tile__img { transform: scale(1.04); filter: contrast(1.08) saturate(1.05); }

.sd-tile__veil {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(20,18,16,0) 28%, rgba(20,18,16,.2) 55%, rgba(20,18,16,.85) 100%);
	z-index: 0;
	pointer-events: none;
	transition: background .35s;
}
.sd-tile:hover .sd-tile__veil {
	background:
		linear-gradient(180deg, rgba(20,18,16,.1) 0%, rgba(20,18,16,.35) 45%, rgba(20,18,16,.92) 100%);
}

.sd-tile__body {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: .35rem;
	z-index: 2;
}

.sd-tile__kicker {
	--kcolor: #ffffff;
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	font-family: var(--sd-sans);
	font-weight: 600;
	font-size: .66rem;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: #fff;
	align-self: flex-start;
	background: rgba(0,0,0,.28);
	backdrop-filter: blur(6px);
	padding: .3rem .55rem;
	border: 1px solid rgba(255,255,255,.18);
	border-radius: 999px;
}
.sd-tile__dot {
	width: 7px; height: 7px; border-radius: 50%;
	background: var(--kcolor);
	box-shadow: 0 0 0 2px color-mix(in oklab, var(--kcolor), white 55%);
}

.sd-tile__title {
	font-family: var(--sd-head);
	font-weight: 700;

	font-size: clamp(.98rem, 1.35vw, 1.22rem);
	line-height: 1.1;
	letter-spacing: -.02em;
	color: #fff;
	text-wrap: balance;
	text-shadow: 0 1px 2px rgba(0,0,0,.35);
}

.sd-tile--big .sd-tile__title  { font-size: clamp(1.6rem, 3.2vw, 2.6rem); font-weight: 800; letter-spacing: -.035em; line-height: 1.02;  }
.sd-tile--wide .sd-tile__title { font-size: clamp(1.2rem, 2vw, 1.7rem); font-weight: 700; letter-spacing: -.028em; line-height: 1.06;  }
.sd-tile--tall .sd-tile__title { font-size: clamp(1.05rem, 1.55vw, 1.35rem); font-weight: 700; line-height: 1.08; }

.sd-tile__dek {
	font-family: var(--sd-display);
	font-size: .95rem;
	line-height: 1.4;
	color: rgba(255,255,255,.86);
	margin-top: .2rem;
	max-width: 52ch;
}
.sd-tile--big .sd-tile__dek { font-size: clamp(1rem, 1.15vw, 1.1rem); }

.sd-tile__meta {
	font-family: var(--sd-mono);
	font-size: .68rem;
	color: rgba(255,255,255,.68);
	letter-spacing: .05em;
	margin-top: .4rem;
	text-transform: uppercase;
}

/* --------- Text-only category slab --------- */
.sd-tile--slab {
	--slab: var(--sd-oxblood);
	background:
		radial-gradient(circle at 85% 15%, rgba(255,255,255,.08) 0, transparent 45%),
		radial-gradient(circle at 10% 85%, rgba(0,0,0,.25) 0, transparent 55%),
		var(--slab);
	border-color: color-mix(in oklab, var(--slab), black 35%);
}
.sd-tile--slab .sd-tile__title {
	font-family: var(--sd-display);
	font-style: italic;
	font-weight: 500;

	letter-spacing: -.015em;
	text-shadow: none;
	font-size: clamp(1.15rem, 1.7vw, 1.45rem);
	line-height: 1.15;
}
.sd-tile--slab .sd-tile__kicker {
	background: rgba(255,255,255,.12);
	border-color: rgba(255,255,255,.28);
}
.sd-tile--slab .sd-tile__dek {
	color: rgba(255,255,255,.85);
	font-family: var(--sd-display);
	font-style: italic;
}
.sd-tile--slab::before {
	content: "";
	position: absolute;
	top: 12px; right: 14px;
	width: 28px; height: 28px;
	border: 1px solid rgba(255,255,255,.4);
	border-radius: 50%;
	background:
		radial-gradient(circle at center, rgba(255,255,255,.1) 0 40%, transparent 42%);
	pointer-events: none;
}

/* ===================== MORE BUTTON ===================== */

.sd-more { text-align: center; margin: 1rem 0 2.4rem; }
.sd-btn {
	display: inline-block;
	padding: .8rem 1.6rem;
	border: 1px solid var(--sd-ink);
	background: var(--sd-ink);
	color: var(--sd-paper);
	font-family: var(--sd-sans);
	font-size: .85rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	transition: background .2s, color .2s, transform .2s;
}
.sd-btn:hover { background: var(--sd-oxblood); border-color: var(--sd-oxblood); transform: translateY(-2px); }

/* ===================== COLOPHON ===================== */

.sd-colophon {
	margin-top: 3rem;
	border-top: 3px double var(--sd-ink);
	padding: 2rem 0 1rem;
	color: var(--sd-ink);
}
.sd-colophon__top {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 1.5rem 2rem;
	align-items: start;
}
@media (max-width: 880px) {
	.sd-colophon__top { grid-template-columns: 1fr; }
}
.sd-colophon__mark { display: flex; align-items: center; gap: .6rem; }
.sd-colophon__dot  { color: var(--sd-oxblood); font-size: 1rem; }
.sd-colophon__brand { font-family: var(--sd-head); font-weight: 800; font-size: 1.15rem; letter-spacing: -.025em; }
.sd-colophon__copy {
	font-family: var(--sd-display); font-style: italic;
	color: var(--sd-ink-soft);
	max-width: 58ch; margin: 0; font-size: .95rem; line-height: 1.5;
}
.sd-colophon__nav {
	display: flex; flex-wrap: wrap; gap: .6rem 1.2rem;
	font-family: var(--sd-sans);
	font-size: .78rem;
	letter-spacing: .08em;
	text-transform: uppercase;
}
.sd-colophon__nav a { color: var(--sd-ink-soft); border-bottom: 1px solid transparent; padding-bottom: 2px; }
.sd-colophon__nav a:hover { color: var(--sd-oxblood); border-color: var(--sd-oxblood); }

.sd-colophon__bottom {
	margin-top: 1.5rem;
	padding-top: 1rem;
	border-top: 1px dotted var(--sd-hairline);
	display: flex; flex-wrap: wrap; gap: .4rem .8rem;
	font-family: var(--sd-mono);
	font-size: .72rem;
	color: var(--sd-fog);
	letter-spacing: .05em;
}
.sd-colophon__sep { color: var(--sd-hairline); }

/* ===================== MOTION ===================== */

@media (prefers-reduced-motion: no-preference) {
	.sd-masthead, .sd-mosaic, .sd-more, .sd-colophon {
		animation: sd-in .7s cubic-bezier(.2, .7, .2, 1) both;
	}
	.sd-masthead { animation-delay: .02s; }
	.sd-mosaic   { animation-delay: .15s; }
	.sd-more     { animation-delay: .4s; }
	.sd-colophon { animation-delay: .5s; }

	.sd-tile {
		animation: sd-tile-in .6s cubic-bezier(.2, .7, .2, 1) both;
	}
	/* cascade — first 28 tiles */
	.sd-tile:nth-child(1)  { animation-delay: .2s; }
	.sd-tile:nth-child(2)  { animation-delay: .24s; }
	.sd-tile:nth-child(3)  { animation-delay: .28s; }
	.sd-tile:nth-child(4)  { animation-delay: .32s; }
	.sd-tile:nth-child(5)  { animation-delay: .36s; }
	.sd-tile:nth-child(6)  { animation-delay: .40s; }
	.sd-tile:nth-child(7)  { animation-delay: .44s; }
	.sd-tile:nth-child(8)  { animation-delay: .48s; }
	.sd-tile:nth-child(9)  { animation-delay: .52s; }
	.sd-tile:nth-child(10) { animation-delay: .56s; }
	.sd-tile:nth-child(11) { animation-delay: .60s; }
	.sd-tile:nth-child(12) { animation-delay: .64s; }
	.sd-tile:nth-child(n+13) { animation-delay: .7s; }
}

@keyframes sd-in {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}
@keyframes sd-tile-in {
	from { opacity: 0; transform: translateY(14px) scale(.98); }
	to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ===================== RESPONSIVE ===================== */

@media (max-width: 1080px) {
	.sd-mosaic {
		grid-template-columns: repeat(3, 1fr);
		grid-auto-rows: 200px;
	}
	.sd-tile--big  { grid-column: span 2; grid-row: span 2; }
	.sd-tile--wide { grid-column: span 2; }
	.sd-tile--tall { grid-row: span 2; }
}
@media (max-width: 720px) {
	.sd-mosaic {
		grid-template-columns: repeat(2, 1fr);
		grid-auto-rows: 180px;
	}
	.sd-tile--big  { grid-column: span 2; grid-row: span 2; }
	.sd-tile--wide { grid-column: span 2; grid-row: span 1; }
	.sd-tile--tall { grid-column: span 1; grid-row: span 2; }
}
@media (max-width: 560px) {
	.sd-shell { padding: .8rem 1rem 2rem; }
	.sd-nameplate { grid-template-columns: 1fr; gap: .15rem; padding: 1rem 0 .4rem; }
	.sd-nameplate__flourish { display: none; }
	.sd-nameplate__title { font-size: clamp(2.6rem, 16vw, 4rem); }
	.sd-subplate { font-size: .95rem; padding: .15rem 0 .7rem; }
	.sd-subplate__motto::before, .sd-subplate__motto::after { width: 14px; margin: 0 .4rem; }
	.sd-mosaic {
		grid-template-columns: 1fr;
		grid-auto-rows: 200px;
	}
	.sd-tile,
	.sd-tile--big,
	.sd-tile--wide,
	.sd-tile--tall { grid-column: auto; grid-row: span 1; }
	.sd-tile--big  { grid-row: span 2; }
}

/* ===================== PRINT ===================== */

@media print {
	body.sd-front { background: #fff; }
	.sd-shell { max-width: none; padding: 0; }
	.sd-nav, .sd-more, .sd-colophon__bottom { display: none; }
	.sd-tile { break-inside: avoid; background: #fff; color: #000; border-color: #000; }
	.sd-tile__title, .sd-tile__dek { color: #000; text-shadow: none; }
	.sd-tile__veil { display: none; }
	a { color: #000; }
}
