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

:root {
  --ink: #1c1a16;
  --paper: #f7f5f0;
  --muted: rgba(28,26,22,0.32);
  --faint: rgba(28,26,22,0.12);
}
:root {
  --font-display: 'rockwell', serif;
  --font-ui:      'futura', monospace;
}

html, body {
  width: 100%; height: 100%;
  background: var(--paper);
  overflow: hidden;
  cursor: none;
  font-family: 'DM Mono', monospace;
   border: 2.5px solid rgb(0, 0, 0); /* thickness, style, color */
  min-height: 100vh; /* ensures border covers the full viewport height */
  margin: 0; /* removes default browser margins */
  box-sizing: border-box;
}

/* ── Grain ──────────────────────────────────────────────────────── */
canvas#grain {
  position: fixed; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  opacity: 0.028;
  z-index: 0;
}

/* ── Cursor ─────────────────────────────────────────────────────── */
#cursor {
  position: fixed;
  width: 5px; height: 5px;
  background: var(--ink);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
}

#cursor-ring {
  position: fixed;
  width: 26px; height: 26px;
  border: 0.7px solid rgba(28,26,22,0.25);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9998;
  transform: translate(-50%, -50%);
  transition: width 0.2s ease, height 0.2s ease,
              border-color 0.2s ease, border-width 0.2s ease;
}
#cursor-ring.dragging {
  width: 8px; height: 8px;
  border-color: rgba(28,26,22,0.7);
  border-width: 1.5px;
}

/* ── Custom cursor — inverts against any background ────────────── */
#cursor {
  position: fixed;
  width: 8px; height: 8px;
  background: #ffffff;
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  mix-blend-mode: difference;
}

#cursor-ring {
  position: fixed;
  width: 32px; height: 32px;
  border: 0.8px solid #ffffff;
  border-radius: 50%;
  pointer-events: none;
  z-index: 9998;
  transform: translate(-50%, -50%);
  mix-blend-mode: difference;
  transition: width 0.25s ease, height 0.25s ease,
              border-color 0.25s ease, border-width 0.25s ease;
}

/* ── Nav ────────────────────────────────────────────────────────── */
.nav-back {
  position: fixed;
  top: clamp(1.2rem, 3vh, 2rem);
  left: clamp(1.5rem, 3vw, 2.5rem);
  font-family: 'Futura', monospace;
  font-size: clamp(0.42rem, 0.72vw, 0.52rem);
  font-weight: 300;
  color: var(--muted);
  letter-spacing: 0.18em;
  text-decoration: none;
  text-transform: uppercase;
  border-bottom: 0.5px solid var(--faint);
  padding-bottom: 2px;
  z-index: 100;
  cursor: none;
  transition: color 0.2s, border-color 0.2s;
}
.nav-back:hover { color: var(--ink); border-color: rgba(28,26,22,0.4); }

.nav-title {
  position: fixed;
  top: clamp(1.2rem, 3vh, 2rem);
  right: clamp(1.5rem, 4vw, 3rem);
  font-family: var(--font-ui);
  font-size: clamp(0.42rem, 0.72vw, 0.52rem);
  font-weight: 300;
  color: rgba(20,18,14,0.4);
  letter-spacing: 0.18em;
  text-decoration: none;
  text-transform: uppercase;
  border-bottom: 0.5px solid rgba(20,18,14,0.15);
  padding-bottom: 2px;
  z-index: 100;
  cursor: none;
}

/* -- CV download -------------------------------------------------- */

.nav-CV {
  position: fixed;
  top: clamp(1.2rem, 3vh, 2rem);
  left: 50%;
   transform: translateX(-50%);
  font-family: 'Futura', monospace;
  font-size: clamp(0.42rem, 0.72vw, 0.52rem);
  font-weight: 300;
  color: var(--muted);
  letter-spacing: 0.18em;
  text-decoration: none;
  text-transform: uppercase;
  border-bottom: 0.5px solid var(--faint);
  padding-bottom: 2px;
  z-index: 50;
  cursor: none;
  transition: color 0.2s, border-color 0.2s;
}
.nav-CV:hover { color: var(--ink); border-color: rgba(28,26,22,0.4); }

/* ── Counter ────────────────────────────────────────────────────── */
.image-counter {
  position: fixed;
  bottom: clamp(1.2rem, 3vh, 2rem);
  right: clamp(1.5rem, 3vw, 2.5rem);
  font-family: 'DM Mono', monospace;
  font-size: clamp(0.42rem, 0.72vw, 0.52rem);
  font-weight: 300;
  color: var(--muted);
  letter-spacing: 0.15em;
  pointer-events: none;
  z-index: 100;
  display: flex;
  gap: 4px;
  align-items: baseline;
}
.counter-sep { color: var(--faint); }

/* ── Main layout ────────────────────────────────────────────────── */
main {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(0.8rem, 2vh, 1.4rem);
  z-index: 1;
}

/* ── Top label ──────────────────────────────────────────────────── */
.label-top {
  display: flex;
  align-items: baseline;
  gap: 0.9em;
  pointer-events: none;
  user-select: none;
}

.label-index {
  font-family: 'DM Mono', monospace;
  font-size: clamp(0.4rem, 0.7vw, 0.5rem);
  font-weight: 300;
  color: var(--faint);
  letter-spacing: 0.15em;
  transition: opacity 0.15s;
}

.label-category {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(0.75rem, 1.6vw, 1.1rem);
  font-weight: 300;
  font-style: italic;
  color: var(--muted);
  letter-spacing: 0.06em;
  transition: opacity 0.15s;
}

/* ── Image frame ────────────────────────────────────────────────── */
.image-frame {
  position: relative;
  width: clamp(260px, 38vmin, 560px);
  height: clamp(320px, 47vmin, 680px);
  overflow: hidden;
  cursor: none;
  /* Subtle border */
  outline: 0.5px solid var(--faint);
}

.image-track {
  position: absolute;
  inset: 0;
}

.image-track canvas,
.image-track img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 0.06s ease;
  pointer-events: none;
  user-select: none;
}

.image-track canvas.active,
.image-track img.active { opacity: 1; }

/* ── Drag hint ──────────────────────────────────────────────────── */
.drag-hint {
  position: absolute;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: 'DM Mono', monospace;
  font-size: 0.6rem;
  font-weight: 300;
  color: rgb(251, 251, 251);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  pointer-events: none;
  transition: opacity 0.4s;
  mix-blend-mode: difference;
}
.drag-hint.hidden { opacity: 0; }

/* ── Speed bar ──────────────────────────────────────────────────── */
.speed-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 1.5px;
  width: 0%;
  background: var(--ink);
  opacity: 0.35;
  transition: width 0.1s linear;
  pointer-events: none;
}

/* ── Bottom label ───────────────────────────────────────────────── */
.label-bottom {
  display: flex;
  flex-direction: column;
  align-items: left;
  gap: 0.4rem;
  pointer-events: auto;
  user-select: none;
}

.label-title {
  font-family: 'futura', serif;
  font-size: 48px;
  font-weight: 300;
  color: var(--ink);
  text-decoration: none;
  letter-spacing: 0.02em;
  line-height: 1;
  text-align: center;
  cursor: none;
  transition: opacity 0.15s;
  border-bottom: 0.5px solid transparent;
}
/*.label-title:hover { border-bottom-color: rgba(28,26,22,0.25); }*/

.label-sub {
  font-family: 'DM Mono', monospace;
  font-size: clamp(0.4rem, 0.72vw, 0.52rem);
  font-weight: 300;
  color: var(--muted);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  transition: opacity 0.15s;
}

/* ── Bio ────────────────────────────────────────────────────────── */
.bio {
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
  max-width: 100vh;
  text-align: center;
  z-index: 100;
  color: black;
  font-weight: 300;
  font-size: clamp(0.8rem, 1.25vw, 2rem);

  align-items: center;
}

/*.bioText p {
  font-family: 'Cormorant Garamond', serif;
  font-size: 30px;
  font-weight: 300;
  font-style: italic;
  color: black;
  line-height: 1.6;
  letter-spacing: 0.01em;
}
*/
/* ── Flash utility — fires briefly on image change ─────────────── */
@keyframes labelFlash {
  0%   { opacity: 0.2; }
  100% { opacity: 1; }
}
.label-flash { animation: labelFlash 0.12s ease forwards; }

/* ── Static decorative border behind image ──────────────────────── */
.image-border {
  width: clamp(260px, 38vmin, 560px);
  height: clamp(320px, 47vmin, 680px);
  position: absolute;
  /* Offset so it peeks out from behind the image frame */
  transform: translate(14px, 14px);
  border: 0.8px solid rgba(28,26,22,0.2);
  pointer-events: none;
  z-index: 0;
}
/* Corner accents on the decorative border 
.image-border::before,
.image-border::after {
  content: "";
  position: absolute;
  width: 18px;
  height: 18px;
  border-color: rgba(28,26,22,0.35);
  border-style: solid;
}
.image-border::before {
  top: -1px; left: -1px;
  border-width: 1px 0 0 1px;
}
.image-border::after {
  bottom: -1px; right: -1px;
  border-width: 0 1px 1px 0;
}*/
/* ── Inline counter — above the image, replaces old top label ────── */
.image-counter-inline {
  font-family: 'DM Mono', monospace;
  font-size: clamp(0.42rem, 0.72vw, 0.52rem);
  font-weight: 300;
  color: var(--muted);
  letter-spacing: 0.15em;
  display: flex;
  gap: 4px;
  align-items: baseline;
  pointer-events: none;
  user-select: none;
}
.image-counter-inline .counter-sep { color: var(--faint); }
main {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(0.8rem, 2vh, 1.4rem);
  z-index: 1;
}