/* =========================================================================
   Project detail pages — shared overlay stylesheet.
   Loaded after main.css to bring detail pages into the new design system.
   Targets the existing class names (.project-content, .feature-section,
   .feature-list, .tech-item, .tech-stack, .status-section, etc.) so no
   markup restructure is needed.
   ========================================================================= */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap");

:root {
	--pd-bg: #0a0d12;
	--pd-bg-elev: #11151c;
	--pd-bg-elev-2: #161b24;
	--pd-surface: rgba(255, 255, 255, 0.03);
	--pd-surface-strong: rgba(255, 255, 255, 0.06);
	--pd-border: rgba(255, 255, 255, 0.08);
	--pd-border-strong: rgba(255, 255, 255, 0.16);
	--pd-text: #f4f5f7;
	--pd-text-dim: rgba(244, 245, 247, 0.65);
	--pd-text-faint: rgba(244, 245, 247, 0.4);
	--pd-accent: #5eead4;
	--pd-accent-soft: rgba(94, 234, 212, 0.12);
	--pd-violet: #a78bfa;
	--pd-font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
	--pd-font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

/* ----- Page reset ----- */

html, body {
	background: var(--pd-bg) !important;
	color: var(--pd-text);
	font-family: var(--pd-font-sans) !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	scroll-behavior: smooth;
	font-size: 16px !important;
}

body {
	overflow-x: hidden;
	line-height: 1.65;
	font-weight: 400;
	letter-spacing: 0;
}

body.is-preload * {
	animation: none !important;
	transition: none !important;
}

#bg, #bg::before, #bg::after {
	display: none !important;
	background: none !important;
}

#wrapper, #main {
	background: transparent !important;
	border: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
	max-width: none !important;
	width: 100% !important;
	opacity: 1 !important;
	filter: none !important;
	transform: none !important;
	transition: none !important;
}

#wrapper { padding-top: 0 !important; }

a {
	color: inherit;
	border-bottom: none !important;
	text-decoration: none;
	transition: color 0.2s ease;
}

p { margin: 0 0 1em 0; color: var(--pd-text-dim); line-height: 1.7; }
strong, b { color: var(--pd-text); font-weight: 600; }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--pd-font-sans) !important;
	color: var(--pd-text) !important;
	font-weight: 700 !important;
	text-transform: none !important;
	letter-spacing: -0.01em !important;
	line-height: 1.2 !important;
	margin: 0 0 0.6em !important;
}

ul, ol { list-style: none; padding: 0; margin: 0; }

::selection { background: var(--pd-accent); color: #0a0d12; }

/* ----- Ambient bg ----- */

body::before {
	content: "";
	position: fixed;
	inset: 0;
	z-index: -2;
	background:
		radial-gradient(1100px 700px at 20% 0%, rgba(94, 234, 212, 0.08), transparent 60%),
		radial-gradient(900px 600px at 90% 100%, rgba(167, 139, 250, 0.05), transparent 60%),
		var(--pd-bg);
	pointer-events: none;
}

body::after {
	content: "";
	position: fixed;
	inset: 0;
	z-index: -1;
	background-image:
		linear-gradient(to right, rgba(255, 255, 255, 0.025) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
	background-size: 64px 64px;
	mask-image: radial-gradient(ellipse 70% 60% at 50% 30%, black, transparent 90%);
	-webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 30%, black, transparent 90%);
	pointer-events: none;
}

/* ----- Top back-bar (injected via JS or anchor inside body) ----- */

.pd-back-bar {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 28px;
	background: rgba(10, 13, 18, 0.7);
	backdrop-filter: saturate(160%) blur(14px);
	-webkit-backdrop-filter: saturate(160%) blur(14px);
	border-bottom: 1px solid var(--pd-border);
	font-family: var(--pd-font-mono);
	font-size: 13px;
}

.pd-back {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--pd-text-dim);
	transition: color 0.2s ease, gap 0.2s ease;
}

.pd-back:hover { color: var(--pd-accent); gap: 14px; }

.pd-back .arr { color: var(--pd-accent); }

.pd-meta {
	color: var(--pd-text-faint);
	display: flex;
	align-items: center;
	gap: 10px;
}

.pd-meta .dot {
	width: 8px;
	height: 8px;
	background: var(--pd-accent);
	border-radius: 50%;
	box-shadow: 0 0 10px rgba(94, 234, 212, 0.5);
	animation: pd-pulse 2.4s ease-in-out infinite;
}

@keyframes pd-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50% { opacity: 0.5; transform: scale(0.8); }
}

@media (max-width: 600px) {
	.pd-back-bar { padding: 12px 18px; }
	.pd-meta { display: none; }
}

/* ----- Header ----- */

#header {
	padding: 140px 28px 40px !important;
	max-width: 1100px;
	margin: 0 auto !important;
	text-align: left !important;
	background: transparent !important;
	border: 0 !important;
	display: block !important;
}

#header .content,
#header .inner {
	margin: 0 !important;
	padding: 0 !important;
	max-width: none !important;
	background: transparent !important;
	border: 0 !important;
	text-align: left !important;
}

#header h1 {
	font-size: clamp(2.2rem, 5vw, 3.8rem) !important;
	font-weight: 800 !important;
	letter-spacing: -0.025em !important;
	line-height: 1.05 !important;
	margin: 0 0 0.4em !important;
	background: linear-gradient(180deg, #ffffff 0%, #c9d1da 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent !important;
}

#header p {
	font-size: clamp(1.05rem, 1.4vw, 1.25rem);
	color: var(--pd-text-dim);
	max-width: 720px;
	margin: 0;
	font-weight: 400;
}

/* ----- Project content frame ----- */

.project-content {
	max-width: 1100px !important;
	margin: 0 auto !important;
	padding: 40px 28px 100px !important;
	color: var(--pd-text);
}

.project-content > .project-header {
	text-align: left !important;
	margin-bottom: 2em !important;
}

/* ----- Feature sections ----- */

.feature-section {
	margin: 56px 0 !important;
}

.feature-section h2 {
	font-size: clamp(1.4rem, 2.2vw, 1.85rem) !important;
	border-bottom: 1px solid var(--pd-border) !important;
	padding-bottom: 0.5em !important;
	margin-bottom: 1em !important;
	color: var(--pd-text) !important;
	display: flex;
	align-items: baseline;
	gap: 14px;
}

.feature-section h2::before {
	content: "//";
	font-family: var(--pd-font-mono);
	font-size: 0.7em;
	color: var(--pd-accent);
	font-weight: 500;
	letter-spacing: 0;
}

.feature-section p {
	font-size: 1.05rem;
	color: var(--pd-text-dim);
	line-height: 1.8;
}

/* ----- Feature list (bullets) ----- */

.feature-list { display: flex; flex-direction: column; gap: 14px; }

.feature-list li {
	position: relative;
	padding: 16px 18px 16px 44px !important;
	margin: 0 !important;
	background: var(--pd-bg-elev);
	border: 1px solid var(--pd-border);
	border-radius: 10px;
	color: var(--pd-text-dim);
	line-height: 1.55;
	transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.2s ease;
}

.feature-list li:hover {
	border-color: var(--pd-border-strong);
	background: var(--pd-bg-elev-2);
	transform: translateX(2px);
}

.feature-list li::before {
	content: "▸" !important;
	position: absolute !important;
	left: 18px !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	color: var(--pd-accent) !important;
	font-size: 14px !important;
	font-family: var(--pd-font-mono) !important;
}

/* ----- Tech stack pills ----- */

.tech-stack {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 8px !important;
	margin: 1em 0 !important;
}

.tech-item {
	background: var(--pd-surface) !important;
	border: 1px solid var(--pd-border) !important;
	color: var(--pd-text-dim) !important;
	padding: 6px 12px !important;
	border-radius: 6px !important;
	font-family: var(--pd-font-mono) !important;
	font-size: 12.5px !important;
	letter-spacing: 0 !important;
	transition: color 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.tech-item:hover {
	color: var(--pd-accent);
	border-color: var(--pd-accent);
	background: var(--pd-accent-soft);
}

/* ----- Status section ----- */

.status-section {
	background: var(--pd-bg-elev) !important;
	border: 1px solid var(--pd-border) !important;
	border-left: 3px solid var(--pd-accent) !important;
	padding: 28px !important;
	border-radius: 12px !important;
	margin: 48px 0 !important;
}

.status-section h2 {
	margin-top: 0 !important;
	border-bottom: 0 !important;
	padding-bottom: 0 !important;
	font-size: 1.1rem !important;
}

.status-section h2::before {
	content: "●" !important;
	color: var(--pd-accent) !important;
	font-size: 0.6em;
	letter-spacing: 0;
}

.status-section p {
	color: var(--pd-text-dim) !important;
	margin-bottom: 0.6em;
	line-height: 1.7;
}

.status-section p:last-child { margin-bottom: 0; }

/* ----- Buttons & links ----- */

.button, a.button {
	display: inline-flex !important;
	align-items: center !important;
	gap: 10px;
	padding: 12px 20px !important;
	background: var(--pd-accent) !important;
	color: #0a0d12 !important;
	border: 1px solid transparent !important;
	border-radius: 10px !important;
	font-family: var(--pd-font-sans) !important;
	font-size: 14.5px !important;
	font-weight: 500 !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
	height: auto !important;
	line-height: 1.2 !important;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
	box-shadow: 0 0 0 0 rgba(94, 234, 212, 0);
	cursor: pointer;
}

.button:hover, a.button:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 28px -8px rgba(94, 234, 212, 0.35);
}

.button.alt, a.button.alt {
	background: var(--pd-surface) !important;
	color: var(--pd-text) !important;
	border-color: var(--pd-border) !important;
}

.button.alt:hover, a.button.alt:hover {
	border-color: var(--pd-border-strong) !important;
	background: var(--pd-surface-strong) !important;
}

/* ----- Embedded media ----- */

.project-content img,
.project-content video {
	max-width: 100%;
	height: auto;
	border-radius: 12px;
	border: 1px solid var(--pd-border);
	display: block;
	margin: 20px 0;
}

/* ----- Footer ----- */

#footer {
	border-top: 1px solid var(--pd-border) !important;
	padding: 24px 28px !important;
	text-align: center !important;
	color: var(--pd-text-faint) !important;
	font-family: var(--pd-font-mono) !important;
	font-size: 12px !important;
	max-width: none !important;
	margin: 0 !important;
	background: transparent !important;
}

#footer .copyright,
#footer .copyright a {
	color: var(--pd-text-faint) !important;
}

/* ----- Focus ----- */
:focus-visible {
	outline: 2px solid var(--pd-accent);
	outline-offset: 3px;
	border-radius: 4px;
}

/* ----- Responsive ----- */

@media (max-width: 760px) {
	#header { padding: 120px 20px 32px !important; }
	.project-content { padding: 24px 20px 80px !important; }
}
