:root {
  --bg: #05070a;
  --bg-2: #0a0f17;
  --ink: #e9f0f5;
  --ink-dim: #8a97a5;
  --line: rgba(255, 255, 255, 0.08);
  --accent: #00ffa3;
  --accent-2: #7cf9d0;
  --glow: 0 0 24px rgba(0, 255, 163, 0.35), 0 0 80px rgba(0, 255, 163, 0.15);
}
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html,
body {
  background: var(--bg);
  color: var(--ink);
  font-family: "Space Grotesk", system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
body {
  cursor: none;
}
a {
  color: inherit;
  text-decoration: none;
}
img {
  max-width: 100%;
  display: block;
}
::selection {
  background: var(--accent);
  color: #001a10;
}
/* Noise */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  opacity: 0.06;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.9'/></svg>");
}
/* Vignette */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(
    120% 80% at 50% 10%,
    transparent 50%,
    rgba(0, 0, 0, 0.55) 100%
  );
}
/* Cursor */
.cursor {
  position: fixed;
  left: 0;
  top: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: var(--glow);
  transform: translate(-50%, -50%);
  z-index: 9999;
  pointer-events: none;
  mix-blend-mode: screen;
}
.cursor-ring {
  position: fixed;
  left: 0;
  top: 0;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(0, 255, 163, 0.5);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  z-index: 9998;
  pointer-events: none;
  transition:
    width 0.25s,
    height 0.25s,
    border-color 0.25s;
}
.cursor-ring.big {
  width: 80px;
  height: 80px;
  border-color: var(--accent);
}
/* Nav */
nav.top {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 22px 40px;
  backdrop-filter: blur(10px);
  background: linear-gradient(to bottom, rgba(5, 7, 10, 0.6), transparent);
}
.logo {
  font-family: "Fraunces", serif;
  font-weight: 900;
  font-style: italic;
  font-size: 22px;
  letter-spacing: -0.02em;
}
.logo span {
  color: var(--accent);
}
nav.top ul {
  display: flex;
  gap: 28px;
  list-style: none;
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-family: "JetBrains Mono", monospace;
}
nav.top a {
  position: relative;
  color: var(--ink-dim);
  transition: color 0.3s;
}
nav.top a:hover,
nav.top a.active {
  color: var(--ink);
}
nav.top a.active::before {
  content: "";
  position: absolute;
  left: -14px;
  top: 50%;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: var(--glow);
  transform: translateY(-50%);
}
@media (max-width: 720px) {
  nav.top ul {
    display: none;
  }
}
/* Hero */
section {
  position: relative;
}
.hero {
  height: 100vh;
  min-height: 680px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
}
#heroCanvas {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-inner {
  position: relative;
  z-index: 2;
  padding: 0 24px;
  max-width: 1100px;
}
.eyebrow {
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.4em;
  color: var(--accent);
  text-transform: uppercase;
  margin-bottom: 28px;
  opacity: 0;
  transform: translateY(20px);
}
h1.hero-title {
  font-family: "Fraunces", serif;
  font-weight: 500;
  font-size: clamp(48px, 9vw, 120px);
  line-height: 0.95;
  letter-spacing: -0.04em;
}
h1.hero-title em {
  font-style: italic;
  color: var(--accent);
  font-weight: 300;
}
h1 .word {
  display: inline-block;
  overflow: hidden;
  vertical-align: bottom;
}
h1 .word span {
  display: inline-block;
  transform: translateY(110%);
}
.sub {
  margin-top: 30px;
  font-size: clamp(15px, 1.5vw, 19px);
  color: var(--ink-dim);
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
  opacity: 0;
}
.ctas {
  display: flex;
  gap: 14px;
  justify-content: center;
  margin-top: 40px;
  flex-wrap: wrap;
  opacity: 0;
}
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 26px;
  border-radius: 999px;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  transition:
    transform 0.3s,
    background 0.3s,
    color 0.3s;
  border: 1px solid var(--line);
}
.btn.primary {
  background: var(--accent);
  color: #001a10;
  border-color: transparent;
  box-shadow: var(--glow);
}
.btn.primary:hover {
  transform: translateY(-2px);
}
.btn.ghost:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: var(--accent);
  color: var(--accent);
}
.scroll-ind {
  position: absolute;
  bottom: 0px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.3em;
  color: var(--ink-dim);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.scroll-ind .bar {
  width: 1px;
  height: 50px;
  background: linear-gradient(to bottom, var(--accent), transparent);
  animation: dropline 1.8s ease-in-out infinite;
}
@keyframes dropline {
  0% {
    transform: scaleY(0);
    transform-origin: top;
  }
  50% {
    transform: scaleY(1);
    transform-origin: top;
  }
  50.1% {
    transform-origin: bottom;
  }
  100% {
    transform: scaleY(0);
    transform-origin: bottom;
  }
}
/* Generic section */
.wrap {
  max-width: 1240px;
  margin: 0 auto;
  padding: 140px 40px;
}
@media (max-width: 720px) {
  .wrap {
    padding: 90px 22px;
  }
}
.section-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.4em;
  color: var(--accent);
  text-transform: uppercase;
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.section-label::before {
  content: "";
  width: 30px;
  height: 1px;
  background: var(--accent);
}
h2 {
  font-family: "Fraunces", serif;
  font-weight: 500;
  font-size: clamp(36px, 5.5vw, 76px);
  line-height: 1.02;
  letter-spacing: -0.03em;
  max-width: 900px;
}
h2 em {
  font-style: italic;
  color: var(--accent);
  font-weight: 300;
}
/* About */
.about-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 80px;
  align-items: center;
  margin-top: 60px;
}
@media (max-width: 900px) {
  .about-grid {
    grid-template-columns: 1fr;
    gap: 50px;
  }
}
.about p {
  color: var(--ink-dim);
  font-size: 17px;
  line-height: 1.7;
  margin-top: 22px;
  max-width: 560px;
}
.pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 34px;
}
.pill {
  padding: 9px 16px;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.pill.accent {
  color: var(--accent);
  border-color: rgba(0, 255, 163, 0.3);
}
#aboutCanvas {
  width: 100%;
  aspect-ratio: 1/1;
  max-width: 520px;
  margin-left: auto;
  display: block;
}
/* Skills */
.skills-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 60px;
}
@media (max-width: 900px) {
  .skills-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 520px) {
  .skills-grid {
    grid-template-columns: 1fr;
  }
}
.skill {
  position: relative;
  padding: 36px 28px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent);
  transition:
    transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1),
    border-color 0.3s;
  transform-style: preserve-3d;
  overflow: hidden;
}
.skill:hover {
  border-color: rgba(0, 255, 163, 0.4);
}
.skill::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 18px;
  padding: 1px;
  background: radial-gradient(
    400px circle at var(--mx, 50%) var(--my, 50%),
    rgba(0, 255, 163, 0.4),
    transparent 40%
  );
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.3s;
}
.skill:hover::before {
  opacity: 1;
}
.skill .num {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: var(--ink-dim);
  letter-spacing: 0.2em;
}
.skill .name {
  font-family: "Fraunces", serif;
  font-size: 28px;
  font-weight: 500;
  margin-top: 10px;
  letter-spacing: -0.02em;
}
.skill .desc {
  font-size: 13px;
  color: var(--ink-dim);
  margin-top: 14px;
  line-height: 1.55;
}
/* Projects */
.projects-stack {
  display: flex;
  flex-direction: column;
  gap: 30px;
  margin-top: 70px;
}
.project {
  position: relative;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 0;
  border: 1px solid var(--line);
  border-radius: 24px;
  overflow: hidden;
  background: #080c12;
  transform-style: preserve-3d;
  transition:
    transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1),
    border-color 0.3s;
}
.project:hover {
  border-color: rgba(0, 255, 163, 0.35);
}
@media (max-width: 900px) {
  .project {
    grid-template-columns: 1fr;
  }
}
.project .shot {
  position: relative;
  aspect-ratio: 16/10;
  background: radial-gradient(120% 100% at 20% 0%, #0f1a22 0%, #05080c 70%);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.project .shot .browser {
  width: 88%;
  height: 78%;
  border-radius: 10px;
  background: #0a1118;
  border: 1px solid var(--line);
  overflow: hidden;
  box-shadow: 0 30px 80px -30px rgba(0, 255, 163, 0.25);
  transform: translateZ(40px);
}
.browser .bar {
  height: 28px;
  background: #0d141c;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  border-bottom: 1px solid var(--line);
}
.browser .bar i {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #1e2a36;
  display: inline-block;
}
.browser .body {
  height: calc(100% - 28px);
  background:
    linear-gradient(115deg, rgba(0, 255, 163, 0.08), transparent 60%),
    repeating-linear-gradient(
      0deg,
      rgba(255, 255, 255, 0.03) 0 1px,
      transparent 1px 40px
    ),
    repeating-linear-gradient(
      90deg,
      rgba(255, 255, 255, 0.03) 0 1px,
      transparent 1px 40px
    ),
    #05090d;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 18px;
}
.browser .row {
  height: 10px;
  border-radius: 4px;
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.08),
    rgba(255, 255, 255, 0.02)
  );
}
.browser .row.s {
  width: 40%;
}
.browser .row.m {
  width: 70%;
}
.browser .row.l {
  width: 90%;
}
.browser .row.accent {
  background: linear-gradient(90deg, var(--accent), transparent);
  width: 25%;
  box-shadow: var(--glow);
}
.project .meta {
  padding: 48px 44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 18px;
}
@media (max-width: 900px) {
  .project .meta {
    padding: 32px 28px;
  }
}
.project .index {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: var(--accent);
  letter-spacing: 0.3em;
}
.project h3 {
  font-family: "Fraunces", serif;
  font-weight: 500;
  font-size: 38px;
  letter-spacing: -0.02em;
  line-height: 1.05;
}
.project p {
  color: var(--ink-dim);
  font-size: 15px;
  line-height: 1.65;
  max-width: 480px;
}
.tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.tag {
  padding: 6px 12px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-dim);
  border: 1px solid var(--line);
  border-radius: 999px;
}
.pbtns {
  display: flex;
  gap: 10px;
  margin-top: 6px;
}
.pbtn {
  padding: 12px 18px;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transition: all 0.3s;
}
.pbtn.primary {
  background: var(--accent);
  color: #001a10;
  border-color: transparent;
}
.pbtn:hover {
  transform: translateY(-2px);
}
.project.locked {
  opacity: 0.55;
}
.project.locked .shot {
  filter: blur(2px);
}
.project.locked::after {
  content: "COMING SOON";
  position: absolute;
  top: 20px;
  right: 20px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.3em;
  padding: 8px 14px;
  background: rgba(0, 0, 0, 0.5);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--accent);
}
/* Education timeline */
.timeline {
  margin-top: 70px;
  position: relative;
  padding-left: 34px;
}
.timeline::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 6px;
  bottom: 6px;
  width: 1px;
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.03),
    transparent
  );
}
.timeline-progress {
  position: absolute;
  left: 8px;
  top: 42px;
  width: 1px;
  height: 0;
  max-height: calc(100% - 42px);
  background: linear-gradient(to bottom, var(--accent), var(--accent-2));
  box-shadow: none;
  z-index: 1;
  opacity: 0.25;
  pointer-events: none;
  transform-origin: top;
}
.tl-item {
  position: relative;
  padding: 24px 0 48px;
}
.tl-item::before {
  content: "";
  position: absolute;
  left: -30px;
  top: 30px;
  width: 13px;
  height: 13px;
  border-radius: 50%;
  background: var(--bg);
  border: 2px solid var(--accent);
  box-shadow: var(--glow);
}
.tl-year {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.3em;
  color: var(--accent);
  text-transform: uppercase;
}
.tl-title {
  font-family: "Fraunces", serif;
  font-size: 28px;
  font-weight: 500;
  margin-top: 8px;
  letter-spacing: -0.02em;
}
.tl-desc {
  color: var(--ink-dim);
  margin-top: 8px;
  font-size: 15px;
  line-height: 1.6;
  max-width: 640px;
}
/* Contact */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  margin-top: 60px;
  align-items: start;
}
@media (max-width: 900px) {
  .contact-grid {
    grid-template-columns: 1fr;
  }
}
.contact-info p {
  color: var(--ink-dim);
  font-size: 17px;
  line-height: 1.7;
  max-width: 460px;
  margin-top: 22px;
}
.socials {
  margin-top: 36px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.social {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 22px;
  border: 1px solid var(--line);
  border-radius: 14px;
  transition: all 0.3s;
  font-family: "JetBrains Mono", monospace;
  font-size: 13px;
  letter-spacing: 0.05em;
}
.social:hover {
  border-color: var(--accent);
  color: var(--accent);
  transform: translateX(6px);
}
.social svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.social .arrow {
  margin-left: auto;
  color: var(--ink-dim);
}
form {
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
}
#envCanvas {
  position: absolute;
  right: -40px;
  top: -90px;
  width: 220px;
  height: 220px;
  pointer-events: none;
  z-index: 0;
  opacity: 0.85;
}
.field {
  position: relative;
  z-index: 1;
}
.field label {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-dim);
  display: block;
  margin-bottom: 8px;
}
.field input,
.field textarea {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--line);
  padding: 12px 0;
  color: var(--ink);
  font-family: "Space Grotesk", sans-serif;
  font-size: 17px;
  transition: border-color 0.3s;
}
.field input:focus,
.field textarea:focus {
  outline: none;
  border-color: var(--accent);
}
.field textarea {
  resize: vertical;
  min-height: 110px;
}
form .btn {
  align-self: flex-start;
  margin-top: 10px;
}
footer {
  padding: 50px 40px;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-dim);
  flex-wrap: wrap;
  gap: 14px;
}
/* Reveal helpers */
.reveal {
  opacity: 0;
  transform: translateY(40px);
}
