@font-face {
  font-family: 'FK Raster Compact Smooth';
  src: url('fonts/FKRasterRomanCompactTrial-Smooth.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  /* 5-tone grayscale: T1 (bg) → T5 (heading) */
  --t1: #212121;   /* background */
  --t2: #2c2c2c;   /* dividers, borders */
  --t3: #8a8a8a;   /* muted — metadata, labels */
  --t4: #c2c2c2;   /* body — readable prose */
  --t5: #ebebeb;   /* heading — primary text */

  --color-bg: var(--t1);
  --color-text: var(--t5);
  --color-body: var(--t4);
  --color-muted: var(--t3);
  --color-divider: var(--t2);
  --color-accent: #E05A33;
  --font-display: 'FK Raster Compact Smooth', monospace;
  --font-mono: 'JetBrains Mono', monospace;
  --font-body: 'Inter', system-ui, sans-serif;
  --max-width: 1100px;
  --side-padding: 2.5rem;
}

html {
  font-size: 16px;
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='20' viewBox='0 0 16 20'%3E%3Cpath d='M0 0 L0 16 L4.5 12.5 L7 19 L9.5 18 L7 11.5 L12.5 11.5 Z' fill='%23E05A33'/%3E%3C/svg%3E") 0 0, auto;
  scroll-behavior: smooth;
}

a, button, [role="button"] {
  cursor: pointer;
}

body {
  background-color: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-weight: 300;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main, section {
  flex: 1;
}

/* ── Load animations ─────────────────────────────── */

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

h1 {
  animation: fadeUp 0.7s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0; }
}

.typewriter-cursor {
  display: inline-block;
  width: 3px;
  height: 0.85em;
  background: var(--color-accent);
  margin-left: 4px;
  vertical-align: middle;
  position: relative;
  top: -0.05em;
}

header nav {
  animation: fadeUp 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.1s both;
}

main, .about-page {
  animation: fadeUp 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.2s both;
}

/* ── Header ──────────────────────────────────────── */

header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  width: 100%;
  padding: 6rem max(var(--side-padding), calc((100% - var(--max-width)) / 2 + var(--side-padding))) 4rem;
}

h1 {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 8.5vw, 6.5rem);
  font-weight: normal;
  letter-spacing: clamp(2px, 1vw, 7px);
  line-height: 1;
  white-space: nowrap;
}

nav {
  display: flex;
  gap: 1.5rem;
  align-items: center;
}

nav a {
  font-family: var(--font-mono);
  font-size: clamp(0.6875rem, 0.85vw, 0.875rem);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text);
  text-decoration: none;
  transition: color 0.15s ease;
}

nav a:hover {
  color: var(--color-accent);
}

/* ── Nav active state ────────────────────────────── */

nav a.nav-active {
  color: var(--color-accent);
}

header a {
  text-decoration: none;
  color: inherit;
  transition: color 0.15s ease;
}

header a:hover {
  color: var(--color-accent);
}

/* ── About page ──────────────────────────────────── */

.about-page {
  width: 100%;
  padding: 3rem max(var(--side-padding), calc((100% - var(--max-width)) / 2 + var(--side-padding))) 8rem;
  border-top: 1px solid var(--color-divider);
  display: grid;
  grid-template-columns: clamp(280px, 45vw, 660px) 1fr;
  gap: clamp(2rem, 3vw, 4rem);
  align-items: stretch;
}

.about-page-image {
  width: 100%;
}

.about-page-image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: 2px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  filter: contrast(1.1);
}

.about-page-text {
  padding-top: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.about-page-text p {
  font-family: var(--font-mono);
  font-size: clamp(1.125rem, 1.5vw, 1.375rem);
  font-weight: 400;
  line-height: 1.7;
  color: var(--color-body);
  letter-spacing: -0.02em;
}

.about-page-text p + p {
  margin-top: 2rem;
}

.about-role {
  font-size: clamp(1.375rem, 1.9vw, 1.75rem) !important;
  color: var(--color-text) !important;
  margin-bottom: 2.5rem;
  line-height: 1.4 !important;
}

.about-role-muted {
  color: var(--color-muted);
}

@media (max-width: 700px) {
  .about-page {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}

/* ── Main ────────────────────────────────────────── */

main {
  width: 100%;
  padding: 0 max(var(--side-padding), calc((100% - var(--max-width)) / 2 + var(--side-padding))) 8rem;
  border-top: 1px solid var(--color-divider);
}

/* ── Accordion ───────────────────────────────────── */

.accordion-item {
  border-bottom: 1px solid var(--color-divider);
}

.accordion-item:last-child {
  border-bottom: none;
}

.accordion-trigger {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  width: 100%;
  padding: 2rem 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  color: var(--color-text);
  font-family: var(--font-mono);
}

.accordion-trigger:focus-visible {
  outline: 2px solid var(--color-text);
  outline-offset: 2px;
}

.accordion-left {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.accordion-title {
  font-family: var(--font-mono);
  font-size: clamp(0.8125rem, 1vw, 1.0625rem);
  font-weight: 400;
  letter-spacing: 0;
  line-height: 1.1;
  text-transform: uppercase;
  color: var(--color-muted);
}

.accordion-company {
  font-family: var(--font-mono);
  font-size: clamp(1rem, 2vw, 1.25rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-text);
}

.accordion-end {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-shrink: 0;
}

.accordion-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: var(--color-accent);
  flex-shrink: 0;
}

.accordion-date {
  font-family: var(--font-mono);
  font-size: clamp(0.8125rem, 1vw, 1.0625rem);
  font-weight: 400;
  color: var(--color-muted);
  white-space: nowrap;
}

.accordion-icon {
  font-family: var(--font-mono);
  font-size: 1rem;
  font-weight: 400;
  color: var(--color-muted);
  line-height: 1;
  transition: color 0.2s ease;
  flex-shrink: 0;
  width: 1ch;
  text-align: center;
}

.accordion-trigger[aria-expanded="true"] .accordion-icon {
  color: var(--color-accent);
}

.accordion-body {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.3s ease;
}

.accordion-body[hidden] {
  display: block !important;
}

.accordion-content {
  padding: 1.5rem 0 4rem;
  font-size: 0.9375rem;
  font-weight: 300;
  line-height: 1.7;
  color: var(--color-body);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.4s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.accordion-content.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.accordion-content p {
  color: var(--color-body);
}

/* ── Role description ────────────────────────────── */

.role-description {
  font-size: 1.0625rem;
  font-weight: 400;
  line-height: 1.7;
  color: var(--color-body);
  max-width: 65%;
  margin-bottom: 4rem;
}

.role-description + .role-description {
  margin-top: -2rem;
}

.role-note {
  font-size: 0.8125rem;
  font-weight: 300;
  line-height: 1.6;
  color: var(--color-muted);
  margin-bottom: 4rem;
  margin-top: -2rem;
}

.role-note a {
  color: var(--color-muted);
  text-decoration: underline;
  text-decoration-style: dotted;
  text-decoration-color: var(--color-muted);
  text-underline-offset: 4px;
  transition: color 0.15s ease, text-decoration-color 0.15s ease;
}

.role-note a:hover {
  color: var(--color-accent);
  text-decoration-style: solid;
  text-decoration-color: var(--color-accent);
}

.role-description a {
  color: inherit;
  text-decoration: underline;
  text-decoration-style: dotted;
  text-decoration-color: var(--color-muted);
  text-underline-offset: 4px;
  transition: color 0.15s ease, text-decoration-color 0.15s ease;
}

.role-description a:hover {
  color: var(--color-accent);
  text-decoration-style: solid;
  text-decoration-color: var(--color-accent);
}

.role-description .highlight {
  background: none;
  color: inherit;
  font-weight: inherit;
}

::selection {
  background-color: var(--color-accent);
  color: #ffffff;
}

/* ── Project subsection ──────────────────────────── */

.project {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 3rem;
  padding: 3rem 0;
  border-top: 1px solid var(--color-divider);
}

.project:first-child {
  border-top: none;
  padding-top: 0;
}

.project-image {
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background: #262626;
  border-radius: 2px;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

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

.project-image--inset {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem;
  background: #262626;
}

.project-image--inset video {
  width: 92%;
  height: 92%;
  object-fit: contain;
  display: block;
  border-radius: 2px;
}

.project-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1rem;
}

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

.project-title {
  font-family: var(--font-mono);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--color-text);
}

.project-body {
  font-size: 0.9375rem;
  font-weight: 300;
  line-height: 1.7;
  color: var(--color-body);
}


/* ── Footer ──────────────────────────────────────── */

footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 2rem max(var(--side-padding), calc((100% - var(--max-width)) / 2 + var(--side-padding))) 3rem;
  border-top: 1px solid var(--color-divider);
  font-family: var(--font-mono);
  font-size: clamp(0.6875rem, 0.8vw, 0.8125rem);
  color: var(--color-muted);
}

footer a {
  color: var(--color-muted);
  text-decoration: none;
  transition: color 0.15s ease;
}

footer a:hover {
  color: var(--color-accent);
}

/* ── Moth ────────────────────────────────────────── */

@keyframes moth-drift {
  0%   { top: 80vh; left: 30vw; transform: rotate(-2deg)   scale(1);    }
  12%  { top: 55vh; left: -4vw; transform: rotate(6deg)    scale(1.02); }
  24%  { top: 20vh; left: -3vw; transform: rotate(-4deg)   scale(0.97); }
  36%  { top: 8vh;  left: 1vw;  transform: rotate(2deg)    scale(1.01); }
  48%  { top: 40vh; left: -5vw; transform: rotate(-7deg)   scale(0.98); }
  60%  { top: 78vh; left: 15vw; transform: rotate(4deg)    scale(1.03); }
  72%  { top: 85vh; left: 50vw; transform: rotate(-3deg)   scale(1);    }
  84%  { top: 70vh; left: 2vw;  transform: rotate(5deg)    scale(0.98); }
  94%  { top: 30vh; left: -4vw; transform: rotate(-5deg)   scale(1.02); }
  100% { top: 80vh; left: 30vw; transform: rotate(-2deg)   scale(1);    }
}

.moth-float {
  position: fixed;
  width: clamp(75px, 23vw, 315px);
  pointer-events: none;
  z-index: 10;
  animation: moth-drift 220s cubic-bezier(0.45, 0.05, 0.55, 0.95) infinite;
  will-change: top, left, transform;
}

@keyframes mug-drift {
  0%   { top: 78vh; left: 55vw; transform: rotate(3deg)    scale(1);    }
  12%  { top: 30vh; left: 82vw; transform: rotate(-5deg)   scale(1.02); }
  25%  { top: 10vh; left: 80vw; transform: rotate(6deg)    scale(0.97); }
  38%  { top: 50vh; left: 84vw; transform: rotate(-3deg)   scale(1.01); }
  50%  { top: 80vh; left: 70vw; transform: rotate(5deg)    scale(0.99); }
  62%  { top: 20vh; left: 83vw; transform: rotate(-6deg)   scale(1.03); }
  75%  { top: 85vh; left: 35vw; transform: rotate(4deg)    scale(0.98); }
  88%  { top: 60vh; left: 81vw; transform: rotate(-4deg)   scale(1.01); }
  100% { top: 78vh; left: 55vw; transform: rotate(3deg)    scale(1);    }
}

.mug-float {
  position: fixed;
  width: clamp(53px, 16vw, 225px);
  pointer-events: none;
  z-index: 10;
  animation: mug-drift 175s cubic-bezier(0.45, 0.05, 0.55, 0.95) infinite;
  will-change: top, left, transform;
}

@keyframes tulip-drift {
  0%   { top: 82vh; left: 42vw; transform: rotate(34deg)  scale(1);    }
  14%  { top: 78vh; left: 8vw;  transform: rotate(24deg)  scale(1.02); }
  28%  { top: 88vh; left: 65vw; transform: rotate(33deg)  scale(0.97); }
  42%  { top: 80vh; left: 25vw; transform: rotate(26deg)  scale(1.01); }
  56%  { top: 76vh; left: 78vw; transform: rotate(37deg)  scale(0.98); }
  70%  { top: 85vh; left: 48vw; transform: rotate(27deg)  scale(1.03); }
  84%  { top: 80vh; left: -3vw; transform: rotate(35deg)  scale(0.99); }
  94%  { top: 78vh; left: 82vw; transform: rotate(25deg)  scale(1.01); }
  100% { top: 82vh; left: 42vw; transform: rotate(34deg)  scale(1);    }
}

.tulip-float {
  position: fixed;
  width: clamp(56px, 15vw, 225px);
  pointer-events: none;
  z-index: 10;
  mix-blend-mode: screen;
  animation: tulip-drift 195s cubic-bezier(0.45, 0.05, 0.55, 0.95) infinite;
  will-change: top, left, transform;
}

/* ── Responsive ──────────────────────────────────── */

@media (max-width: 600px) {
  header {
    flex-direction: column;
    gap: 1.5rem;
    padding-bottom: 3rem;
  }

  nav {
    gap: 1.5rem;
  }

  .role-description {
    max-width: 100%;
  }
}

/* ── Focus styles ────────────────────────────────── */

:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 4px;
  border-radius: 2px;
}

/* ── Reduced motion ──────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  html {
    scroll-behavior: auto;
  }
}
