/**
 * Custom Styles — Agent Driven Development
 *
 * Styles that supplement theme.json design tokens.
 *
 * @package add
 */

/* ---- Skip Link ---- */

.add-skip-link {
	position: absolute;
	top: -100%;
	left: 0;
	z-index: 10000;
	padding: 0.75rem 1.5rem;
	background: var(--wp--preset--color--accent, #355E3B);
	color: #fff;
	font-weight: 600;
	text-decoration: none;
	border-radius: 0 0 6px 0;
}

.add-skip-link:focus {
	top: 0;
}

/* ---- Screen Reader Text (WordPress standard) ---- */

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

/* ---- Copy button status (screen reader only) ---- */

.add-copy-status {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
}

/* ---- Noscript fallback — ensure content visible without JS ---- */

.add-reveal {
	opacity: 1;
	transform: none;
}

/* ---- Reading Time ---- */

.add-reading-time {
	color: var(--wp--preset--color--secondary, #64748b);
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: var(--wp--preset--spacing--40, 1rem);
}

/* ---- Section Break (em dash separator) ---- */

.wp-block-separator.is-style-section-break {
	border: none;
	text-align: center;
	max-width: 42rem;
	margin-left: auto;
	margin-right: auto;
}

.wp-block-separator.is-style-section-break::before {
	content: "\2014";
	display: block;
	color: var(--wp--preset--color--secondary, #64748b);
	font-size: var(--wp--preset--font-size--large, 1.125rem);
	line-height: 1;
}

/* ---- Post terms (category badges) ---- */

.wp-block-post-terms a {
	background: var(--wp--preset--color--bg-medium, #f1f5f9);
	color: var(--wp--preset--color--muted, #475569);
	padding: 0.15em 0.6em;
	border-radius: 3px;
	text-decoration: none;
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.wp-block-post-terms a:hover {
	background: var(--wp--preset--color--accent, #355E3B);
	color: var(--wp--preset--color--contrast, #fff);
}

/* ---- Author Bio ---- */

.is-style-rounded img {
	border-radius: 50%;
	object-fit: cover;
}

/* ---- Blockquote (for Office Space quotes and similar) ---- */

.wp-block-quote cite,
.wp-block-pullquote cite {
	font-style: normal;
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	color: var(--wp--preset--color--secondary, #64748b);
}

/* ---- Smooth scroll for skip links and anchors ---- */

html {
	scroll-behavior: smooth;
}

/* ---- Focus styles for accessibility ---- */

:focus-visible {
	outline: 2px solid var(--wp--preset--color--accent, #355E3B);
	outline-offset: 2px;
}

/* ---- Dark mode overrides ---- */

[data-theme="dark"] {
	--wp--preset--color--primary: #f8fafc;
	--wp--preset--color--secondary: #94a3b8;
	--wp--preset--color--accent: #34d399;
	--wp--preset--color--base: #f1f5f9;
	--wp--preset--color--contrast: #0f172a;
	--wp--preset--color--bg-light: #1e293b;
	--wp--preset--color--bg-medium: #162032;
	--wp--preset--color--border: #334155;
	--wp--preset--color--muted: #cbd5e1;
	--wp--preset--color--subtle: #94a3b8;
	color-scheme: dark;
}

[data-theme="dark"] body {
	background-color: var(--wp--preset--color--contrast);
	color: var(--wp--preset--color--base);
}

[data-theme="dark"] .wp-block-post-terms a {
	background: var(--wp--preset--color--bg-medium);
	color: var(--wp--preset--color--muted);
}

[data-theme="dark"] .wp-block-post-terms a:hover {
	background: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--contrast);
}

/* ---- Dark mode toggle button ---- */

.add-dark-mode-toggle {
	background: none;
	border: 1px solid var(--wp--preset--color--border, #e2e8f0);
	border-radius: 4px;
	padding: 0.35em 0.6em;
	cursor: pointer;
	color: var(--wp--preset--color--secondary, #64748b);
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	line-height: 1;
	transition: border-color 0.2s, color 0.2s;
}

.add-dark-mode-toggle:hover {
	border-color: var(--wp--preset--color--accent, #355E3B);
	color: var(--wp--preset--color--primary, #0f172a);
}

/* ---- Print styles ---- */

@media print {
	.add-progress-bar,
	.add-dark-mode-toggle,
	.wp-block-navigation,
	.wp-block-buttons {
		display: none;
	}

	body {
		font-size: 12pt;
		line-height: 1.5;
		color: #000;
		background: #fff;
	}
}
