/*
 * Nick Rogers Portfolio — Theme Styles
 *
 * Organization:
 *   1. Tokens (CSS variables)
 *   2. Reset
 *   3. Base
 *   4. A11y utilities
 *   5. Layout primitives (.port, .section)
 *   6. Components (nav, ticker, hero, work, expertise, market, footer)
 *   7. Pages (page, archive, single, post-card)
 *   8. WP core admin / block-editor compatibility
 *   9. Responsive breakpoints
 */

/* ── 1. Tokens ─────────────────────────────────────────────── */
:root {
	--c-bg: #0a0a08;
	--c-surface: #0d0d0b;
	--c-surface-2: #100d0d;
	--c-hairline: #1e1e1a;
	--c-text: #e8e4d8;
	--c-text-mute: #888780;
	--c-accent: #c0392b;
	--c-accent-hover: #a93226;

	--ff-display: 'Bebas Neue', sans-serif;
	--ff-mono: 'DM Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
	--ff-body: 'Barlow', system-ui, -apple-system, sans-serif;

	--container-pad: 40px;
	--section-pad-y: 60px;
}

/* ── 2. Reset ──────────────────────────────────────────────── */
* { box-sizing: border-box; margin: 0; padding: 0; }
img, svg, video { max-width: 100%; display: block; }

/* ── 3. Base ───────────────────────────────────────────────── */
html { scroll-behavior: smooth; }
body.port {
	font-family: var(--ff-body);
	background: var(--c-bg);
	color: var(--c-text);
	min-height: 100vh;
	overflow-x: hidden;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
a { color: inherit; }

/* ── 4. A11y utilities ─────────────────────────────────────── */
.screen-reader-text {
	position: absolute;
	clip: rect(1px, 1px, 1px, 1px);
	width: 1px; height: 1px;
	overflow: hidden;
	white-space: nowrap;
}
.screen-reader-text:focus {
	clip: auto;
	height: auto;
	width: auto;
	display: block;
	background: var(--c-accent);
	color: #fff;
	padding: 12px 18px;
	z-index: 100;
	left: 12px;
	top: 12px;
	text-decoration: none;
}

/* ── 5. Layout ─────────────────────────────────────────────── */
.section {
	padding: var(--section-pad-y) var(--container-pad);
	border-bottom: 1px solid var(--c-hairline);
}

.section-label {
	font-family: var(--ff-mono);
	font-size: 10px;
	letter-spacing: 3px;
	color: var(--c-accent);
	text-transform: uppercase;
	margin-bottom: 32px;
	display: flex;
	align-items: center;
	gap: 10px;
}
.section-label::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--c-hairline);
}

/* ── 6. Components ─────────────────────────────────────────── */

/* Nav */
.nav {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 20px var(--container-pad);
	border-bottom: 1px solid var(--c-hairline);
	position: relative;
	z-index: 10;
}
.nav-logo {
	font-family: var(--ff-display);
	font-size: 22px;
	letter-spacing: 3px;
	color: var(--c-text);
	text-decoration: none;
}
.nav-logo span { color: var(--c-accent); }
.nav-links {
	display: flex;
	gap: 28px;
	list-style: none;
}
.nav-links a {
	font-family: var(--ff-mono);
	font-size: 11px;
	color: var(--c-text-mute);
	text-decoration: none;
	letter-spacing: 2px;
	text-transform: uppercase;
	transition: color 0.2s;
}
.nav-links a:hover,
.nav-links .current-menu-item a { color: var(--c-text); }

.nav-cta {
	font-family: var(--ff-mono);
	font-size: 11px;
	letter-spacing: 2px;
	padding: 8px 18px;
	border: 1px solid var(--c-accent);
	color: var(--c-accent);
	background: none;
	cursor: pointer;
	text-transform: uppercase;
	text-decoration: none;
	transition: all 0.2s;
	display: inline-block;
}
.nav-cta:hover { background: var(--c-accent); color: #fff; }

/* Ticker */
.ticker {
	background: var(--c-surface-2);
	border-top: 1px solid var(--c-hairline);
	border-bottom: 1px solid var(--c-hairline);
	padding: 10px 0;
	overflow: hidden;
	white-space: nowrap;
}
.ticker-inner {
	display: inline-block;
	animation: ticker 28s linear infinite;
}
.ticker-item {
	display: inline-block;
	font-family: var(--ff-mono);
	font-size: 11px;
	color: var(--c-text-mute);
	letter-spacing: 2px;
	padding: 0 32px;
	text-transform: uppercase;
}
.ticker-item .dot { color: var(--c-accent); margin-right: 32px; }
@keyframes ticker {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
	.ticker-inner { animation: none; }
}

/* Hero */
.hero {
	padding: 80px var(--container-pad) var(--section-pad-y);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: center;
	border-bottom: 1px solid var(--c-hairline);
	position: relative;
}
.hero::before {
	content: '';
	position: absolute;
	top: 0; right: 0;
	width: 400px; height: 400px;
	background: radial-gradient(circle, rgba(192, 57, 43, 0.06) 0%, transparent 70%);
	pointer-events: none;
}
.hero-eyebrow {
	font-family: var(--ff-mono);
	font-size: 11px;
	letter-spacing: 3px;
	color: var(--c-accent);
	text-transform: uppercase;
	margin-bottom: 16px;
	display: flex;
	align-items: center;
	gap: 10px;
}
.hero-eyebrow::before {
	content: '';
	display: block;
	width: 24px; height: 1px;
	background: var(--c-accent);
}
.hero-name {
	font-family: var(--ff-display);
	font-size: clamp(48px, 7vw, 72px);
	line-height: 0.95;
	letter-spacing: 2px;
	margin-bottom: 20px;
}
.hero-name .accent { color: var(--c-accent); }
.hero-title {
	font-size: 14px;
	font-weight: 300;
	color: var(--c-text-mute);
	line-height: 1.7;
	max-width: 380px;
	margin-bottom: 32px;
}
.hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; }

.btn-primary,
.btn-secondary {
	font-family: var(--ff-mono);
	font-size: 11px;
	letter-spacing: 2px;
	text-transform: uppercase;
	padding: 12px 24px;
	cursor: pointer;
	transition: all 0.2s;
	text-decoration: none;
	display: inline-block;
	border: none;
}
.btn-primary { background: var(--c-accent); color: #fff; }
.btn-primary:hover { background: var(--c-accent-hover); }
.btn-secondary {
	background: none;
	color: var(--c-text-mute);
	border: 1px solid var(--c-hairline);
}
.btn-secondary:hover { border-color: var(--c-text-mute); color: var(--c-text); }

.hero-stats {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1px;
	background: var(--c-hairline);
	border: 1px solid var(--c-hairline);
}
.stat-box {
	background: var(--c-surface);
	padding: 28px 24px;
	position: relative;
}
.stat-box.highlight { background: var(--c-surface-2); }
.stat-num {
	font-family: var(--ff-display);
	font-size: 44px;
	color: var(--c-text);
	line-height: 1;
	margin-bottom: 6px;
}
.stat-num span { color: var(--c-accent); }
.stat-label {
	font-family: var(--ff-mono);
	font-size: 10px;
	letter-spacing: 2px;
	color: var(--c-text-mute);
	text-transform: uppercase;
}

/* Selected Work */
.work-grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 1px;
	background: var(--c-hairline);
}
.work-card {
	background: var(--c-surface);
	padding: 28px 24px;
	cursor: pointer;
	transition: background 0.2s;
	position: relative;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	display: block;
}
.work-card:hover { background: #111110; }
.work-card::after {
	content: '';
	position: absolute;
	bottom: 0; left: 0; right: 0;
	height: 2px;
	background: var(--c-accent);
	transform: scaleX(0);
	transition: transform 0.2s;
	transform-origin: left;
}
.work-card:hover::after { transform: scaleX(1); }
.work-tag {
	font-family: var(--ff-mono);
	font-size: 10px;
	letter-spacing: 2px;
	color: var(--c-accent);
	text-transform: uppercase;
	margin-bottom: 12px;
}
.work-company {
	font-family: var(--ff-display);
	font-size: 26px;
	letter-spacing: 1px;
	margin-bottom: 8px;
}
.work-role {
	font-size: 12px;
	color: var(--c-text-mute);
	font-weight: 300;
	margin-bottom: 16px;
}
.work-kpi {
	font-size: 13px;
	color: var(--c-text);
	font-weight: 500;
	margin-bottom: 4px;
}
.work-kpi-label {
	font-family: var(--ff-mono);
	font-size: 10px;
	color: var(--c-text-mute);
	letter-spacing: 1px;
}
.work-detail {
	margin-top: 12px;
	font-size: 12px;
	color: var(--c-text-mute);
	line-height: 1.6;
}

/* Capabilities */
.expertise-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1px;
	background: var(--c-hairline);
}
.expertise-item {
	background: var(--c-surface);
	padding: 20px;
}
.expertise-num {
	font-family: var(--ff-mono);
	font-size: 10px;
	color: var(--c-accent);
	margin-bottom: 10px;
	letter-spacing: 1px;
}
.expertise-name {
	font-size: 13px;
	font-weight: 500;
	color: var(--c-text);
	line-height: 1.4;
}

/* Verticals */
.market-grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 12px;
}
.market-pill {
	background: var(--c-surface-2);
	border: 1px solid var(--c-hairline);
	padding: 14px 18px;
	display: flex;
	align-items: center;
	gap: 12px;
}
.market-dot {
	width: 6px; height: 6px;
	border-radius: 50%;
	background: var(--c-accent);
	flex-shrink: 0;
}
.market-text {
	font-size: 13px;
	color: var(--c-text-mute);
}

/* Footer strip */
.footer-strip {
	padding: 24px var(--container-pad);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
	flex-wrap: wrap;
}
.footer-mono,
.footer-mono a {
	font-family: var(--ff-mono);
	font-size: 11px;
	color: var(--c-text-mute);
	letter-spacing: 1px;
	text-decoration: none;
}
.footer-mono a:hover { color: var(--c-text); }
.footer-links {
	display: flex;
	gap: 20px;
	list-style: none;
}
.footer-links a {
	font-family: var(--ff-mono);
	font-size: 10px;
	color: var(--c-text-mute);
	letter-spacing: 2px;
	text-transform: uppercase;
	text-decoration: none;
	transition: color 0.2s;
}
.footer-links a:hover { color: var(--c-text); }

/* ── 7. Pages (blog / static) ──────────────────────────────── */
.page-content,
.post-single { max-width: 760px; }
.page-title,
.post-single__title {
	font-family: var(--ff-display);
	font-size: clamp(36px, 5vw, 56px);
	letter-spacing: 1px;
	margin-bottom: 24px;
}
.page-body,
.post-single__body {
	font-size: 15px;
	line-height: 1.8;
	color: var(--c-text);
}
.page-body p,
.post-single__body p { margin-bottom: 1em; }
.page-body a,
.post-single__body a { color: var(--c-accent); }
.page-body h2, .post-single__body h2 {
	font-family: var(--ff-display);
	font-size: 32px;
	margin: 1.5em 0 0.5em;
	letter-spacing: 1px;
}
.page-body h3, .post-single__body h3 {
	font-family: var(--ff-display);
	font-size: 22px;
	margin: 1.5em 0 0.5em;
	letter-spacing: 1px;
}
.page-body ul, .post-single__body ul,
.page-body ol, .post-single__body ol {
	margin: 0 0 1em 1.5em;
}

.post-single__meta {
	font-family: var(--ff-mono);
	font-size: 11px;
	color: var(--c-text-mute);
	letter-spacing: 2px;
	text-transform: uppercase;
	margin-bottom: 32px;
}
.post-single__media { margin-bottom: 32px; border: 1px solid var(--c-hairline); }

/* Archive / post list */
.post-list {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 1px;
	background: var(--c-hairline);
}
.post-card {
	background: var(--c-surface);
	transition: background 0.2s;
}
.post-card:hover { background: #111110; }
.post-card__link {
	display: block;
	padding: 28px 24px;
	text-decoration: none;
	color: inherit;
}
.post-card__meta {
	font-family: var(--ff-mono);
	font-size: 10px;
	letter-spacing: 2px;
	color: var(--c-accent);
	text-transform: uppercase;
	margin-bottom: 12px;
}
.post-card__title {
	font-family: var(--ff-display);
	font-size: 24px;
	letter-spacing: 1px;
	margin-bottom: 12px;
}
.post-card__excerpt {
	font-size: 13px;
	color: var(--c-text-mute);
	line-height: 1.6;
}

.post-empty {
	color: var(--c-text-mute);
	font-size: 14px;
}

/* WP pagination */
.pagination, .nav-links.pagination {
	margin-top: 40px;
	display: flex;
	gap: 12px;
	font-family: var(--ff-mono);
	font-size: 11px;
	letter-spacing: 2px;
	text-transform: uppercase;
}
.pagination a, .pagination .current {
	padding: 8px 14px;
	border: 1px solid var(--c-hairline);
	color: var(--c-text-mute);
	text-decoration: none;
}
.pagination .current { color: var(--c-accent); border-color: var(--c-accent); }

/* ── 8. WP admin bar offset (rare for FE) ──────────────────── */
body.admin-bar .nav { position: relative; }

/* ── 9. Responsive ─────────────────────────────────────────── */
@media (max-width: 960px) {
	.hero { grid-template-columns: 1fr; padding-top: 48px; }
	.work-grid,
	.expertise-grid,
	.market-grid,
	.post-list { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
	:root { --container-pad: 20px; --section-pad-y: 40px; }
	.nav { flex-wrap: wrap; gap: 16px; }
	.nav-links { gap: 16px; flex-wrap: wrap; order: 3; width: 100%; }
	.work-grid,
	.expertise-grid,
	.market-grid,
	.post-list,
	.hero-stats { grid-template-columns: 1fr; }
	.hero-stats .stat-box { padding: 20px 18px; }
	.footer-strip { justify-content: flex-start; }
}
