/*──────────────────────────────────────────────
  RESET & TOKENS
──────────────────────────────────────────────*/
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0
}

:root {
  --ink: #0d0d0d;
  --paper: #f0ece3;
  --cream: #f7f4ee;
  --acid: #c8ff00;
  --warm: #ff5c35;
  --sky: #91c8ff;
  --mid: #7a7670;
  --border: 2px solid var(--ink);
  --gap: clamp(1.5rem, 4vw, 4rem);
  --r: 0px;
}

html {
  scroll-behavior: smooth
}

body {
  font-family: 'DM Sans', sans-serif;
  background: var(--paper);
  color: var(--ink);

  overflow-x: hidden;
  min-height: 100vh;
}

/*──────────────────────────────────────────────
  CUSTOM CURSOR
──────────────────────────────────────────────*/
#cur {
  position: fixed;
  width: 12px;
  height: 12px;
  background: var(--acid);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  transition: width .25s, height .25s, background .25s, transform .1s;
  mix-blend-mode: multiply;
}

#cur.big {
  width: 56px;
  height: 56px;
  background: var(--warm);
  mix-blend-mode: multiply
}

#cur.text {
  width: 80px;
  height: 80px;
  background: var(--ink);
  mix-blend-mode: normal;
  display: flex;
  align-items: center;
  justify-content: center;
}

#cur.click {
  transform: translate(-50%, -50%) scale(.55)
}

.cur-label {
  position: fixed;
  pointer-events: none;
  z-index: 9998;
  font-family: 'Space Mono', monospace;
  font-size: .5rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--paper);
  white-space: nowrap;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: opacity .2s;
}

.cur-label.show {
  opacity: 1
}

/*──────────────────────────────────────────────
  LOADER
──────────────────────────────────────────────*/
#loader {
  position: fixed;
  inset: 0;
  background: var(--ink);
  z-index: 8000;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 1.5rem;
  transition: opacity .7s ease, visibility .7s ease;
}

#loader.gone {
  opacity: 0;
  visibility: hidden
}

.ld-logo {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(4rem, 12vw, 10rem);
  color: var(--paper);
  letter-spacing: .06em;
  animation: ldPulse 1.1s ease-in-out infinite;
}

.ld-logo span {
  color: var(--acid)
}

.ld-bar {
  width: 200px;
  height: 2px;
  background: rgba(240, 236, 227, .15);
  overflow: hidden
}

.ld-fill {
  height: 100%;
  background: var(--acid);
  width: 0;
  animation: ldFill 1.3s ease forwards
}

@keyframes ldPulse {

  0%,
  100% {
    opacity: 1
  }

  50% {
    opacity: .25
  }
}

@keyframes ldFill {
  0% {
    width: 0
  }

  100% {
    width: 100%
  }
}

/*──────────────────────────────────────────────
  PAGE SYSTEM
──────────────────────────────────────────────*/
.page {
  display: none;
  min-height: 100vh;
  animation: pgIn .5s ease
}

.page.active {
  display: block
}

@keyframes pgIn {
  from {
    opacity: 0;
    transform: translateY(16px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

/*──────────────────────────────────────────────
  NAV
──────────────────────────────────────────────*/
nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 700;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.2rem var(--gap);
  background: transparent;
  mix-blend-mode: multiply;
}

.nav-logo {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.6rem;
  letter-spacing: .07em;
  color: var(--ink);
  text-decoration: none;
}

.nav-logo span {
  color: var(--warm)
}

.nav-links {
  display: flex;
  gap: 2rem;
  list-style: none;
  align-items: center
}

.nav-links a,
.nav-btn {
  font-family: 'Space Mono', monospace;
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--ink);
  text-decoration: none;
  transition: color .2s;
  background: none;
  border: none;
}

.nav-links a:hover {
  color: var(--warm)
}

.nav-hire {
  background: var(--acid);
  color: var(--ink) !important;
  padding: .55rem 1.3rem;
  border: var(--border);
  box-shadow: 3px 3px 0 var(--ink);
  transition: transform .2s, box-shadow .2s !important;
}

.nav-hire:hover {
  transform: translate(-2px, -2px) !important;
  box-shadow: 5px 5px 0 var(--ink) !important
}

.nav-back {
  display: none;
  align-items: center;
  gap: .5rem;
  font-family: 'Space Mono', monospace;
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  background: none;
  border: none;
  color: var(--ink);
}

.nav-back.show {
  display: flex
}

/*──────────────────────────────────────────────
  SHARED COMPONENTS
──────────────────────────────────────────────*/
.sec {
  padding: calc(var(--gap)*1.5) var(--gap)
}

.sec-tag {
  font-family: 'Space Mono', monospace;
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--mid);
  margin-bottom: .8rem;
  display: flex;
  align-items: center;
  gap: .6rem;
}

.sec-tag::before {
  content: '//';
  color: var(--warm)
}

.sec-h {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(3rem, 7vw, 7rem);
  line-height: .95;
  letter-spacing: .03em;
  margin-bottom: 3rem;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  padding: .85rem 2rem;
  font-family: 'Space Mono', monospace;
  font-size: .75rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  text-decoration: none;
  border: var(--border);
  transition: transform .2s, box-shadow .2s;
}

.btn:hover {
  transform: translate(-3px, -3px);
  box-shadow: 5px 5px 0 var(--ink)
}

.btn-primary {
  background: var(--acid);
  color: var(--ink);
  box-shadow: 4px 4px 0 var(--ink)
}

.btn-dark {
  background: var(--ink);
  color: var(--paper);
  box-shadow: 4px 4px 0 var(--acid)
}

.btn-dark:hover {
  box-shadow: 5px 5px 0 var(--acid)
}

.btn-outline {
  background: transparent;
  color: var(--ink)
}

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .65s ease, transform .65s ease
}

.reveal.vis {
  opacity: 1;
  transform: translateY(0)
}

.d1 {
  transition-delay: .1s
}

.d2 {
  transition-delay: .2s
}

.d3 {
  transition-delay: .3s
}

.d4 {
  transition-delay: .4s
}

/*──────────────────────────────────────────────
  MARQUEE
──────────────────────────────────────────────*/
.mq-wrap {
  overflow: hidden;
  border-top: var(--border);
  border-bottom: var(--border);
  background: var(--ink);
  padding: .75rem 0;
}

.mq-track {
  display: flex;
  gap: 2.5rem;
  width: max-content;
  animation: mq 22s linear infinite
}

.mq-track.rev {
  animation-direction: reverse;
  animation-duration: 28s
}

@keyframes mq {
  from {
    transform: translateX(0)
  }

  to {
    transform: translateX(-50%)
  }
}

.mq-item {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.3rem;
  letter-spacing: .1em;
  color: var(--paper);
  white-space: nowrap;
}

.mq-item .dot {
  color: var(--acid);
  margin: 0 .4rem
}

.mq-pill {
  border: var(--border);
  padding: .6rem 1.3rem;
  font-family: 'Space Mono', monospace;
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  white-space: nowrap;
  background: var(--paper);
  color: var(--ink);
}

/*──────────────────────────────────────────────
  ═══════ HOME PAGE ═══════
──────────────────────────────────────────────*/
#home {}

.hero {
  min-height: 100svh;
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
  padding: 5rem var(--gap) 8rem;
}

.hero-bg {
  position: absolute;
  bottom: -5rem;
  left: -2rem;
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(10rem, 30vw, 28rem);
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(13, 13, 13, .06);
  white-space: nowrap;
  user-select: none;
  pointer-events: none;
  animation: bgDrift 20s linear infinite;
  letter-spacing: .02em;
}

@keyframes bgDrift {
  from {
    transform: translateX(0)
  }

  to {
    transform: translateX(-38%)
  }
}

.hero-inner {
  text-align: center;
  position: relative;
  z-index: 1;
  max-width: 1100px
}

.hero-eye {
  font-family: 'Space Mono', monospace;
  font-size: .7rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--mid);
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .8rem;
}

.hero-eye::before,
.hero-eye::after {
  content: '';
  display: block;
  width: 3rem;
  height: 1px;
  background: var(--mid)
}

.hero-h {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(4rem, 14vw, 13rem);
  line-height: .9;
  letter-spacing: .02em;
}

.hero-h .ac {
  color: var(--warm)
}

.hero-h .ol {
  -webkit-text-stroke: 2px var(--ink);
  color: transparent
}

.hero-sub {
  font-size: clamp(.95rem, 1.8vw, 1.2rem);
  font-weight: 300;
  color: var(--mid);
  max-width: 44ch;
  margin: 2rem auto 3rem;
  line-height: 1.7;
}

.hero-sub em {
  color: var(--ink);
  font-style: normal;
  font-weight: 600
}

.hero-cta {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap
}

.scroll-hint {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: 'Space Mono', monospace;
  font-size: .6rem;
  letter-spacing: .15em;
  color: var(--mid);
  text-transform: uppercase;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
}

.scroll-line {
  width: 1px;
  height: 3rem;
  background: var(--mid);
  animation: sLine 2s ease infinite;
  transform-origin: top
}

@keyframes sLine {
  0% {
    transform: scaleY(0);
    opacity: 0
  }

  50% {
    transform: scaleY(1);
    opacity: 1
  }

  100% {
    transform: scaleY(0);
    opacity: 0
  }
}

/* Featured work strip */
.home-feat {
  padding: var(--gap);
  background: var(--cream);
  border-top: var(--border)
}

.feat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
  margin-top: 2rem;
}

@media(max-width:700px) {
  .feat-grid {
    grid-template-columns: 1fr
  }
}

.feat-card {
  border: var(--border);
  overflow: hidden;
  transition: transform .25s, box-shadow .25s;
  position: relative;
}

.feat-card:hover {
  transform: translate(-4px, -4px);
  box-shadow: 4px 4px 0 var(--ink)
}

.feat-thumb {
  aspect-ratio: 4/3;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.feat-thumb img {
  width: 100%;
  height: 100%;
  object-fit: fill;
  /* stretches if needed */
  display: block;
}

.feat-card:hover .feat-thumb {
  transform: scale(1.05)
}

.feat-info {
  padding: .9rem 1rem;
  border-top: var(--border);
  background: var(--paper)
}

.feat-tag {
  font-family: 'Space Mono', monospace;
  font-size: .58rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--mid)
}

.feat-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.4rem;
  letter-spacing: .04em;
  margin-top: .2rem
}

.feat-ov {
  position: absolute;
  inset: 0;
  background: rgba(13, 13, 13, .9);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: .6rem;
  opacity: 0;
  transition: opacity .3s;
}

.feat-card:hover .feat-ov {
  opacity: 1
}

.feat-ov span {
  font-family: 'Space Mono', monospace;
  font-size: .7rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--acid);
}

.feat-ov .arr {
  font-size: 2rem;
  color: var(--paper)
}

/* Stats */
.stats-sec {
  border-top: var(--border);
  padding: var(--gap);
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: space-around;
  background: var(--paper);
}

.stat {
  text-align: center
}

.stat-n {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(3rem, 6vw, 5rem);
  color: var(--warm);
  line-height: 1
}

.stat-l {
  font-family: 'Space Mono', monospace;
  font-size: .65rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--mid);
  margin-top: .3rem
}

/*──────────────────────────────────────────────
  ═══════ ABOUT PAGE ═══════
──────────────────────────────────────────────*/
#about {}

.about-hero {
  padding-top: 8rem;
  padding-bottom: 4rem;
  padding-left: var(--gap);
  padding-right: var(--gap);
  background: var(--cream);
  border-bottom: var(--border);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}

@media(max-width:760px) {
  .about-hero {
    grid-template-columns: 1fr;
    padding-top: 6rem
  }
}

.about-headline {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(4rem, 10vw, 9rem);
  line-height: .9;
  letter-spacing: .03em;
}

.about-headline .ol {
  -webkit-text-stroke: 2px var(--ink);
  color: transparent
}

.about-right p {
  font-size: clamp(1rem, 1.6vw, 1.2rem);
  line-height: 1.75;
  font-weight: 300;
  margin-bottom: 1.5rem;
}

.about-right strong {
  font-weight: 700
}

.highlight {
  background: var(--acid);
  padding: .05em .25em;
  font-weight: 600
}

/* Levels */
.levels-sec {
  padding: var(--gap);
  background: var(--paper)
}

.levels-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.2rem;
  margin-top: 2rem
}

@media(max-width:700px) {
  .levels-grid {
    grid-template-columns: 1fr
  }
}

.lv {
  border: var(--border);
  padding: 1.5rem;
  position: relative;
  overflow: hidden;
  transition: transform .2s, box-shadow .2s;
}

.lv:hover {
  transform: translate(-4px, -4px);
  box-shadow: 4px 4px 0 var(--ink)
}

.lv-n {
  position: absolute;
  right: .8rem;
  top: .5rem;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 5rem;
  color: rgba(13, 13, 13, .06);
  line-height: 1;
  pointer-events: none;
}

.lv-tag {
  font-family: 'Space Mono', monospace;
  font-size: .6rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  margin-bottom: .5rem
}

.lv-t {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.6rem;
  letter-spacing: .05em;
  margin-bottom: .5rem
}

.lv-d {
  font-size: .9rem;
  line-height: 1.6
}

.lv-a {
  background: var(--acid)
}

.lv-b {
  background: var(--sky)
}

.lv-c {
  background: var(--warm);
  color: white
}

.lv-c .lv-tag,
.lv-c .lv-d {
  color: rgba(255, 255, 255, .8)
}

.lv-d2 {
  background: var(--ink);
  color: var(--paper)
}

.lv-d2 .lv-tag {
  color: rgba(240, 236, 227, .5)
}

.lv-d2 .lv-t {
  color: var(--acid)
}

.lv-d2 .lv-d {
  color: rgba(240, 236, 227, .7)
}

/* Skills */
.skills-sec {
  padding: var(--gap);
  background: var(--cream);
  border-top: var(--border)
}

.skills-grid {
  display: flex;
  flex-wrap: wrap;
  gap: .7rem;
  margin-top: 1.5rem
}

.skill-tag {
  border: var(--border);
  padding: .5rem 1.1rem;
  font-family: 'Space Mono', monospace;
  font-size: .7rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  transition: background .2s, transform .15s;
}

.skill-tag:hover {
  background: var(--acid);
  transform: translate(-2px, -2px)
}

/*──────────────────────────────────────────────
  ═══════ PROJECTS PAGE ═══════
──────────────────────────────────────────────*/
#projects {}

.proj-hero {
  padding-top: 8rem;
  padding-bottom: 3rem;
  padding-left: var(--gap);
  padding-right: var(--gap);
  background: var(--ink);
}

.proj-hero .sec-tag {
  color: rgba(240, 236, 227, .4)
}

.proj-hero .sec-tag::before {
  color: var(--acid)
}

.proj-hero .sec-h {
  color: var(--paper)
}

.proj-hero .sec-h .ac {
  color: var(--acid)
}

/* Filter bar */
.filter-bar {
  padding: .8rem var(--gap);
  background: var(--ink);
  border-bottom: var(--border);
  display: flex;
  gap: .7rem;
  flex-wrap: wrap;
  align-items: center;
}

.filter-btn {
  font-family: 'Space Mono', monospace;
  font-size: .65rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .4rem 1rem;
  border: 1px solid rgba(240, 236, 227, .3);
  background: transparent;
  color: rgba(240, 236, 227, .6);
  transition: all .2s;
}

.filter-btn.active,
.filter-btn:hover {
  background: var(--acid);
  color: var(--ink);
  border-color: var(--acid)
}

/* Projects mosaic */
.proj-mosaic {
  padding: var(--gap);
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1.2rem;
}

@media(max-width:900px) {
  .proj-mosaic .pc {
    grid-column: span 12 !important
  }
}

.pc {
  grid-column: span 6
}

.pc7 {
  grid-column: span 7
}

.pc5 {
  grid-column: span 5
}

.pc4 {
  grid-column: span 4
}

.pc8 {
  grid-column: span 8
}

.pc12 {
  grid-column: span 12
}

.pc3 {
  grid-column: span 3
}

.pcard {
  border: var(--border);
  overflow: hidden;
  position: relative;
  transition: transform .25s, box-shadow .25s;
  background: var(--paper);
}

.pcard:hover {
  transform: translate(-5px, -5px);
  box-shadow: 5px 5px 0 var(--ink)
}

.pcard-thumb {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Bebas Neue', sans-serif;
  letter-spacing: .05em;
  overflow: hidden;
  position: relative;
}

.pcard-thumb-inner {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .5s ease;
  font-family: 'Bebas Neue', sans-serif;
}

.pcard:hover .pcard-thumb-inner {
  transform: scale(1.06)
}

.pcard-ov {
  position: absolute;
  inset: 0;
  background: rgba(13, 13, 13, .9);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 1.5rem;
  opacity: 0;
  transition: opacity .3s;
}

.pcard:hover .pcard-ov {
  opacity: 1
}

.pcard-ov-tag {
  font-family: 'Space Mono', monospace;
  font-size: .6rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--acid);
  margin-bottom: .4rem
}

.pcard-ov-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(1.3rem, 3vw, 2.2rem);
  color: var(--paper);
  line-height: 1.05;
  margin-bottom: .4rem
}

.pcard-ov-desc {
  font-size: .8rem;
  color: rgba(240, 236, 227, .65);
  line-height: 1.5;
  max-width: 36ch
}

.pcard-meta {
  padding: .85rem 1rem;
  border-top: var(--border);
  background: var(--paper);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.pcard-name {
  font-family: 'Space Mono', monospace;
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase
}

.pcard-yr {
  font-family: 'Space Mono', monospace;
  font-size: .62rem;
  color: var(--mid)
}

.pcard-badge {
  position: absolute;
  top: .8rem;
  right: .8rem;
  z-index: 5;
  font-family: 'Space Mono', monospace;
  font-size: .52rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  background: var(--acid);
  color: var(--ink);
  padding: .25rem .6rem;
  border: 1.5px solid var(--ink);
  transform: rotate(2.5deg);
}

/* thumbnail sizes */
.th-43 {
  aspect-ratio: 4/3
}

.th-169 {
  aspect-ratio: 16/9
}

.th-11 {
  aspect-ratio: 1/1
}

.th-34 {
  aspect-ratio: 3/4
}

.th-219 {
  aspect-ratio: 21/9
}

/* color palettes for cards */
.bg-ink {
  background: var(--ink);
  color: var(--paper)
}

.bg-acid {
  background: var(--acid);
  color: var(--ink)
}

.bg-warm {
  background: var(--warm);
  color: white
}

.bg-sky {
  background: var(--sky);
  color: var(--ink)
}

.bg-cream {
  background: var(--cream);
  color: var(--ink)
}

.bg-rust {
  background: #b84c2b;
  color: white
}

.bg-forest {
  background: #2d5a27;
  color: #c8ff00
}

.bg-sand {
  background: #d4a853;
  color: var(--ink)
}

.bg-violet {
  background: #4a2c7a;
  color: #91c8ff
}

.bg-rose {
  background: #e0c4b4;
  color: var(--ink)
}

.bg-teal {
  background: #1a6b6b;
  color: var(--acid)
}

.bg-crimson {
  background: #8b1a1a;
  color: var(--paper)
}

.bg-olive {
  background: #6b6b2d;
  color: var(--acid)
}

.bg-char {
  background: #2d2d2d;
  color: var(--paper)
}

.bg-slate {
  background: #3a4a5c;
  color: var(--sky)
}

.bg-gold {
  background: #c9a227;
  color: var(--ink)
}

/*──────────────────────────────────────────────
  ═══════ PROJECT DETAIL PAGE ═══════
──────────────────────────────────────────────*/
#project-detail {}

.pd-hero {
  min-height: 55vh;
  display: flex;
  align-items: flex-end;
  padding: var(--gap);
  padding-top: 7rem;
  position: relative;
  overflow: hidden;
  border-bottom: var(--border);
}

.pd-hero-bg {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(10rem, 30vw, 30rem);
  letter-spacing: .02em;
  pointer-events: none;
  user-select: none;
  opacity: .07;
  line-height: 1;
  transition: color .4s;
}

.pd-hero-content {
  position: relative;
  z-index: 1;
  max-width: 900px
}

.pd-eyebrow {
  font-family: 'Space Mono', monospace;
  font-size: .7rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: .8rem;
}

.pd-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(3.5rem, 10vw, 9rem);
  line-height: .9;
  letter-spacing: .03em;
  margin-bottom: 1rem;
}

.pd-subtitle {
  font-size: clamp(1rem, 1.8vw, 1.3rem);
  font-weight: 300;
  max-width: 52ch;
  line-height: 1.65;
  color: inherit;
  opacity: .75;
}

.pd-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(13, 13, 13, .2);
}

.pd-meta-item .label {
  font-family: 'Space Mono', monospace;
  font-size: .58rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  opacity: .5;
  margin-bottom: .3rem;
}

.pd-meta-item .value {
  font-family: 'Space Mono', monospace;
  font-size: .8rem;
  font-weight: 700
}

/* Case study body */
.cs-body {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--gap)
}

.cs-sec {
  padding: 4rem 0;
  border-bottom: 1px solid rgba(13, 13, 13, .1)
}

.cs-sec:last-child {
  border-bottom: none
}

.cs-label {
  font-family: 'Space Mono', monospace;
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--mid);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: .6rem;
}

.cs-label::before {
  content: '0' attr(data-n);
  color: var(--warm);
  font-size: .6rem
}

.cs-h {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2rem, 5vw, 4rem);
  letter-spacing: .04em;
  margin-bottom: 1.5rem;
}

.cs-text {
  font-size: clamp(.95rem, 1.5vw, 1.1rem);
  line-height: 1.8;
  font-weight: 300;
  max-width: 68ch;
  color: var(--ink);
}

.cs-text strong {
  font-weight: 600
}

.cs-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: start
}

@media(max-width:700px) {
  .cs-2col {
    grid-template-columns: 1fr
  }
}

/* Mockup blocks */
.mockup-block {
  border: var(--border);
  overflow: hidden;
  margin: 2rem 0;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  background: var(--cream);
  font-family: 'Bebas Neue', sans-serif;
  letter-spacing: .06em;
  transition: transform .2s;
}

.mockup-block:hover {
  transform: scale(1.01)
}

.mockup-block.full {
  min-height: 340px;
  font-size: clamp(2rem, 8vw, 7rem)
}

.mockup-block.half {
  min-height: 220px;
  font-size: clamp(1.5rem, 4vw, 4rem)
}

.mockup-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
  margin: 2rem 0
}

@media(max-width:600px) {
  .mockup-grid {
    grid-template-columns: 1fr
  }
}

/* process steps */
.process-steps {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 2rem 0
}

.ps {
  display: flex;
  gap: 1.5rem;
  align-items: flex-start;
  padding: 1.2rem 0;
  border-bottom: 1px solid rgba(13, 13, 13, .1);
}

.ps:last-child {
  border-bottom: none
}

.ps-n {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 2.5rem;
  color: var(--acid);
  line-height: 1;
  min-width: 2.5rem;
  text-align: right;
  -webkit-text-stroke: 1.5px var(--ink);
  color: transparent;
}

.ps-content .ps-t {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.4rem;
  letter-spacing: .04em;
  margin-bottom: .3rem
}

.ps-content .ps-d {
  font-size: .9rem;
  line-height: 1.6;
  color: var(--mid)
}

/* colour palette display */
.palette {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin: 1.5rem 0
}

.swatch {
  width: 80px;
  height: 80px;
  border: var(--border);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: .3rem .4rem;
}

.swatch span {
  font-family: 'Space Mono', monospace;
  font-size: .5rem;
  letter-spacing: .05em;
  opacity: .7
}

/* result tags */
.result-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .7rem;
  margin-top: 1.5rem
}

.rtag {
  border: var(--border);
  padding: .5rem 1rem;
  font-family: 'Space Mono', monospace;
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.rtag.good {
  background: var(--acid);
  border-color: var(--ink)
}

/* next project */
.next-proj {
  padding: var(--gap);
  background: var(--ink);
  border-top: var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 2rem;
}

.np-label {
  font-family: 'Space Mono', monospace;
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(240, 236, 227, .4);
  margin-bottom: .4rem
}

.np-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2rem, 5vw, 4rem);
  color: var(--paper);
  letter-spacing: .04em;
  line-height: 1
}

.np-btn {
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  background: var(--acid);
  color: var(--ink);
  padding: 1rem 2rem;
  border: var(--border);
  box-shadow: 4px 4px 0 rgba(240, 236, 227, .3);
  font-family: 'Space Mono', monospace;
  font-size: .75rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  transition: transform .2s, box-shadow .2s;
}

.np-btn:hover {
  transform: translate(-3px, -3px);
  box-shadow: 7px 7px 0 rgba(240, 236, 227, .3)
}

/*──────────────────────────────────────────────
  ═══════ HIRE ME PAGE ═══════
──────────────────────────────────────────────*/
#hire {}

.hire-hero {
  min-height: 65vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--ink);
  padding: 8rem var(--gap) 4rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.hire-hero-bg {
  position: absolute;
  inset: 0;
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(15rem, 40vw, 40rem);
  color: transparent;
  -webkit-text-stroke: 1px rgba(240, 236, 227, .04);
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  user-select: none;
  line-height: 1;
}

.hire-hero h1 {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(4rem, 13vw, 12rem);
  line-height: .88;
  letter-spacing: .03em;
  color: var(--paper);
  position: relative;
  z-index: 1;
}

.hire-hero h1 .a {
  color: var(--acid)
}

.hire-hero h1 .o {
  -webkit-text-stroke: 2px var(--paper);
  color: transparent
}

.hire-hero p {
  font-size: clamp(1rem, 1.8vw, 1.2rem);
  font-weight: 300;
  color: rgba(240, 236, 227, .6);
  max-width: 48ch;
  margin: 1.5rem auto 3rem;
  line-height: 1.7;
  position: relative;
  z-index: 1;
}

/* service cards */
.services-sec {
  padding: var(--gap);
  background: var(--cream);
  border-top: var(--border)
}

.serv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
  margin-top: 2rem
}

@media(max-width:700px) {
  .serv-grid {
    grid-template-columns: 1fr
  }
}

.serv-card {
  border: var(--border);
  padding: 1.8rem;
  transition: transform .2s, box-shadow .2s;
}

.serv-card:hover {
  transform: translate(-4px, -4px);
  box-shadow: 4px 4px 0 var(--ink)
}

.serv-icon {
  font-size: 2.5rem;
  margin-bottom: 1rem
}

.serv-t {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.6rem;
  letter-spacing: .04em;
  margin-bottom: .6rem
}

.serv-d {
  font-size: .88rem;
  line-height: 1.65;
  color: var(--mid)
}

.serv-price {
  font-family: 'Space Mono', monospace;
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--warm);
  margin-top: 1rem;
  font-weight: 700;
}

/*──────────────────────────────────────────────
  ═══════ SURVEY PAGE ═══════
──────────────────────────────────────────────*/
#survey {}

.survey-wrap {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

@media(max-width:800px) {
  .survey-wrap {
    grid-template-columns: 1fr
  }
}

.survey-left {
  background: var(--ink);
  padding: 8rem 3rem 3rem;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

@media(max-width:800px) {
  .survey-left {
    position: static;
    height: auto;
    padding: 6rem 2rem 3rem
  }
}

.survey-left h2 {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(3rem, 6vw, 5.5rem);
  color: var(--paper);
  line-height: .9;
  letter-spacing: .03em;
}

.survey-left h2 span {
  color: var(--acid)
}

.survey-left p {
  font-size: .9rem;
  line-height: 1.7;
  color: rgba(240, 236, 227, .55);
  margin-top: 1.5rem;
  max-width: 36ch;
}

.survey-progress {
  margin-top: 3rem
}

.sp-label {
  font-family: 'Space Mono', monospace;
  font-size: .62rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: rgba(240, 236, 227, .4);
  margin-bottom: .6rem;
  display: flex;
  justify-content: space-between;
}

.sp-bar {
  height: 3px;
  background: rgba(240, 236, 227, .1);
  border-radius: 0
}

.sp-fill {
  height: 100%;
  background: var(--acid);
  transition: width .5s ease
}

.step-dots {
  display: flex;
  gap: .5rem;
  margin-top: 1rem;
  flex-wrap: wrap
}

.sdot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(240, 236, 227, .15);
  transition: background .3s;
}

.sdot.done {
  background: var(--acid)
}

.sdot.active {
  background: var(--warm)
}

.survey-right {
  padding: 8rem var(--gap) 4rem;
  background: var(--paper);
  overflow-y: auto;
}

@media(max-width:800px) {
  .survey-right {
    padding: 3rem 1.5rem
  }
}

/* steps */
.step {
  display: none;
  animation: stepIn .4s ease
}

.step.active {
  display: block
}

@keyframes stepIn {
  from {
    opacity: 0;
    transform: translateX(20px)
  }

  to {
    opacity: 1;
    transform: translateX(0)
  }
}

.step-tag {
  font-family: 'Space Mono', monospace;
  font-size: .65rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--warm);
  margin-bottom: .8rem;
}

.step-q {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2rem, 5vw, 3.5rem);
  letter-spacing: .03em;
  line-height: 1;
  margin-bottom: .8rem;
}

.step-hint {
  font-size: .88rem;
  color: var(--mid);
  margin-bottom: 2rem;
  line-height: 1.5
}

/* form elements */
.form-input {
  width: 100%;
  border: var(--border);
  background: transparent;
  padding: 1rem 1.2rem;
  font-family: 'DM Sans', sans-serif;
  font-size: 1rem;
  color: var(--ink);
  outline: none;
  margin-bottom: 1.2rem;
  transition: box-shadow .2s;
}

.form-input:focus {
  box-shadow: 4px 4px 0 var(--acid)
}

.form-input::placeholder {
  color: var(--mid)
}

.form-textarea {
  resize: vertical;
  min-height: 120px
}

.choice-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .8rem;
  margin-bottom: 1.5rem
}

@media(max-width:500px) {
  .choice-grid {
    grid-template-columns: 1fr
  }
}

.choice {
  border: var(--border);
  padding: 1rem 1.2rem;
  transition: background .2s, transform .15s;
  display: flex;
  align-items: center;
  gap: .7rem;
}

.choice:hover {
  background: var(--cream);
  transform: translate(-2px, -2px)
}

.choice.selected {
  background: var(--acid);
  box-shadow: 3px 3px 0 var(--ink)
}

.choice input[type=checkbox],
.choice input[type=radio] {
  appearance: none;
  width: 14px;
  height: 14px;
  border: 2px solid var(--ink);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.choice.selected input::after {
  content: '✓';
  font-size: .6rem;
  font-weight: 700;
  color: var(--ink);
}

.choice input[type=radio] {
  border-radius: 50%
}

.choice-label {
  font-family: 'Space Mono', monospace;
  font-size: .75rem;
  letter-spacing: .06em;
  text-transform: uppercase
}

.budget-slider {
  width: 100%;
  appearance: none;
  height: 3px;
  background: var(--ink);
  outline: none;
  margin: 1.5rem 0;
}

.budget-slider::-webkit-slider-thumb {
  appearance: none;
  width: 20px;
  height: 20px;
  background: var(--acid);
  border: var(--border);
}

.budget-display {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 3rem;
  color: var(--warm);
  letter-spacing: .04em;
  margin-bottom: .5rem;
}

.step-nav {
  display: flex;
  gap: 1rem;
  margin-top: 2rem;
  align-items: center;
  flex-wrap: wrap
}

.step-btn {
  border: var(--border);
  padding: .85rem 2rem;
  font-family: 'Space Mono', monospace;
  font-size: .75rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  background: var(--acid);
  color: var(--ink);
  box-shadow: 4px 4px 0 var(--ink);
  transition: transform .2s, box-shadow .2s;
}

.step-btn:hover {
  transform: translate(-3px, -3px);
  box-shadow: 7px 7px 0 var(--ink)
}

.step-btn.back-btn {
  background: transparent;
  box-shadow: none;
  opacity: .6
}

.step-btn.back-btn:hover {
  transform: translate(-2px, -2px);
  box-shadow: 3px 3px 0 var(--ink);
  opacity: 1
}

.step-counter {
  font-family: 'Space Mono', monospace;
  font-size: .65rem;
  letter-spacing: .12em;
  color: var(--mid)
}

/*──────────────────────────────────────────────
  ═══════ THANK YOU PAGE ═══════
──────────────────────────────────────────────*/
#thankyou {}

.ty-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--gap);
  background: var(--ink);
}

.ty-inner {
  max-width: 700px
}

.ty-icon {
  width: 80px;
  height: 80px;
  border: var(--border);
  background: var(--acid);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 2rem;
  animation: tyBounce .6s ease;
  border-color: rgba(240, 236, 227, .5);
}

@keyframes tyBounce {
  0% {
    transform: scale(0)
  }

  80% {
    transform: scale(1.1)
  }

  100% {
    transform: scale(1)
  }
}

.ty-h {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(3rem, 10vw, 8rem);
  color: var(--paper);
  line-height: .9;
  letter-spacing: .04em;
  margin-bottom: 1rem;
}

.ty-h span {
  color: var(--acid)
}

.ty-p {
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  color: rgba(240, 236, 227, .6);
  line-height: 1.7;
  margin-bottom: 3rem
}

.ty-next {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  margin-bottom: 3rem
}

.ty-roadmap {
  border: 1px solid rgba(240, 236, 227, .15);
  padding: 2rem;
  text-align: left;
  margin-top: 2rem;
}

.ty-rm-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.5rem;
  color: var(--acid);
  letter-spacing: .06em;
  margin-bottom: 1.2rem;
}

.rm-step {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  padding: .8rem 0;
  border-bottom: 1px solid rgba(240, 236, 227, .1);
}

.rm-step:last-child {
  border-bottom: none
}

.rm-dot {
  width: 24px;
  height: 24px;
  background: var(--acid);
  border: 1.5px solid rgba(240, 236, 227, .3);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Space Mono', monospace;
  font-size: .6rem;
  font-weight: 700;
  color: var(--ink);
}

.rm-t {
  font-family: 'Space Mono', monospace;
  font-size: .75rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--paper);
  margin-bottom: .2rem
}

.rm-d {
  font-size: .8rem;
  color: rgba(240, 236, 227, .45);
  line-height: 1.5
}

/*──────────────────────────────────────────────
  TOKREATE TEASER STRIP
──────────────────────────────────────────────*/
.tk-strip {
  background: var(--warm);
  border-top: var(--border);
  border-bottom: var(--border);
  padding: 2.5rem var(--gap);
  text-align: center;
}

.tk-strip p {
  font-family: 'Space Mono', monospace;
  font-size: .7rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .7);
  margin-bottom: .4rem;
}

.tk-strip h3 {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2rem, 5vw, 4rem);
  color: white;
  letter-spacing: .04em;
}

.tk-strip h3 .tk {
  color: var(--ink)
}

/*──────────────────────────────────────────────
  FOOTER
──────────────────────────────────────────────*/
footer {
  background: var(--ink);
  padding: 2rem var(--gap);
  border-top: 1px solid rgba(240, 236, 227, .08);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  font-family: 'Space Mono', monospace;
  font-size: .62rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(240, 236, 227, .3);
}

footer a {
  color: var(--acid);
  text-decoration: none
}

/*──────────────────────────────────────────────
  NOISE TEXTURE
──────────────────────────────────────────────*/
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  opacity: .45;
}

/*──────────────────────────────────────────────
  SCROLL TO TOP
──────────────────────────────────────────────*/
.up-btn {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 600;
  width: 44px;
  height: 44px;
  border: var(--border);
  background: var(--paper);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  box-shadow: 3px 3px 0 var(--ink);
  opacity: 0;
  transition: opacity .3s, transform .2s;
  transform: translateY(10px);
}

.up-btn.show {
  opacity: 1;
  transform: translateY(0)
}

.up-btn:hover {
  transform: translate(-2px, -2px) translateY(0);
  box-shadow: 5px 5px 0 var(--ink)
}

/* responsive nav */
@media(max-width:600px) {
  .nav-links li:not(:last-child) {
    display: none
  }
}

/* ── PROJECT THEMED PAGES ── */
.pd-hero {
  transition: background .4s ease, color .4s ease;
}

.pd-hero-bg {
  transition: color .4s ease;
}

/* Image caption bars */
.img-caption {
  padding: .55rem 1rem;
  border-top: 2px solid var(--ink);
  font-family: 'Space Mono', monospace;
  font-size: .6rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--mid);
  background: var(--paper);
}

/* Gallery image blocks */
.gal-block {
  border: 2px solid var(--ink);
  overflow: hidden;
  margin: 2.5rem 0;
}

.gal-block img {
  width: 100%;
  display: block;
  object-fit: cover;
  transition: transform .5s ease;
}

.gal-block:hover img {
  transform: scale(1.03);
}

/* Responsive two-col gallery */
@media(max-width:600px) {
  div[style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
}

/* ── INPUT VALIDATION STYLES ── */
.input-error {
  border-color: #ff3333 !important;
  box-shadow: 0 0 5px rgba(255, 51, 51, 0.4) !important;
}

.choice-grid.input-error {
  border: 2px solid #ff3333 !important;
  padding: 0.5rem;
  border-radius: 4px;
}

/* Hide custom cursor elements */
#cur, .cur-label {
  display: none !important;
}

/* ── NAV BAR DARK BACKGROUND OPTION ── */
nav.nav-dark-bg {
  mix-blend-mode: normal !important;
}
nav.nav-dark-bg .nav-logo {
  color: var(--paper) !important;
}
nav.nav-dark-bg .nav-links a,
nav.nav-dark-bg .nav-btn {
  color: var(--paper) !important;
}
nav.nav-dark-bg .nav-back {
  color: var(--paper) !important;
}