:root {
	--bg: #080808;
	--panel: #101010;
	--panel-soft: #141414;
	--line: #232323;
	--line-soft: #1b1b1b;
	--text: #f4f4f4;
	--muted: #aaaaaa;
	--link: #dfdfdf;
}

* {
	box-sizing: border-box;
}

html,
body {
	margin: 0;
	padding: 0;
}

body {
	background: var(--bg);
	color: var(--text);
	font-family: "Manrope", "Segoe UI", sans-serif;
	line-height: 1.55;
}

a {
	color: var(--link);
	text-underline-offset: 3px;
}

.page-wrap {
	min-height: 100vh;
}

.container {
	width: min(820px, calc(100% - 2rem));
	margin-inline: auto;
}

.topbar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	padding: 1rem 0 0.95rem;
	border-bottom: 1px solid var(--line);
	position: sticky;
	top: 0;
	backdrop-filter: blur(6px);
	background: rgba(8, 8, 8, 0.82);
	z-index: 20;
}

.brand {
	text-decoration: none;
	font-weight: 700;
	letter-spacing: 0.01em;
}

.topnav {
	display: flex;
	gap: 1rem;
}

.topnav a {
	text-decoration: none;
	font-size: 0.9rem;
	color: var(--muted);
}

.topnav a:hover {
	color: var(--text);
}

.hero {
	display: grid;
	grid-template-columns: 1fr 200px;
	gap: 1.25rem;
	padding: 2.4rem 0;
	border-bottom: 1px solid var(--line);
}

.hero h1 {
	margin: 0;
	font-size: clamp(2.2rem, 5vw, 3.55rem);
	line-height: 1.1;
	letter-spacing: -0.03em;
}

.wave {
	display: inline-block;
	animation: wave 1.9s ease-in-out infinite;
	transform-origin: 70% 70%;
}

.lead {
	margin: 0.95rem 0 0;
	font-size: 1rem;
	color: #e7e7e7;
}

.placeholder {
	color: var(--muted);
}

.sublead {
	margin: 0.7rem 0 0;
	color: var(--muted);
	font-size: 0.95rem;
}

.support-line {
	margin: 0.5rem 0 0;
	color: var(--muted);
	font-size: 0.88rem;
}

.real {
	color: #e3f6ce;
}

.quick-links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.72rem;
	margin-top: 0.95rem;
}

.quick-links a {
	color: #e6e6e6;
	font-weight: 500;
	font-size: 0.93rem;
}

.quick-links a + a::before {
	content: "•";
	color: #4b4b4b;
	margin-right: 0.72rem;
}

.hero-photo {
	margin: 0;
	display: flex;
	align-items: flex-start;
	justify-content: flex-end;
}

.hero-photo img {
	width: 200px;
	height: 200px;
	object-fit: cover;
	border-radius: 12px;
	border: 1px solid #2b2b2b;
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.3);
}

.section {
	padding: 2.1rem 0;
	border-bottom: 1px solid var(--line);
}

.section h2 {
	margin: 0;
	font-size: 1.28rem;
	letter-spacing: -0.01em;
}

.section-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1rem;
}

.view-more {
	color: var(--muted);
	font-size: 0.9rem;
}

.tablist {
	border: 1px solid var(--line);
	border-radius: 8px;
	overflow: hidden;
	display: inline-flex;
}

.tab {
	border: 0;
	background: transparent;
	color: var(--muted);
	padding: 0.4rem 0.78rem;
	font: inherit;
	font-size: 0.9rem;
	cursor: pointer;
}

.tab.active {
	background: var(--panel-soft);
	color: var(--text);
}

.panel {
	display: none;
}

.panel.active {
	display: block;
}

.entry {
	padding: 0.95rem 0.95rem 0.75rem;
	border: 1px solid var(--line-soft);
	border-radius: 10px;
	background: #0d0d0d;
	margin-bottom: 0.75rem;
}

.entry h3 {
	margin: 0;
	font-size: 1.04rem;
}

.meta {
	margin: 0.18rem 0 0;
	color: var(--muted);
	font-size: 0.89rem;
}

.entry ul {
	margin: 0.65rem 0 0;
	padding-left: 1.1rem;
}

.cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.9rem;
}

.project-card {
	display: grid;
	grid-template-columns: 230px 1fr;
	gap: 0;
	border: 1px solid var(--line-soft);
	border-radius: 11px;
	background: #0e0e0e;
	overflow: hidden;
}

.project-media {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.media-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(145deg, #171717, #101010);
	color: #8f8f8f;
	font-size: 0.85rem;
	letter-spacing: 0.01em;
	border-right: 1px solid var(--line-soft);
}

.card-body {
	padding: 0.85rem 0.95rem;
}

.card-body h3 {
	margin: 0;
	font-size: 1.03rem;
}

.card-body p {
	margin: 0.3rem 0 0;
	color: var(--muted);
	font-size: 0.9rem;
}

.chips {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	margin-top: 0.6rem;
}

.chips span {
	border: 1px solid #2a2a2a;
	border-radius: 999px;
	padding: 0.18rem 0.5rem;
	font-size: 0.74rem;
	color: #d0d0d0;
}

.card-links {
	display: flex;
	gap: 0.75rem;
	margin-top: 0.62rem;
}

.card-links a {
	font-size: 0.88rem;
}

.posts-list {
	display: grid;
	gap: 0.55rem;
}

.posts-list a {
	text-decoration: none;
	border-bottom: 1px solid var(--line-soft);
	padding: 0.58rem 0;
	display: flex;
	justify-content: space-between;
	gap: 0.75rem;
	align-items: baseline;
}

.posts-list a span {
	color: #e2e2e2;
}

.posts-list a small {
	color: #8f8f8f;
	font-size: 0.76rem;
}

.facts-grid {
	display: grid;
	gap: 0.72rem;
}

.fact-row {
	display: grid;
	grid-template-columns: 210px 1fr;
	gap: 0.9rem;
	padding: 0.58rem 0;
	border-bottom: 1px solid var(--line-soft);
}

.fact-row span {
	color: #cfcfcf;
	font-size: 0.88rem;
	font-weight: 600;
}

.fact-row p {
	margin: 0;
	color: var(--muted);
	font-size: 0.9rem;
}

#contact p {
	margin: 0.32rem 0;
	color: var(--muted);
	font-size: 0.93rem;
}

.footer {
	padding: 1rem 0 1.8rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	color: var(--muted);
}

.footer p {
	margin: 0;
	font-size: 0.84rem;
}

.footer-links {
	display: flex;
	gap: 0.8rem;
}

.footer-links a {
	color: var(--muted);
	text-decoration: none;
	font-size: 0.9rem;
}

.reveal {
	opacity: 0;
	transform: translateY(12px);
	transition: opacity 0.55s ease, transform 0.55s ease;
}

.reveal.is-visible {
	opacity: 1;
	transform: none;
}

@keyframes wave {
	0%,
	100% {
		transform: rotate(0deg);
	}
	25% {
		transform: rotate(18deg);
	}
	50% {
		transform: rotate(0deg);
	}
	75% {
		transform: rotate(12deg);
	}
}

@media (max-width: 860px) {
	.hero {
		grid-template-columns: 1fr;
		gap: 1rem;
	}

	.hero-photo {
		justify-content: flex-start;
	}

	.project-card {
		grid-template-columns: 1fr;
	}

	.project-media {
		aspect-ratio: 16 / 9;
		border-right: 0;
		border-bottom: 1px solid var(--line-soft);
	}

	.fact-row {
		grid-template-columns: 1fr;
		gap: 0.35rem;
	}

	.cards {
		grid-template-columns: 1fr;
	}

	.footer {
		flex-direction: column;
		align-items: flex-start;
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation: none !important;
		transition: none !important;
	}

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