* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }

body {
  background: #080808; color: #fff;
  font-family: 'Space Mono', monospace;
  overflow-x: hidden;
}

body::after {
  content: ''; position: fixed; inset: 0;
  background: repeating-linear-gradient(0deg, rgba(0,0,0,0.06) 0px, rgba(0,0,0,0.06) 1px, transparent 1px, transparent 4px);
  pointer-events: none; z-index: 9996;
}

#staticCanvas {
  position: fixed; inset: 0; width: 100%; height: 100%;
  pointer-events: none; z-index: 9997; opacity: 0.10; image-rendering: pixelated;
}

/* ── NAV ── */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 32px;
  background: linear-gradient(to bottom, rgba(8,8,8,0.98) 0%, rgba(8,8,8,0) 100%);
}

.nav-logo {
  font-family: 'Bebas Neue', sans-serif; font-size: 18px;
  letter-spacing: 4px; color: #fff; text-decoration: none;
  text-transform: uppercase;
}

.nav-links {
  display: flex; align-items: center; gap: 32px;
}

.nav-link {
  font-size: 8px; letter-spacing: 3px; color: rgba(255,255,255,0.38);
  text-decoration: none; text-transform: uppercase;
  font-family: 'Space Mono', monospace; transition: color 0.12s;
}
.nav-link:hover { color: #fff; }
.nav-link.active { color: #fff; }
.nav-special { color: rgba(255,255,255,0.22); }

.nav-socials { display: flex; align-items: center; gap: 18px; }
.nav-social {
  font-size: 7px; letter-spacing: 2px; color: rgba(255,255,255,0.28);
  text-decoration: none; font-family: 'Space Mono', monospace;
  transition: color 0.12s; text-transform: uppercase;
}
.nav-social:hover { color: #fff; }

/* ── HERO ── */
.hero {
  width: 100%; height: 100vh;
  /* ADD HERO IMAGE: background-image: url('images/hero.jpg'); */
  background-color: #050505;
  background-size: cover; background-position: center top;
  position: relative;
}

.hero::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0;
  height: 40%; pointer-events: none;
  background: linear-gradient(to bottom, transparent 0%, #080808 100%);
}

.hero-placeholder {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  font-size: 9px; letter-spacing: 5px; color: rgba(255,255,255,0.18);
  text-transform: uppercase; font-family: 'Space Mono', monospace; text-align: center;
}

/* ── ABOUT ── */
.about {
  min-height: 50vh; display: flex; align-items: flex-start; justify-content: flex-end;
  padding: 60px 80px 120px 48px;
}
.about-inner { max-width: 540px; display: flex; flex-direction: column; }

.about-label {
  font-size: 7px; letter-spacing: 5px; color: rgba(255,255,255,0.22);
  text-transform: uppercase; margin-bottom: 32px;
}

.bio-line {
  font-size: 13px; line-height: 2.1; letter-spacing: 0.3px;
  color: rgba(255,255,255,0.6); padding-bottom: 20px;
}
.bio-line:last-child { padding-bottom: 0; }

/* ── PORTFOLIO ── */
.portfolio {
  padding: 140px 48px 100px;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 48px;
}

.portfolio-item {
  display: flex; flex-direction: column; gap: 16px;
  text-decoration: none; transition: opacity 0.15s;
}
.portfolio-item:hover { opacity: 0.75; }

.portfolio-img-wrap {
  width: 100%; aspect-ratio: 1 / 1; background: #0d0d0d;
  overflow: hidden; position: relative;
  /* ADD IMAGE: background-image: url('...'); background-size: cover; background-position: center; */
  display: flex; align-items: center; justify-content: center;
}

.portfolio-placeholder {
  font-size: 8px; letter-spacing: 3px; color: rgba(255,255,255,0.1);
  font-family: 'Space Mono', monospace; text-transform: uppercase;
}

.portfolio-meta { display: flex; flex-direction: column; gap: 6px; }
.portfolio-title {
  font-family: 'Bebas Neue', sans-serif; font-size: clamp(24px, 3.5vw, 38px);
  letter-spacing: 2px; color: rgba(255,255,255,0.8); line-height: 1;
  transition: color 0.12s;
}
.portfolio-item:hover .portfolio-title { color: #fff; }
.portfolio-sub {
  font-size: 7px; letter-spacing: 3px; color: rgba(255,255,255,0.28);
  text-transform: uppercase;
}

/* ── CONTACT ── */
.contact {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
}
.contact-inner { display: flex; flex-direction: column; align-items: flex-start; }
.contact-link {
  font-family: 'Bebas Neue', sans-serif; font-size: clamp(56px, 8vw, 96px);
  letter-spacing: 3px; color: rgba(255,255,255,0.35);
  text-decoration: none; text-transform: uppercase;
  transition: color 0.08s; display: block; line-height: 1.05;
}
.contact-link:hover { color: #fff; }

/* ── REVEAL ── */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity 0.9s ease, transform 0.9s ease; }

/* ── CORNER ── */
.corner {
  position: fixed; bottom: 22px; left: 20px; z-index: 10;
  font-size: 6px; letter-spacing: 3px; color: rgba(255,255,255,0.2);
  text-transform: uppercase; pointer-events: none;
}

/* ── MOBILE ── */
@media (max-width: 700px) {
  .nav { padding: 16px 20px; }
  .nav-logo { font-size: 14px; }
  .nav-links { gap: 16px; }
  .nav-link { font-size: 7px; letter-spacing: 2px; }
  .nav-special { display: none; }
  .nav-socials { gap: 12px; }

  .about { padding: 40px 24px 80px; justify-content: flex-start; }
  .about-inner { max-width: 100%; }
  .bio-line { font-size: 11px; line-height: 2; }

  .portfolio { padding: 100px 20px 60px; grid-template-columns: 1fr; gap: 36px; }

  .contact-link { font-size: clamp(40px, 12vw, 64px); }
}
