:root {
  --black: #17110f;
  --paper: #eadcc7;
  --white: #fbf2df;
  --muted: #7c6e5e;
  --green: #8b8f5f;
  --blue: #b8afa2;
  --pink: #d6a5a7;
  --orange: #a85d3f;
  --burgundy: #681f2d;
  --espresso: #2a1712;
  --cream: #f4e5c9;
  --graphite: #201b18;
  --border: rgba(42, 23, 18, 0.18);
  --shadow: 0 22px 70px rgba(42, 23, 18, 0.22);
  --display: "DM Serif Display", Georgia, serif;
  --play: "Allura", "Gaegu", "DM Serif Display", Georgia, serif;
  --hand: "Gaegu", "DM Serif Display", Georgia, serif;
  --mono: "DM Mono", ui-monospace, monospace;
  --body: "Instrument Sans", Inter, Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html { background: #eadcc7; }
body {
  position: relative;
  margin: 0;
  background-color: var(--paper);
  background-image:
    radial-gradient(ellipse at 18% 12%, rgba(104,31,45,.12), transparent 24%),
    radial-gradient(ellipse at 82% 18%, rgba(42,23,18,.08), transparent 22%),
    radial-gradient(ellipse at 76% 88%, rgba(139,143,95,.1), transparent 28%),
    repeating-linear-gradient(7deg, rgba(255,255,255,.08) 0 1px, transparent 1px 9px),
    repeating-linear-gradient(97deg, rgba(42,23,18,.035) 0 1px, transparent 1px 13px),
    linear-gradient(180deg, #eadcc7 0%, #e3d0b4 52%, #efe1ca 100%);
  background-size: auto, auto, auto, 240px 240px, 280px 280px, auto;
  background-position: 0 0;
  color: var(--black);
  font-family: var(--body);
  overflow-x: hidden;
}
a { color: inherit; }
a:not(.project-card) {
  text-decoration: none;
}
a:not(.project-card):hover {
  text-decoration: underline;
  text-underline-offset: 4px;
}
img {
  display: block;
  max-width: 100%;
  height: auto;
}

:focus-visible {
  outline: 2px solid rgba(104,31,45,.72);
  outline-offset: 4px;
}

body::before,
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
}

body::before {
  z-index: 0;
  background:
    radial-gradient(ellipse at 12% 26%, rgba(104,31,45,.1) 0 3%, transparent 12%),
    radial-gradient(ellipse at 84% 64%, rgba(42,23,18,.08) 0 2%, transparent 10%),
    radial-gradient(circle at 36% 42%, rgba(255,255,255,.16) 0 1px, transparent 1.4px),
    radial-gradient(circle at 72% 18%, rgba(42,23,18,.08) 0 .8px, transparent 1.3px);
  background-size: auto, auto, 22px 22px, 18px 18px;
  mix-blend-mode: multiply;
  opacity: .58;
}

body::after {
  z-index: 0;
  background-image:
    linear-gradient(115deg, transparent 0 44%, rgba(255,255,255,.1) 45%, transparent 46%),
    repeating-linear-gradient(0deg, rgba(42,23,18,.025) 0 1px, transparent 1px 5px);
  background-size: 100% 100%, 100% 10px;
  opacity: .3;
}

.cursor {
  position: fixed;
  z-index: 200;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  pointer-events: none;
  background: rgba(104,31,45,.72);
  mix-blend-mode: multiply;
  opacity: 0;
  transform: translate(-50%, -50%);
}
body.cursor-ready .cursor { opacity: 1; }

body.is-loading {
  overflow: hidden;
}

html.case-scroll-lock {
  overflow: hidden;
}

body.case-scroll-lock {
  position: fixed;
  inset: 0;
  overflow: hidden;
}

body.case-focus-open > .nav,
body.case-focus-open > .mobile-magic-popup,
body.case-focus-open > main,
body.case-focus-open > .footer {
  pointer-events: none;
  user-select: none;
  filter: blur(2.4px) saturate(.88) brightness(.84);
  transform: scale(.982);
  transform-origin: 50% 42%;
  transition:
    filter .78s cubic-bezier(.16, 1, .3, 1),
    transform .78s cubic-bezier(.16, 1, .3, 1);
}

body.case-focus-open .cursor {
  opacity: 0;
}

body.case-focus-open .project-card,
body.case-focus-open .desktop-folder,
body.case-focus-open .board-canvas,
body.case-focus-open .workspace-thoughts,
body.case-focus-open .desktop-popup,
body.case-focus-open .desktop-music-widget,
body.case-focus-open .desktop-cursor,
body.case-focus-open .desktop-paw,
body.case-focus-open .memory-fragment,
body.case-focus-open .memory-particle {
  animation-play-state: paused !important;
  transition: none;
}

.portfolio-loader {
  --load-progress: 0;
  --loader-x: 0;
  --loader-y: 0;
  --steam-strength: .42;
  --loader-breath: .72;
  position: fixed;
  inset: 0;
  z-index: 500;
  display: grid;
  place-items: center;
  overflow: hidden;
  color: var(--cream);
  background:
    radial-gradient(ellipse at 48% 38%, rgba(255,246,226,.82), transparent 26%),
    radial-gradient(ellipse at 18% 72%, rgba(104,31,45,.16), transparent 34%),
    radial-gradient(ellipse at 84% 24%, rgba(42,23,18,.14), transparent 34%),
    radial-gradient(ellipse at 62% 88%, rgba(139,143,95,.12), transparent 32%),
    repeating-linear-gradient(8deg, rgba(255,255,255,.1) 0 1px, transparent 1px 10px),
    linear-gradient(145deg, #f5e7cf 0%, #ead8bb 48%, #d9bea0 100%);
  transition: opacity 1.1s ease, visibility 1.1s ease, filter 1.1s ease;
}

body.loader-exiting .portfolio-loader {
  animation: loaderDissolve 1.3s ease forwards;
}

.portfolio-loader.is-complete .loader-scene,
.portfolio-loader.is-complete .loader-copy,
.portfolio-loader.is-complete .loader-dust {
  opacity: 0;
  transition: opacity .72s ease, transform .92s ease;
}

.portfolio-loader.is-complete .loader-scene {
  transform: scale(1.025);
}

.portfolio-loader::before,
.portfolio-loader::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.portfolio-loader::before {
  background:
    linear-gradient(115deg, transparent 0 34%, rgba(255,246,226,.08) 42%, transparent 62%),
    radial-gradient(ellipse at 28% 9%, rgba(255,246,226,.08), transparent 22%),
    radial-gradient(ellipse at 50% 100%, rgba(244,229,201,.18), transparent 36%);
  opacity: .92;
  animation: loaderLightSweep 10s ease-in-out infinite;
}

.portfolio-loader::after {
  background:
    repeating-linear-gradient(92deg, rgba(255,246,226,.035) 0 1px, transparent 1px 15px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.025) 0 1px, transparent 1px 5px),
    radial-gradient(ellipse at center, transparent 0 42%, rgba(23,17,15,.52) 100%);
  mix-blend-mode: soft-light;
  opacity: .76;
}

.loader-transition-ripple {
  position: absolute;
  left: 50%;
  top: 55%;
  z-index: 20;
  width: 22vmin;
  aspect-ratio: 1;
  border-radius: 50%;
  pointer-events: none;
  background:
    radial-gradient(circle, rgba(255,246,226,.72) 0 7%, rgba(244,229,201,.42) 8% 18%, rgba(104,31,45,.2) 19% 36%, transparent 62%);
  mix-blend-mode: screen;
  opacity: 0;
  transform: translate(-50%, -50%) scale(.25);
  filter: blur(4px);
}

.portfolio-loader.is-complete .loader-transition-ripple {
  animation: loaderExitRipple 1.3s cubic-bezier(.16, 1, .3, 1) forwards;
}

.loader-film-grain {
  position: absolute;
  inset: -20%;
  z-index: 5;
  pointer-events: none;
  background-image:
    radial-gradient(circle, rgba(255,255,255,.18) 0 1px, transparent 1.5px),
    radial-gradient(circle, rgba(42,23,18,.22) 0 .8px, transparent 1.4px);
  background-size: 22px 22px, 17px 17px;
  opacity: .2;
  animation: loaderGrain 1.1s steps(4, end) infinite;
}

.loader-scene {
  position: relative;
  z-index: 2;
  width: min(960px, 92vw);
  aspect-ratio: 1.62;
  transform:
    translate3d(calc(var(--loader-x) * -22px), calc(var(--loader-y) * -16px), 0)
    rotate(-1.8deg);
  animation: loaderCamera 11s ease-in-out infinite;
}

.loader-scene::before {
  content: "";
  position: absolute;
  left: 1%;
  right: 5%;
  bottom: 7%;
  height: 56%;
  border-radius: 46% 54% 7% 6%;
  background:
    linear-gradient(90deg, rgba(255,246,226,.07) 1px, transparent 1px),
    repeating-linear-gradient(2deg, rgba(255,246,226,.035) 0 1px, transparent 1px 9px),
    radial-gradient(ellipse at 28% 16%, rgba(251,242,223,.24), transparent 35%),
    linear-gradient(180deg, rgba(131,84,58,.9), rgba(60,33,25,.98));
  background-size: 34px 100%, 180px 180px, auto, auto;
  box-shadow: 0 42px 130px rgba(15,10,8,.48);
  transform: perspective(900px) rotateX(57deg) rotateZ(-1deg);
  transform-origin: 50% 100%;
  animation: deskShadowBreath 8.5s ease-in-out infinite;
}

.loader-light {
  position: absolute;
  left: 8%;
  top: 2%;
  width: 58%;
  height: 58%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,246,226,.22), transparent 66%);
  filter: blur(8px);
  animation: loaderLight 7.8s ease-in-out infinite;
}

.loader-tab,
.loader-note,
.loader-photo,
.loader-type,
.loader-glow,
.loader-fragment {
  position: absolute;
  z-index: 3;
  filter: drop-shadow(0 18px 26px rgba(15,10,8,.26));
  animation: loaderAmbient var(--drift-speed, 7s) cubic-bezier(.45, 0, .25, 1) infinite;
  animation-delay: var(--drift-delay, 0s);
}

.loader-tab {
  min-width: 112px;
  padding: .42rem .62rem;
  border: 1px solid rgba(244,229,201,.14);
  border-radius: 7px 7px 3px 3px;
  background: rgba(251,242,223,.095);
  color: rgba(244,229,201,.68);
  font-family: var(--hand);
  font-size: 1rem;
  backdrop-filter: blur(12px);
}

.tab-one { left: 9%; top: 24%; transform: rotate(-9deg); --drift-speed: 8.4s; --drift-delay: -1.2s; }
.tab-two { right: 20%; top: 13%; transform: rotate(6deg); --drift-speed: 9.6s; --drift-delay: -4s; }
.tab-three { right: 8%; bottom: 38%; transform: rotate(-5deg); --drift-speed: 7.4s; --drift-delay: -2.7s; }

.loader-fragment {
  color: rgba(251,242,223,.42);
  font-family: var(--display);
  letter-spacing: 0;
  pointer-events: none;
}

.fragment-one { left: 23%; top: 13%; font-size: 1.25rem; transform: rotate(-12deg); --drift-speed: 10s; --drift-delay: -4.5s; }
.fragment-two { right: 28%; bottom: 15%; font-size: 1.6rem; transform: rotate(8deg); --drift-speed: 8.8s; --drift-delay: -3.1s; }
.fragment-three { left: 67%; top: 36%; font-family: var(--hand); font-size: 1.1rem; transform: rotate(-8deg); --drift-speed: 7.8s; --drift-delay: -5.2s; }

.loader-note {
  left: 13%;
  bottom: 20%;
  width: 186px;
  min-height: 130px;
  padding: .85rem;
  border-radius: 3px;
  background: rgba(244,229,201,.88);
  color: var(--espresso);
  transform: rotate(-9deg);
  --drift-speed: 10.5s;
  --drift-delay: -2.5s;
}

.loader-note i {
  display: block;
  width: 54px;
  height: 35px;
  margin-bottom: .55rem;
  border: 1px solid rgba(42,23,18,.22);
  border-radius: 4px;
  background:
    linear-gradient(90deg, transparent 54%, rgba(104,31,45,.18) 55%),
    linear-gradient(0deg, transparent 68%, rgba(42,23,18,.12) 69%);
}

.loader-note b {
  display: block;
  margin-bottom: .45rem;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
}

.loader-note span {
  display: block;
  height: 7px;
  margin: .3rem 0;
  border-radius: 999px;
  background: rgba(42,23,18,.16);
}

.loader-note span:nth-of-type(2) { width: 72%; }
.loader-note span:nth-of-type(3) { width: 48%; }

.loader-photo {
  width: 138px;
  height: 174px;
  padding: .55rem .55rem 1.8rem;
  background: rgba(251,242,223,.88);
  border-radius: 3px;
  transform-origin: 48% 82%;
}

.loader-photo span {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 2px;
  background:
    radial-gradient(circle at 42% 36%, rgba(244,229,201,.72), transparent 11%),
    linear-gradient(145deg, rgba(104,31,45,.76), rgba(139,143,95,.46) 54%, rgba(42,23,18,.72));
}

.photo-one { right: 15%; bottom: 16%; transform: rotate(9deg); --drift-speed: 11s; --drift-delay: -5.4s; }
.photo-two { left: 31%; top: 15%; width: 112px; height: 142px; transform: rotate(5deg); --drift-speed: 9.2s; --drift-delay: -1.9s; }

.loader-type {
  color: rgba(251,242,223,.74);
  font-family: var(--display);
}

.type-one {
  left: 32%;
  bottom: 17%;
  font-size: 4rem;
  transform: rotate(-12deg);
  --drift-speed: 9s;
  --drift-delay: -6s;
}

.type-two {
  right: 33%;
  top: 25%;
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  transform: rotate(7deg);
  --drift-speed: 8.2s;
  --drift-delay: -3.5s;
}

.loader-glow {
  width: 88px;
  height: 48px;
  border: 1px solid rgba(244,229,201,.22);
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(244,229,201,.18), transparent 55%),
    rgba(104,31,45,.14);
  box-shadow: 0 0 34px rgba(214,165,167,.2);
  animation-name: loaderAmbient, hiddenUiPulse;
  animation-duration: var(--drift-speed, 7s), 5.4s;
}

.glow-one { left: 43%; top: 18%; transform: rotate(-4deg); --drift-speed: 9s; --drift-delay: -2s; }
.glow-two { right: 27%; bottom: 28%; width: 68px; height: 68px; border-radius: 50%; --drift-speed: 8s; --drift-delay: -4s; }
.glow-three { left: 58%; bottom: 12%; width: 124px; height: 28px; transform: rotate(4deg); --drift-speed: 10s; --drift-delay: -6s; }

.coffee-pour {
  position: absolute;
  left: 52%;
  top: 7%;
  z-index: 7;
  width: 92px;
  height: 250px;
  transform: translateX(-50%) rotate(3.5deg);
  animation: pourHand 5.4s ease-in-out infinite;
}

.coffee-pot-lip {
  position: absolute;
  left: 8px;
  top: 0;
  width: 104px;
  height: 46px;
  border-radius: 58% 42% 52% 48%;
  background: linear-gradient(135deg, rgba(251,242,223,.82), rgba(131,84,58,.34));
  clip-path: polygon(0 24%, 84% 0, 100% 56%, 14% 100%);
  box-shadow: 0 20px 40px rgba(15,10,8,.24);
}

.coffee-stream {
  position: absolute;
  left: 50%;
  top: 34px;
  width: 16px;
  height: 178px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, rgba(255,246,226,.18), transparent 28%),
    linear-gradient(180deg, #1b0d09, #4f2518 64%, rgba(84,39,25,.72));
  transform: translateX(-50%) scaleY(calc(.24 + var(--load-progress) * .76));
  transform-origin: 50% 0;
  filter: drop-shadow(0 0 10px rgba(131,84,58,.34));
  animation: coffeeStream 1.6s ease-in-out infinite;
}

.coffee-mug {
  position: absolute;
  left: 50%;
  bottom: 19%;
  z-index: 8;
  width: 232px;
  height: 188px;
  transform:
    translateX(calc(-50% + var(--loader-x) * 12px))
    translateY(calc(var(--loader-y) * 8px))
    rotate(-1.2deg);
  animation: mugBreath 6.2s ease-in-out infinite;
}

.coffee-mug::before {
  content: "";
  position: absolute;
  left: 30px;
  right: 34px;
  top: 32px;
  bottom: 8px;
  border-radius: 12px 14px 52px 52px / 16px 16px 58px 58px;
  background:
    radial-gradient(ellipse at 28% 18%, rgba(255,255,255,.8), transparent 10%),
    linear-gradient(92deg, rgba(255,255,255,.42), transparent 18% 72%, rgba(82,43,31,.18)),
    linear-gradient(145deg, #fff8e9 0%, #f0d9ba 44%, #c99f7e 76%, #8f5f4d 100%);
  box-shadow:
    inset 18px 8px 20px rgba(255,255,255,.28),
    inset -24px -24px 38px rgba(42,23,18,.2),
    0 34px 58px rgba(15,10,8,.32);
}

.coffee-mug::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: -10px;
  height: 34px;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at 44% 35%, rgba(255,255,255,.3), transparent 28%),
    linear-gradient(90deg, rgba(124,77,55,.28), rgba(255,246,226,.42), rgba(74,38,28,.3));
  box-shadow: 0 26px 42px rgba(15,10,8,.32);
  transform: rotate(-2deg);
}

.mug-rim {
  position: absolute;
  left: 18px;
  right: 26px;
  top: 8px;
  height: 62px;
  z-index: 4;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at center, transparent 0 47%, rgba(255,255,255,.58) 48% 55%, transparent 56%),
    radial-gradient(ellipse at center, #1c0b07 0 42%, transparent 43%),
    linear-gradient(180deg, #fffdf2 0%, #f0d4b4 68%, #b17c61 100%);
  box-shadow:
    inset 0 8px 18px rgba(255,255,255,.34),
    inset 0 -8px 18px rgba(42,23,18,.2),
    0 16px 26px rgba(15,10,8,.2);
}

.mug-handle {
  position: absolute;
  right: 2px;
  top: 58px;
  width: 68px;
  height: 86px;
  z-index: 1;
  border: 17px solid #d8b493;
  border-left: 0;
  border-radius: 0 999px 999px 0 / 0 70% 70% 0;
  box-shadow:
    inset -8px -8px 14px rgba(42,23,18,.18),
    inset 6px 5px 10px rgba(255,255,255,.28);
  filter: drop-shadow(9px 16px 18px rgba(15,10,8,.2));
}

.coffee-surface {
  position: absolute;
  left: 36px;
  right: 44px;
  top: 24px;
  height: 35px;
  z-index: 5;
  overflow: hidden;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at 31% 35%, rgba(255,246,226,.34), transparent 9%),
    radial-gradient(ellipse at 62% 58%, rgba(198,126,78,.26), transparent 20%),
    radial-gradient(ellipse at calc(34% + var(--load-progress) * 24%) 48%, rgba(244,229,201,.18), transparent 18%),
    radial-gradient(ellipse at 48% 48%, rgba(98,43,25,.5), transparent 40%),
    linear-gradient(90deg, #120604, #542617 52%, #1f0d08);
  box-shadow:
    inset 0 0 20px rgba(15,10,8,.64),
    inset 0 3px 8px rgba(255,246,226,.12);
  transform: scaleY(calc(.96 + var(--coffee-breath) * .035));
  animation: coffeeSurfaceDrift 4.2s ease-in-out infinite;
}

.coffee-surface i {
  position: absolute;
  left: var(--ripple-x, 22%);
  top: var(--ripple-y, 26%);
  width: 52%;
  aspect-ratio: 1.9;
  border: 1px solid rgba(244,229,201,.3);
  border-radius: 50%;
  opacity: calc(.2 + var(--load-progress) * .64);
  transform: scale(calc(.45 + var(--load-progress) * 1.1));
  animation: coffeeRipple 2.1s ease-out infinite;
  animation-duration: var(--ripple-duration, 2.1s);
}

.coffee-surface i:nth-child(2) {
  animation-delay: -.7s;
  --ripple-x: 42%;
  --ripple-y: 38%;
  width: 34%;
}

.coffee-surface i:nth-child(3) {
  animation-delay: -1.3s;
  --ripple-x: 5%;
  --ripple-y: 10%;
  width: 70%;
}

.coffee-fill {
  position: absolute;
  left: 42px;
  right: 50px;
  top: 46px;
  height: 98px;
  z-index: 2;
  border-radius: 0 0 42px 42px;
  background:
    radial-gradient(ellipse at 35% 18%, rgba(255,246,226,.16), transparent 15%),
    linear-gradient(180deg, rgba(91,39,23,.9), rgba(29,12,8,.96));
  transform: scaleY(calc(.18 + var(--load-progress) * .82));
  transform-origin: 50% 0;
  opacity: .74;
}

.steam {
  position: absolute;
  top: -56px;
  z-index: 6;
  width: 24px;
  height: 80px;
  border-left: 2px solid rgba(251,242,223,.34);
  border-top: 1px solid rgba(251,242,223,.16);
  border-radius: 50%;
  filter: blur(.2px);
  opacity: calc(.42 + var(--steam-strength) * .48);
  animation: steamRise 3.4s ease-in-out infinite;
}

.steam-one { left: 72px; animation-duration: 3.7s; }
.steam-two { left: 99px; height: 96px; animation-delay: -1s; animation-duration: 4.4s; }
.steam-three { left: 127px; height: 70px; animation-delay: -1.8s; animation-duration: 3.1s; }

.loader-dust {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
}

.loader-dust span {
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(251,242,223,.54);
  box-shadow: 0 0 14px rgba(251,242,223,.44);
  animation: loaderDust 8s ease-in-out infinite;
}

.loader-dust span:nth-child(1) { left: 16%; top: 28%; }
.loader-dust span:nth-child(2) { left: 72%; top: 24%; animation-delay: -1.7s; }
.loader-dust span:nth-child(3) { left: 84%; top: 62%; animation-delay: -3.4s; }
.loader-dust span:nth-child(4) { left: 26%; top: 70%; animation-delay: -4.5s; }
.loader-dust span:nth-child(5) { left: 48%; top: 16%; animation-delay: -5.8s; }
.loader-dust span:nth-child(6) { left: 60%; top: 76%; animation-delay: -2.5s; }
.loader-dust span:nth-child(7) { left: 38%; top: 42%; width: 3px; height: 3px; animation-delay: -7s; }
.loader-dust span:nth-child(8) { left: 9%; top: 58%; width: 5px; height: 5px; animation-delay: -3.9s; }
.loader-dust span:nth-child(9) { left: 91%; top: 35%; width: 3px; height: 3px; animation-delay: -6.2s; }
.loader-dust span:nth-child(10) { left: 54%; top: 54%; width: 2px; height: 2px; animation-delay: -1.1s; }

.loader-copy {
  position: absolute;
  left: 50%;
  bottom: clamp(1.7rem, 5vw, 3.6rem);
  z-index: 6;
  width: min(520px, calc(100vw - 2rem));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  color: rgba(251,242,223,.82);
  font-family: var(--hand);
  font-size: clamp(1.25rem, 2.4vw, 1.7rem);
  transform: translateX(-50%);
}

.loader-copy::before {
  content: none;
}

.loader-copy::after {
  content: none;
}

.loader-copy p,
.loader-copy span {
  margin: 0;
}

.loader-copy b {
  font-weight: 500;
}

.loader-copy p {
  transition: opacity .34s ease, transform .34s ease;
}

.loader-copy p.is-changing {
  animation: phraseWrite .62s cubic-bezier(.16, 1, .3, 1);
}

.loader-copy span {
  min-width: 4.2rem;
  padding: .34rem .58rem;
  border: 1px solid rgba(244,229,201,.16);
  border-radius: 999px;
  background: rgba(251,242,223,.08);
  color: rgba(251,242,223,.72);
  font-family: var(--mono);
  font-size: 11px;
  text-align: center;
  backdrop-filter: blur(12px);
}

@keyframes loaderCamera {
  0%, 100% { translate: 0 0; scale: 1; }
  35% { translate: -8px -7px; scale: 1.012; }
  70% { translate: 7px 4px; scale: 1.006; }
}

@keyframes loaderAmbient {
  0%, 100% { translate: 0 0; }
  30% { translate: 5px -7px; }
  68% { translate: -4px 5px; }
}

@keyframes loaderLight {
  0%, 100% { opacity: .5; transform: scale(1) translateX(0); }
  45% { opacity: .88; transform: scale(1.08) translateX(18px); }
  72% { opacity: .62; transform: scale(1.03) translateX(-10px); }
}

@keyframes loaderLightSweep {
  0%, 100% { opacity: .78; transform: translateX(-1.5%); }
  50% { opacity: .98; transform: translateX(1.5%); }
}

@keyframes deskShadowBreath {
  0%, 100% { filter: brightness(.96) saturate(.94); }
  48% { filter: brightness(1.06) saturate(1.02); }
}

@keyframes hiddenUiPulse {
  0%, 100% { opacity: .38; }
  45% { opacity: .74; }
  72% { opacity: .2; }
}

@keyframes coffeeStream {
  0%, 100% { border-radius: 999px 999px 70% 70%; width: 14px; }
  50% { border-radius: 70% 70% 999px 999px; width: 18px; }
}

@keyframes coffeeRipple {
  0% { opacity: .62; transform: translate(-18%, -22%) scale(.2) rotate(0deg); }
  58% { opacity: calc(.22 + var(--load-progress) * .38); }
  100% { opacity: 0; transform: translate(-22%, -20%) scale(calc(1.25 + var(--load-progress) * .55)) rotate(8deg); }
}

@keyframes coffeeSurfaceDrift {
  0%, 100% { background-position: 0 0, 0 0, 0 0, 0 0, 0 0; }
  50% { background-position: 4px -1px, -3px 2px, 8px 0, 0 0, 0 0; }
}

@keyframes pourHand {
  0%, 100% { translate: 0 0; rotate: 0deg; }
  48% { translate: 3px -3px; rotate: .8deg; }
}

@keyframes mugBreath {
  0%, 100% { filter: drop-shadow(0 0 0 rgba(255,246,226,0)); }
  50% { filter: drop-shadow(0 8px 16px rgba(255,246,226,.08)); }
}

@keyframes steamRise {
  0% { opacity: 0; transform: translateY(18px) translateX(0) scale(.72) rotate(8deg); border-radius: 48% 52% 50% 50%; }
  28% { opacity: calc(.34 + var(--steam-strength) * .46); }
  62% { transform: translateY(-18px) translateX(-10px) scale(1.04) rotate(18deg); border-radius: 62% 38% 56% 44%; }
  100% { opacity: 0; transform: translateY(-48px) translateX(20px) scale(1.22) rotate(-16deg); border-radius: 38% 62% 44% 56%; }
}

@keyframes loaderDust {
  0%, 100% { opacity: .08; transform: translate3d(0, 0, 0) scale(.55); }
  45% { opacity: .66; transform: translate3d(18px, -34px, 0) scale(1); }
}

@keyframes loaderGrain {
  0%, 100% { transform: translate(0, 0); }
  33% { transform: translate(-2%, 1%); }
  66% { transform: translate(1%, -2%); }
}

@keyframes phraseWrite {
  0% { opacity: 0; transform: translateY(8px) rotate(-1deg); }
  100% { opacity: 1; transform: translateY(0) rotate(0); }
}

@keyframes loaderExitRipple {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(.18); filter: blur(6px); }
  22% { opacity: .88; }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(18); filter: blur(22px); }
}

@keyframes loaderDissolve {
  0%, 68% { opacity: 1; visibility: visible; filter: blur(0) saturate(1) brightness(1); }
  100% { opacity: 0; visibility: hidden; filter: blur(18px) saturate(.82) brightness(1.08); }
}

@media (max-width: 760px) {
  .loader-scene {
    width: min(520px, 94vw);
    aspect-ratio: .82;
  }

  .cat-loader-scene {
    width: min(420px, 94vw);
    aspect-ratio: 1.42;
  }

  .cat-loader-stage {
    width: min(360px, 88vw);
    height: 150px;
  }

  .cat-loading-bar {
    width: min(320px, 82vw);
  }

  .loader-cat {
    width: 172px;
    height: 96px;
    left: calc(50% - 72px + var(--cat-shift));
  }

  .loader-cat-gif {
    left: calc(50% - 58px + var(--cat-shift));
    bottom: 40px;
    width: min(158px, 44vw);
  }

  .loader-scene::before {
    left: -18%;
    right: -18%;
    bottom: 11%;
    height: 46%;
  }

  .loader-tab,
  .loader-photo,
  .loader-type,
  .loader-glow,
  .loader-fragment,
  .loader-note {
    display: none;
  }

  .coffee-pour {
    left: 50%;
    top: 12%;
    height: 230px;
  }

  .coffee-mug {
    bottom: 24%;
    width: 198px;
    height: 162px;
  }

  .loader-copy {
    flex-direction: column;
    align-items: flex-start;
    gap: .4rem;
    font-size: 1.22rem;
  }
}

.cat-loader-scene {
  width: min(680px, 88vw);
  aspect-ratio: 2.15;
  display: grid;
  place-items: center;
  transform:
    translate3d(calc(var(--loader-x) * -14px), calc(var(--loader-y) * -10px), 0)
    rotate(-.6deg);
  animation: catCameraBreath 8.8s ease-in-out infinite;
}

.cat-loader-scene::before {
  content: "";
  position: absolute;
  inset: 13% 4% 6%;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at 48% 40%, rgba(255,246,226,.32), transparent 38%),
    radial-gradient(ellipse at 52% 78%, rgba(104,31,45,.16), transparent 54%);
  filter: blur(18px);
  opacity: .9;
  animation: catLightBreath 6.4s ease-in-out infinite;
}

.cat-loader-stage {
  position: relative;
  z-index: 3;
  width: min(520px, 86vw);
  height: 170px;
}

.cat-loader-glow {
  position: absolute;
  inset: 18% 8% 10%;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at 50% 52%, rgba(255,246,226,.3), transparent 48%),
    radial-gradient(ellipse at 48% 68%, rgba(104,31,45,.18), transparent 62%);
  filter: blur(24px);
  opacity: .84;
  animation: catGlowPulse 5.8s ease-in-out infinite;
}

.cat-loading-bar {
  position: absolute;
  left: 50%;
  bottom: 26px;
  width: min(440px, 82vw);
  height: 26px;
  overflow: hidden;
  border: 1px solid rgba(42,23,18,.12);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.38), rgba(255,255,255,0) 38%),
    rgba(255,246,226,.82);
  box-shadow:
    inset 0 1px 8px rgba(255,255,255,.42),
    inset 0 -8px 18px rgba(42,23,18,.08),
    0 18px 42px rgba(42,23,18,.18),
    0 0 36px rgba(104,31,45,.12);
  transform: translateX(-50%);
}

.cat-loading-fill {
  position: absolute;
  inset: 4px auto 4px 4px;
  width: calc((100% - 8px) * var(--load-progress));
  border-radius: 999px;
  background:
    linear-gradient(90deg, rgba(255,246,226,.18), transparent 32% 72%, rgba(255,246,226,.22)),
    linear-gradient(135deg, #681f2d, #4e1722 58%, #2a1712);
  box-shadow:
    inset 0 1px 7px rgba(255,246,226,.24),
    0 0 22px rgba(104,31,45,.34);
  transition: width .42s cubic-bezier(.16, 1, .3, 1);
}

.cat-loading-shine {
  position: absolute;
  inset: 3px;
  border-radius: 999px;
  background: linear-gradient(115deg, transparent 0 28%, rgba(255,255,255,.28) 38%, transparent 49%);
  transform: translateX(calc(-72% + var(--load-progress) * 145%));
  opacity: .44;
  mix-blend-mode: screen;
}

.loader-cat {
  --cat-shift: calc(var(--load-progress) * 24px);
  position: absolute;
  left: calc(50% - 92px + var(--cat-shift));
  bottom: 42px;
  z-index: 5;
  width: 196px;
  height: 108px;
  transform: translateX(-50%);
  filter: drop-shadow(0 22px 24px rgba(42,23,18,.24));
  animation: catBreath 4.8s ease-in-out infinite;
}

.loader-cat-gif {
  --cat-shift: calc(var(--load-progress) * 24px);
  position: absolute;
  left: calc(50% - 74px + var(--cat-shift));
  bottom: 42px;
  z-index: 5;
  width: min(190px, 42vw);
  height: auto;
  transform: translateX(-50%) rotate(-1deg);
  filter:
    sepia(.16)
    saturate(.82)
    contrast(1.05)
    drop-shadow(0 22px 24px rgba(42,23,18,.24));
  animation: catGifRest 4.8s ease-in-out infinite;
  pointer-events: none;
}

.cat-body {
  position: absolute;
  left: 35px;
  bottom: 21px;
  width: 128px;
  height: 62px;
  border-radius: 52% 48% 45% 50%;
  background:
    radial-gradient(ellipse at 35% 23%, rgba(255,255,255,.12), transparent 18%),
    linear-gradient(145deg, #302927, #100e0e 68%, #070606);
}

.cat-head {
  position: absolute;
  right: 20px;
  bottom: 44px;
  width: 62px;
  height: 54px;
  border-radius: 48% 52% 46% 44%;
  background:
    radial-gradient(ellipse at 34% 24%, rgba(255,255,255,.14), transparent 18%),
    linear-gradient(145deg, #302927, #0b0a0a 70%);
  animation: catLook 5.6s ease-in-out infinite;
}

.cat-ear {
  position: absolute;
  top: -13px;
  width: 24px;
  height: 28px;
  background: #151313;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  transform-origin: 50% 100%;
}

.cat-ear-left {
  left: 7px;
  transform: rotate(-15deg);
  animation: earTwitchLeft 6.8s ease-in-out infinite;
}

.cat-ear-right {
  right: 7px;
  transform: rotate(18deg);
  animation: earTwitchRight 7.6s ease-in-out infinite;
}

.cat-eye {
  position: absolute;
  top: 24px;
  width: 6px;
  height: 8px;
  border-radius: 999px;
  background: rgba(244,229,201,.78);
  box-shadow: 0 0 8px rgba(244,229,201,.26);
  animation: catBlink 5.2s ease-in-out infinite;
}

.cat-eye-left { left: 21px; }
.cat-eye-right { right: 18px; animation-delay: .05s; }

.cat-nose {
  position: absolute;
  left: 34px;
  top: 33px;
  width: 4px;
  height: 3px;
  border-radius: 50%;
  background: rgba(214,165,167,.72);
}

.cat-tail {
  position: absolute;
  left: 7px;
  bottom: 47px;
  width: 84px;
  height: 26px;
  border-radius: 999px 0 0 999px;
  border-top: 16px solid #111;
  transform-origin: 90% 80%;
  animation: catTailSwing 3.6s ease-in-out infinite;
}

.cat-paw {
  position: absolute;
  z-index: 7;
  width: 42px;
  height: 14px;
  border-radius: 999px;
  background: linear-gradient(145deg, #171414, #080707);
}

.cat-paw-front {
  right: 36px;
  bottom: 28px;
  transform-origin: 12% 50%;
  animation: catPawStretch 6.6s ease-in-out infinite;
}

.cat-paw-back {
  left: 78px;
  bottom: 27px;
  opacity: .82;
}

.portfolio-loader.is-complete .loader-cat {
  animation: catExit 1.18s cubic-bezier(.16, 1, .3, 1) forwards;
}

.portfolio-loader.is-complete .loader-cat-gif {
  animation: catGifExit 1.18s cubic-bezier(.16, 1, .3, 1) forwards;
}

.portfolio-loader.is-complete .cat-head {
  animation: catFinalLook 1.18s cubic-bezier(.16, 1, .3, 1) forwards;
}

.portfolio-loader.is-complete .cat-tail {
  animation: catTailExit 1.18s cubic-bezier(.16, 1, .3, 1) forwards;
}

@keyframes catCameraBreath {
  0%, 100% { translate: 0 0; scale: 1; }
  50% { translate: 0 -7px; scale: 1.012; }
}

@keyframes catLightBreath {
  0%, 100% { opacity: .66; transform: scale(.98); }
  50% { opacity: .95; transform: scale(1.05); }
}

@keyframes catGlowPulse {
  0%, 100% { opacity: .66; filter: blur(24px); }
  50% { opacity: .95; filter: blur(30px); }
}

@keyframes catBreath {
  0%, 100% { translate: 0 0; scale: 1 1; }
  50% { translate: 0 2px; scale: 1.012 .985; }
}

@keyframes catGifRest {
  0%, 100% { translate: 0 0; rotate: -1deg; }
  50% { translate: 0 2px; rotate: .6deg; }
}

@keyframes catTailSwing {
  0%, 100% { transform: rotate(-8deg); }
  50% { transform: rotate(13deg) translateY(2px); }
}

@keyframes earTwitchLeft {
  0%, 74%, 100% { transform: rotate(-15deg); }
  77% { transform: rotate(-25deg); }
  80% { transform: rotate(-11deg); }
}

@keyframes earTwitchRight {
  0%, 62%, 100% { transform: rotate(18deg); }
  65% { transform: rotate(29deg); }
  68% { transform: rotate(13deg); }
}

@keyframes catBlink {
  0%, 8%, 100% { transform: scaleY(1); }
  4% { transform: scaleY(.08); }
  64%, 70% { transform: scaleY(1); }
  67% { transform: scaleY(.08); }
}

@keyframes catLook {
  0%, 100% { rotate: 0deg; translate: 0 0; }
  46% { rotate: -2deg; translate: -1px 1px; }
}

@keyframes catPawStretch {
  0%, 55%, 100% { transform: translateX(0) rotate(0); }
  68%, 82% { transform: translateX(18px) rotate(4deg); }
}

@keyframes catExit {
  0% { opacity: 1; transform: translateX(-50%) translateY(0) rotate(0); }
  35% { transform: translateX(-35%) translateY(-18px) rotate(3deg); }
  100% { opacity: 0; transform: translateX(70%) translateY(-54px) rotate(7deg); }
}

@keyframes catGifExit {
  0% { opacity: 1; transform: translateX(-50%) translateY(0) rotate(-1deg); }
  35% { transform: translateX(-34%) translateY(-14px) rotate(3deg); }
  100% { opacity: 0; transform: translateX(72%) translateY(-52px) rotate(7deg); }
}

@keyframes catFinalLook {
  0% { rotate: 0deg; }
  100% { rotate: -8deg; }
}

@keyframes catTailExit {
  0% { transform: rotate(-8deg); }
  100% { transform: rotate(24deg); }
}

.nav {
  position: fixed;
  inset: 0 0 auto;
  z-index: 100;
  height: 66px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 clamp(1rem, 3vw, 2rem);
  background: linear-gradient(180deg, rgba(234,220,199,.82), rgba(234,220,199,0));
  color: var(--espresso);
}
.nav-logo,
.nav a {
  color: inherit;
  text-decoration: none;
  font-family: var(--mono);
  font-size: 12px;
}
.nav-links {
  display: flex;
  gap: 1.4rem;
}
.nav-links a {
  opacity: .7;
}
.nav-links a:hover {
  opacity: 1;
}

.mobile-magic-popup {
  position: fixed;
  inset: auto 1rem 1rem;
  z-index: 240;
  display: none;
  pointer-events: none;
}

.mobile-magic-card {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .28rem .85rem;
  align-items: center;
  padding: .85rem .9rem;
  border: 1px solid rgba(42,23,18,.16);
  border-radius: 8px;
  background: rgba(251,242,223,.94);
  box-shadow: 0 18px 48px rgba(42,23,18,.18);
  color: var(--espresso);
  backdrop-filter: blur(16px);
  transform: translateY(120%);
  opacity: 0;
  transition: transform .42s cubic-bezier(.18,.92,.18,1), opacity .28s ease;
}

.mobile-magic-card p {
  margin: 0;
  font-family: var(--display);
  font-size: 1.05rem;
  line-height: 1.05;
}

.mobile-magic-card span {
  color: var(--muted);
  font-family: var(--mono);
  font-size: 10px;
  line-height: 1.35;
  text-transform: uppercase;
}

.mobile-magic-close {
  grid-column: 2;
  grid-row: 1 / span 2;
  width: 40px;
  height: 34px;
  border: 1px solid rgba(42,23,18,.16);
  border-radius: 999px;
  background: rgba(104,31,45,.88);
  color: var(--white);
  font-family: var(--mono);
  font-size: 11px;
  cursor: pointer;
}

.mobile-magic-popup.is-visible {
  pointer-events: auto;
}

.mobile-magic-popup.is-visible .mobile-magic-card {
  transform: translateY(0);
  opacity: 1;
}

main {
  padding-top: 0;
}

.hero {
  min-height: 100svh;
  position: relative;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
  background:
    radial-gradient(circle at 62% 42%, rgba(104,31,45,.13), transparent 30%),
    radial-gradient(circle at 24% 36%, rgba(255,242,223,.58), transparent 24%),
    linear-gradient(180deg, rgba(255,246,226,.42), rgba(234,220,199,.18));
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(0deg, transparent 0 27px, rgba(42,23,18,.055) 28px, transparent 29px),
    repeating-linear-gradient(90deg, transparent 0 33px, rgba(42,23,18,.035) 34px, transparent 35px);
  opacity: .7;
  transform: rotate(-.4deg) scale(1.04);
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 72% 36%, rgba(255,255,255,.26), transparent 24%),
    radial-gradient(ellipse at 15% 74%, rgba(104,31,45,.11), transparent 19%),
    linear-gradient(115deg, transparent 0 62%, rgba(42,23,18,.045) 63%, transparent 66%);
  mix-blend-mode: multiply;
}

.hero-center {
  position: relative;
  z-index: 6;
  width: min(780px, 88vw);
  text-align: center;
  padding: clamp(2rem, 5vw, 4rem);
}

.hero-kicker {
  margin: 0 0 .3rem;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0;
  text-transform: uppercase;
}

.hero-logo {
  display: block;
  width: min(330px, 47vw);
  margin: 0 auto;
  filter: sepia(.12) contrast(1.06) drop-shadow(0 20px 36px rgba(42,23,18,.12));
}

.hero-illus {
  position: absolute;
  z-index: 5;
  width: var(--w);
  left: var(--x);
  top: var(--y);
  pointer-events: auto;
  user-select: none;
  filter: sepia(.12) saturate(.86) contrast(1.04) drop-shadow(0 18px 26px rgba(42,23,18,.18));
  transform: translate3d(0, 0, 0) rotate(var(--r)) scale(calc(var(--s, 1) * var(--zoom, 1)));
  transition: transform .65s cubic-bezier(.2, .8, .2, 1), filter .65s ease;
  animation: heroIllusFloat var(--d, 8s) ease-in-out infinite;
  animation-delay: var(--delay, 0s);
}

.hero-illus:hover {
  --zoom: 1.08;
  filter: sepia(.08) saturate(.96) contrast(1.06) drop-shadow(0 24px 34px rgba(42,23,18,.22));
}

.illus-one {
  --x: 25%;
  --y: 23%;
  --w: min(178px, 24vw);
  --r: -10deg;
  --s: 1;
  --d: 8.5s;
}

.illus-two {
  --x: 62%;
  --y: 22%;
  --w: min(134px, 18vw);
  --r: 9deg;
  --s: .96;
  --d: 9.2s;
  --delay: -1.7s;
}

.illus-three {
  --x: 32%;
  --y: 61%;
  --w: min(166px, 22vw);
  --r: 7deg;
  --s: .98;
  --d: 7.8s;
  --delay: -3s;
}

.illus-four {
  --x: 59%;
  --y: 63%;
  --w: min(190px, 25vw);
  --r: -8deg;
  --s: 1.04;
  --d: 8.8s;
  --delay: -2.2s;
}

.illus-five {
  --x: 47%;
  --y: 17%;
  --w: min(92px, 13vw);
  --r: 14deg;
  --s: .94;
  --d: 10s;
  --delay: -4s;
}

.fun-bit {
  position: absolute;
  z-index: 6;
  pointer-events: none;
  user-select: none;
  color: rgba(42,23,18,.58);
  font-family: var(--hand);
  font-weight: 700;
  filter: drop-shadow(0 10px 16px rgba(39,31,21,.08));
  animation: funFloat 7s ease-in-out infinite;
}

.fun-heart {
  left: 21%;
  top: 18%;
  color: rgba(104,31,45,.72);
  font-size: 3rem;
  transform: rotate(-12deg);
}

.fun-wow {
  left: 67%;
  top: 18%;
  padding: .12rem .5rem;
  border: 1px solid rgba(15,15,13,.18);
  border-radius: 999px;
  background: rgba(244,229,201,.7);
  font-size: 1.3rem;
  transform: rotate(9deg);
  animation-delay: -1.5s;
}

.fun-smile {
  left: 54%;
  top: 72%;
  color: rgba(139,143,95,.82);
  font-size: 2rem;
  transform: rotate(11deg);
  animation-delay: -2.8s;
}

.fun-scribble {
  left: 30%;
  top: 52%;
  width: 74px;
  height: 30px;
  border-top: 3px solid rgba(104,31,45,.48);
  border-radius: 50%;
  transform: rotate(-18deg);
  animation-delay: -3.6s;
}

.fun-dotline {
  left: 71%;
  top: 58%;
  width: 86px;
  height: 18px;
  background: radial-gradient(circle, rgba(42,23,18,.34) 0 2px, transparent 2.5px);
  background-size: 14px 14px;
  transform: rotate(18deg);
  animation-delay: -4.4s;
}

@keyframes heroIllusFloat {
  0%, 100% {
    translate: 0 0;
  }
  50% {
    translate: 0 -10px;
  }
}

@keyframes funFloat {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -7px; }
}

.hero-bottom {
  position: absolute;
  left: clamp(1rem, 4vw, 3rem);
  right: clamp(1rem, 4vw, 3rem);
  bottom: clamp(1.2rem, 3vw, 2rem);
  z-index: 8;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1.4rem;
  align-items: center;
  padding: .85rem 1rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(251,247,239,.72);
  color: var(--muted);
  font-family: var(--mono);
  font-size: 12px;
  text-transform: uppercase;
}
.hero-bottom i {
  display: inline-block;
  width: 7px;
  height: 7px;
  margin-right: 7px;
  border-radius: 50%;
  background: #22c55e;
}
.hero-bottom a { text-decoration: none; color: var(--black); }

.hero-right {
  position: absolute;
  inset: 0;
  z-index: 7;
  overflow: hidden;
  border-left: 0;
  min-height: auto;
  pointer-events: none;
}

.desk-layer {
  position: absolute;
  z-index: 3;
  pointer-events: none;
  user-select: none;
}

.coffee-stain {
  left: 70%;
  top: 14%;
  width: 150px;
  aspect-ratio: 1.18;
  border: 13px solid rgba(92,50,32,.16);
  border-radius: 48% 52% 45% 55%;
  filter: blur(.2px);
  transform: rotate(16deg);
}

.coffee-stain::after {
  content: "";
  position: absolute;
  inset: 25%;
  border: 2px solid rgba(92,50,32,.12);
  border-radius: 50%;
}

.paperclip {
  left: 39%;
  top: 20%;
  width: 34px;
  height: 72px;
  border: 4px solid rgba(42,23,18,.34);
  border-left-width: 3px;
  border-radius: 999px;
  transform: rotate(-19deg);
}

.paperclip::after {
  content: "";
  position: absolute;
  inset: 9px 7px;
  border: 3px solid rgba(42,23,18,.28);
  border-left: 0;
  border-radius: 999px;
}

.loading-note,
.desk-arrow,
.desk-quote {
  padding: .28rem .5rem;
  color: rgba(42,23,18,.62);
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
}

.loading-note {
  left: 18%;
  top: 82%;
  background: rgba(244,229,201,.68);
  border: 1px dashed rgba(42,23,18,.18);
  transform: rotate(3deg);
}

.desk-arrow {
  left: 56%;
  top: 24%;
  color: rgba(104,31,45,.74);
  font-family: var(--hand);
  font-size: 1.28rem;
  font-weight: 700;
  text-transform: none;
  transform: rotate(-8deg);
}

.desk-quote {
  left: 8%;
  top: 47%;
  width: 210px;
  font-family: var(--display);
  font-size: 1.25rem;
  line-height: 1;
  text-transform: none;
  transform: rotate(-6deg);
}

.float-card {
  position: absolute;
  left: var(--x);
  top: var(--y);
  transform: rotate(var(--r));
  border: 1px solid rgba(42,23,18,.18);
  background: rgba(251,242,223,.9);
  box-shadow: var(--shadow);
  cursor: grab;
  user-select: none;
  pointer-events: auto;
}

.ticket-card {
  position: absolute;
  right: calc((clamp(310px, 34vw, 460px) - clamp(92px, 11vw, 136px)) * -1);
  top: 46%;
  z-index: 115;
  width: clamp(310px, 34vw, 460px);
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  pointer-events: auto;
  transform: translate3d(0, -50%, 0) rotate(-4deg);
  transform-origin: 100% 50%;
  filter: drop-shadow(0 18px 30px rgba(42,23,18,.18));
  animation: ticketBreath 6.6s ease-in-out infinite;
  transition:
    right .58s cubic-bezier(.18, .92, .18, 1),
    transform .58s cubic-bezier(.18, .92, .18, 1),
    filter .42s ease,
    opacity .24s ease;
  will-change: right, transform, filter;
}

.ticket-card img {
  display: block;
  width: 100%;
  filter: sepia(.18) saturate(.86) contrast(1.05);
}

.ticket-card:hover {
  right: calc((clamp(310px, 34vw, 460px) - clamp(170px, 18vw, 230px)) * -1);
  filter: drop-shadow(0 34px 54px rgba(42,23,18,.32));
  transform: translate3d(-10px, -52%, 0) rotate(-2deg) perspective(900px) rotateY(-5deg) rotateX(2deg);
  text-decoration: none;
}

.ticket-card:focus-visible {
  outline: 2px solid rgba(104,31,45,.76);
  outline-offset: 6px;
}

.ticket-card.is-pulling {
  right: 50%;
  transform: translate3d(50%, -50%, 0) rotate(.7deg) perspective(1100px) rotateY(-9deg) scale(1.08);
  filter: drop-shadow(0 48px 82px rgba(42,23,18,.38));
  animation: ticketPull .36s cubic-bezier(.18, .92, .18, 1) both;
}

@keyframes ticketBreath {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -9px; }
}

@keyframes ticketPull {
  0% {
    right: calc((clamp(310px, 34vw, 460px) - clamp(92px, 11vw, 136px)) * -1);
    transform: translate3d(0, -50%, 0) rotate(-4deg);
  }
  62% {
    right: 42%;
    transform: translate3d(32%, -52%, 0) rotate(1.6deg) perspective(1100px) rotateY(-14deg) scale(1.04);
  }
  100% {
    right: 50%;
    transform: translate3d(50%, -50%, 0) rotate(.7deg) perspective(1100px) rotateY(-9deg) scale(1.08);
  }
}

.ticket-card.dragging {
  cursor: grabbing;
  z-index: 20;
}

.ticket-expanded {
  position: fixed;
  inset: 0;
  z-index: 250;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 4vw, 3rem);
  pointer-events: none;
  perspective: 1400px;
}
.ticket-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(23,17,15,.34);
  opacity: 0;
  backdrop-filter: blur(0);
  transition: opacity .45s ease, backdrop-filter .45s ease;
}
.ticket-panel {
  position: relative;
  z-index: 2;
  width: min(720px, 88vw);
  display: block;
  overflow: visible;
  border: 0;
  background: transparent;
  box-shadow: none;
  opacity: 0;
  transform: translateY(48px) rotateX(66deg) rotateZ(-7deg) scale(.56);
  transform-origin: 50% 18%;
  transition:
    opacity .34s ease,
    transform .72s cubic-bezier(.16, 1, .3, 1),
    box-shadow .72s ease;
}
.ticket-panel-image {
  display: block;
  width: 100%;
  filter: drop-shadow(0 42px 72px rgba(42,23,18,.34));
  transform: rotate(-3deg);
  pointer-events: none;
}
.ticket-close {
  position: absolute;
  right: -0.6rem;
  top: -0.6rem;
  z-index: 3;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(42,23,18,.14);
  border-radius: 50%;
  background: rgba(255,255,255,.44);
  color: rgba(42,23,18,.78);
  cursor: pointer;
  font-size: 1.5rem;
  line-height: 1;
  backdrop-filter: blur(10px);
}
body.ticket-open {
  overflow: hidden;
}
body.ticket-open .ticket-expanded {
  pointer-events: auto;
}
body.ticket-open .ticket-card {
  opacity: 0;
  pointer-events: none;
}
body.ticket-open .ticket-backdrop {
  opacity: 1;
  backdrop-filter: blur(8px);
}
body.ticket-open .ticket-panel {
  opacity: 1;
  box-shadow: 0 58px 150px rgba(42,23,18,.36);
  transform: translateY(0) rotateX(0) rotateZ(0) scale(1);
}
body.ticket-open .hero-center,
body.ticket-open .hero-right,
body.ticket-open .about,
body.ticket-open .work,
body.ticket-open .scrapbook-section,
body.ticket-open .footer {
  filter: blur(2px) saturate(.92);
  transition: filter .45s ease;
}

.doodle {
  position: absolute;
  left: var(--x);
  top: var(--y);
  z-index: 3;
  transform: rotate(var(--r));
  color: rgba(15,15,13,.58);
  font-family: var(--hand);
  font-weight: 700;
  pointer-events: none;
  user-select: none;
}

.doodle-star {
  font-size: clamp(2.8rem, 5vw, 5rem);
  color: rgba(238,143,85,.72);
}

.doodle-note {
  padding: .15rem .45rem;
  border: 1px solid rgba(15,15,13,.22);
  border-radius: 999px;
  background: rgba(251,247,239,.55);
  color: rgba(15,15,13,.55);
  font-size: 1.25rem;
}

.doodle-arrow {
  font-size: clamp(3rem, 6vw, 5.5rem);
  color: rgba(15,15,13,.5);
}

.doodle-ring {
  width: 84px;
  height: 58px;
  border: 2px solid rgba(15,15,13,.28);
  border-radius: 49% 51% 44% 56%;
}

.doodle-ring::after {
  content: "";
  position: absolute;
  inset: 9px 13px;
  border: 1px solid rgba(239,191,208,.75);
  border-radius: 55% 45% 50% 50%;
}

.doodle-spark {
  color: rgba(92,115,75,.66);
  font-size: 1.8rem;
  letter-spacing: .18rem;
}
.float-card.dragging {
  cursor: grabbing;
  z-index: 20;
}
.profile-card {
  width: min(260px, 34vw);
  padding: .7rem;
  border-radius: 24px;
}
.profile-card img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 18px;
}
.profile-card p { margin: .7rem 0 0; font-size: 13px; color: var(--muted); }

.hanging-badge {
  left: var(--x);
  top: var(--y, 0);
  z-index: 12;
  width: min(250px, 28vw);
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  transform: rotate(var(--r));
  transform-origin: 50% -58px;
  animation: badgeSwing 6.8s cubic-bezier(.45, 0, .25, 1) infinite;
}

.hanging-badge::before,
.hanging-badge::after {
  content: "";
  position: absolute;
  z-index: 4;
  pointer-events: none;
}

.hanging-badge::before {
  right: -18px;
  top: 58px;
  width: 42px;
  height: 24px;
  border-top: 2px solid rgba(42,23,18,.28);
  border-radius: 50%;
  transform: rotate(22deg);
}

.hanging-badge::after {
  left: -24px;
  bottom: 42px;
  width: 32px;
  height: 32px;
  background:
    linear-gradient(45deg, transparent 44%, rgba(104,31,45,.62) 45% 55%, transparent 56%),
    linear-gradient(-45deg, transparent 44%, rgba(104,31,45,.62) 45% 55%, transparent 56%);
}

.badge-nail {
  position: absolute;
  left: 50%;
  top: -64px;
  z-index: 5;
  width: 18px;
  height: 18px;
  border: 2px solid rgba(15,15,13,.28);
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #fff, #c9beb0 48%, #73675d);
  box-shadow: 0 8px 18px rgba(39,31,21,.16);
  transform: translateX(-50%);
}

.badge-string {
  position: absolute;
  left: 50%;
  top: -54px;
  z-index: 2;
  width: 82px;
  height: 86px;
  border-top: 1.5px solid rgba(15,15,13,.32);
  border-left: 1.5px solid rgba(15,15,13,.32);
  transform: translateX(-50%) rotate(45deg);
  transform-origin: center;
}

.badge-inner {
  position: relative;
  z-index: 3;
  padding: .72rem;
  border: 1px solid rgba(15,15,13,.16);
  border-radius: 12px 18px 14px 16px;
  background:
    linear-gradient(145deg, rgba(244,229,201,.92), rgba(251,242,223,.76)),
    radial-gradient(circle at 20% 5%, rgba(104,31,45,.14), transparent 48%),
    radial-gradient(circle at 95% 90%, rgba(139,143,95,.16), transparent 42%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.85),
    0 24px 70px rgba(42,23,18,.22),
    0 0 42px rgba(104,31,45,.09);
}

.badge-inner::before,
.badge-inner::after {
  content: "";
  position: absolute;
  z-index: 5;
  width: 76px;
  height: 24px;
  background: rgba(255,255,255,.44);
  border: 1px solid rgba(42,23,18,.06);
  box-shadow: 0 8px 16px rgba(42,23,18,.08);
}

.badge-inner::before {
  left: 18px;
  top: -10px;
  transform: rotate(-8deg);
}

.badge-inner::after {
  right: 20px;
  bottom: 42px;
  transform: rotate(7deg);
}

.badge-photo {
  position: relative;
  overflow: hidden;
  border-radius: 36px;
  background: var(--black);
}

.badge-photo img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  transition: opacity .75s ease, transform .75s ease, filter .75s ease;
}

.badge-photo .photo-real {
  filter: grayscale(1) sepia(.18) contrast(1.1);
}

.badge-photo .photo-cartoon {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: scale(1.04);
  filter: saturate(1.16) contrast(1.03);
}

.badge-photo .photo-cartoon-alt {
  transform: scale(1.02);
  transition-delay: 0s;
}

.hanging-badge:hover {
  animation-play-state: paused;
}

.hanging-badge:hover .photo-real {
  opacity: 0;
  transform: scale(1.04);
  filter: blur(4px) saturate(.9);
}

.hanging-badge:hover .photo-cartoon {
  opacity: 1;
  transform: scale(1);
}

.hanging-badge:hover .photo-cartoon-alt {
  opacity: 1;
  transform: scale(1);
  transition-delay: 1s;
}

.hanging-badge p {
  margin: .78rem .2rem .1rem;
  color: rgba(42,23,18,.68);
  font-family: var(--hand);
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}

.badge-background-quote {
  left: clamp(2.4rem, 8vw, 7rem);
  top: calc(clamp(27rem, 52vh, 33rem) + 14px);
  z-index: 4;
  width: 230px;
  color: rgba(42,23,18,.72);
  font-family: var(--display);
  font-size: 1.25rem;
  line-height: 1;
  text-align: center;
  transform: rotate(-5deg);
}

.journey-button {
  position: absolute;
  right: clamp(1rem, 3vw, 2.4rem);
  top: clamp(5.2rem, 12vh, 7.5rem);
  z-index: 11;
  display: inline-flex;
  align-items: center;
  gap: .62rem;
  padding: .78rem 1rem .78rem .82rem;
  border: 1px solid rgba(42,23,18,.2);
  border-radius: 999px;
  background:
    radial-gradient(circle at 28% 12%, rgba(255,255,255,.76), transparent 32%),
    linear-gradient(135deg, rgba(251,242,223,.94), rgba(214,165,167,.82));
  box-shadow: 0 18px 38px rgba(42,23,18,.18);
  color: rgba(42,23,18,.84);
  font-family: var(--hand);
  font-size: 1.18rem;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  pointer-events: auto;
  transform: rotate(4deg);
  transition: transform .38s cubic-bezier(.2, .8, .2, 1), box-shadow .38s ease, filter .38s ease;
}

.journey-button:hover {
  text-decoration: none;
  filter: saturate(1.04);
  box-shadow: 0 24px 48px rgba(42,23,18,.22);
  transform: rotate(2deg) translateY(-5px) scale(1.03);
}

.journey-icon {
  position: relative;
  width: 34px;
  height: 24px;
  flex: 0 0 auto;
  border: 2px solid rgba(104,31,45,.62);
  border-radius: 6px;
  background: rgba(255,255,255,.36);
}

.journey-icon::before,
.journey-icon::after {
  content: "";
  position: absolute;
  inset: 4px 5px auto;
  height: 14px;
  border-top: 2px solid rgba(104,31,45,.62);
  transform-origin: top;
}

.journey-icon::before {
  transform: skewY(32deg);
}

.journey-icon::after {
  transform: skewY(-32deg);
}

@keyframes badgeSwing {
  0%, 100% {
    transform: rotate(-2.4deg) translateY(0);
  }
  25% {
    transform: rotate(2.2deg) translateY(4px);
  }
  50% {
    transform: rotate(-1deg) translateY(1px);
  }
  75% {
    transform: rotate(1.6deg) translateY(5px);
  }
}
.terminal-card {
  width: min(330px, 38vw);
  padding: 1rem;
  border-radius: 14px;
  background: var(--black);
  color: var(--white);
}
.window-bar { display: flex; gap: 5px; margin-bottom: 1rem; }
.window-bar span { width: 9px; height: 9px; border-radius: 50%; background: var(--orange); }
.terminal-card small { color: rgba(251,247,239,.55); font-family: var(--mono); }
.terminal-card strong {
  
  splay: block;
  margin-top: 1rem;
  font-family: var(--display);
  font-size: 2.4rem;
  line-height: .95;
  font-weight: 400;
}
.photo-card {
  width: min(230px, 30vw);
  padding: .6rem;
  border-radius: 20px;
}
.photo-card img { width: 100%; aspect-ratio: 1.2 / 1; object-fit: cover; border-radius: 14px; }
.photo-card span { display: block; margin-top: .4rem; color: var(--muted); font-size: 12px; }
.folder-card {
  width: min(300px, 36vw);
  display: grid;
  gap: .3rem;
  padding: 1rem;
  border-radius: 14px 14px 24px 24px;
  background: var(--blue);
}
.folder-card strong { font-family: var(--display); font-size: 2.5rem; line-height: .9; font-weight: 400; }
.folder-card span,
.folder-card small { font-family: var(--mono); color: rgba(15,15,13,.62); font-size: 12px; }
.playlist-card {
  width: 250px;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: .75rem;
  padding: 1rem .9rem .85rem;
  border-radius: 8px 18px 10px 16px;
  background:
    linear-gradient(90deg, rgba(42,23,18,.08) 1px, transparent 1px),
    radial-gradient(circle at 16% 14%, rgba(255,255,255,.48), transparent 34%),
    linear-gradient(135deg, rgba(104,31,45,.9), rgba(79,44,32,.88));
  background-size: 12px 100%, auto, auto;
  border-color: rgba(42,23,18,.2);
  text-align: center;
  overflow: hidden;
  color: var(--cream);
}
.record-player {
  position: relative;
  width: 104px;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
}
.record {
  position: relative;
  width: 94px;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    repeating-radial-gradient(circle, rgba(255,255,255,.08) 0 1px, transparent 1px 5px),
    radial-gradient(circle, var(--paper) 0 11%, #111 12% 45%, #38312d 46% 51%, #111 52%);
  box-shadow: 0 18px 32px rgba(15,15,13,.18);
  animation: vinylSpin 3.8s linear infinite;
  animation-play-state: paused;
}
.record span {
  position: absolute;
  inset: 35%;
  border-radius: 50%;
  background: #9a3945;
  border: 1px solid rgba(15,15,13,.12);
}
.tone-arm {
  position: absolute;
  right: 2px;
  top: 15px;
  width: 48px;
  height: 7px;
  border-radius: 999px;
  background: rgba(244,229,201,.68);
  transform: rotate(-28deg);
  transform-origin: right center;
  box-shadow: 0 8px 16px rgba(42,23,18,.22);
  transition: transform .45s cubic-bezier(.2,.8,.2,1);
}
.tone-arm::after {
  content: "";
  position: absolute;
  left: -4px;
  top: 3px;
  width: 12px;
  height: 8px;
  border-radius: 3px;
  background: rgba(244,229,201,.82);
  transform: rotate(18deg);
}
.playlist-meta {
  display: grid;
  gap: .12rem;
  text-align: left;
}
.playlist-meta small {
  color: rgba(244,229,201,.58);
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
}
.playlist-meta span {
  color: rgba(244,229,201,.92);
  font-family: var(--display);
  font-size: 1.25rem;
  line-height: .95;
}
.playlist-toggle {
  grid-column: 2;
  justify-self: start;
  width: 38px;
  height: 30px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(244,229,201,.22);
  border-radius: 999px;
  background: rgba(244,229,201,.18);
  color: var(--cream);
  cursor: pointer;
  backdrop-filter: blur(10px);
}
.play-icon {
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 9px solid rgba(244,229,201,.86);
  margin-left: 2px;
}
.pause-bars {
  display: none;
  gap: 4px;
}
.pause-bars i {
  width: 4px;
  height: 13px;
  border-radius: 999px;
  background: rgba(244,229,201,.86);
}
.sound-bars {
  grid-column: 1 / -1;
  display: flex;
  align-items: end;
  gap: 4px;
  height: 20px;
  padding: 0 .2rem;
}
.sound-bars span {
  flex: 1;
  height: 5px;
  border-radius: 999px;
  background: rgba(244,229,201,.34);
  animation: soundPulse 1.2s ease-in-out infinite;
  animation-play-state: paused;
}
.sound-bars span:nth-child(2) { animation-delay: -.3s; }
.sound-bars span:nth-child(3) { animation-delay: -.6s; }
.sound-bars span:nth-child(4) { animation-delay: -.15s; }
.playlist-card.is-playing .record,
.playlist-card.is-playing .sound-bars span {
  animation-play-state: running;
}
.playlist-card.is-playing .tone-arm {
  transform: rotate(-7deg);
}
.playlist-card.is-playing .play-icon {
  display: none;
}
.playlist-card.is-playing .pause-bars {
  display: flex;
}

@keyframes vinylSpin {
  to { transform: rotate(360deg); }
}

@keyframes soundPulse {
  0%, 100% { height: 5px; opacity: .45; }
  50% { height: 18px; opacity: .82; }
}

.sticker-card {
  width: 150px;
  min-height: 78px;
  display: grid;
  place-items: center;
  padding: .8rem;
  border-radius: 999px;
  background: rgba(139,143,95,.86);
  color: rgba(23,17,15,.76);
  font-family: var(--mono);
  font-size: 12px;
  text-transform: uppercase;
}

.diary-card {
  width: 230px;
  display: grid;
  gap: .45rem;
  padding: 1rem;
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(244,229,201,.96), rgba(225,199,165,.94));
  border-radius: 8px 18px 12px 14px;
  transform-origin: 20% 0;
}

.diary-card small {
  color: rgba(42,23,18,.55);
  font-family: var(--mono);
  font-size: 12px;
  text-transform: uppercase;
}

.diary-card strong {
  font-family: var(--display);
  font-size: 2rem;
  font-weight: 400;
  line-height: .95;
}

.sticker-card::after,
.diary-card::after,
.playlist-card::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.sticker-card::after {
  right: -16px;
  top: -18px;
  width: 58px;
  height: 18px;
  background: rgba(255,255,255,.36);
  border: 1px solid rgba(42,23,18,.06);
  transform: rotate(18deg);
}

.diary-card::after {
  left: 18px;
  top: -12px;
  width: 76px;
  height: 24px;
  background: rgba(255,255,255,.38);
  transform: rotate(-7deg);
}

.playlist-card::after {
  right: 16px;
  top: -9px;
  width: 82px;
  height: 21px;
  background: rgba(244,229,201,.28);
  border: 1px solid rgba(244,229,201,.16);
  transform: rotate(4deg);
}

.hero-right:hover .doodle-star,
.hero-right:hover .fun-heart {
  animation: doodlePop .72s cubic-bezier(.2, .8, .2, 1);
}

@keyframes doodlePop {
  0%, 100% { scale: 1; }
  45% { scale: 1.18; }
}

.about,
.work,
.playground {
  width: min(1160px, 92vw);
  margin: 0 auto;
  padding: clamp(4rem, 8vw, 7rem) 0;
}

.about,
.work,
.scrapbook-section {
  content-visibility: auto;
  contain-intrinsic-size: 900px;
}

.about {
  width: 100%;
  max-width: none;
  padding-inline: clamp(2rem, 10vw, 9rem);
}
.about-canvas {
  position: relative;
  min-height: clamp(720px, 78vw, 930px);
  display: grid;
  place-items: center;
  padding: clamp(3.2rem, 7vw, 6rem) 0;
  overflow: visible;
  isolation: isolate;
}

.about-canvas::before {
  content: none;
}

.about-glow {
  position: absolute;
  right: -12%;
  top: -18%;
  z-index: 0;
  width: 560px;
  max-width: 70vw;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,226,167,.5), transparent 68%);
  pointer-events: none;
}

.about-book {
  position: relative;
  z-index: 7;
  display: block;
  width: min(760px, 88vw);
  filter: drop-shadow(0 30px 58px rgba(42,23,18,.22));
  transform: translateX(-58px);
  transition: transform .55s cubic-bezier(.2, .8, .2, 1), filter .55s ease;
}

.about-book:hover {
  transform: translateX(-58px) scale(1.035);
  filter: drop-shadow(0 38px 68px rgba(42,23,18,.26));
}

.about-thisisme {
  position: absolute;
  left: clamp(1rem, 4vw, 4rem);
  top: clamp(.8rem, 3vw, 2.4rem);
  z-index: 5;
  width: min(300px, 38vw);
  filter: drop-shadow(0 18px 32px rgba(42,23,18,.18));
  transform: rotate(-6deg);
  transition: transform .45s cubic-bezier(.2, .8, .2, 1), filter .45s ease;
}

.about-thisisme:hover {
  transform: rotate(-4deg) translateY(-6px) scale(1.04);
  filter: drop-shadow(0 24px 42px rgba(42,23,18,.22));
}

.about-browser,
.about-wireframe,
.about-clip,
.about-doodle,
.about-coffee {
  position: absolute;
  z-index: 2;
}

.about-browser,
.about-wireframe {
  border: 1px solid rgba(42,23,18,.13);
  box-shadow: 0 22px 48px rgba(42,23,18,.16);
}

.about-tape {
  position: absolute;
  left: 50%;
  top: -12px;
  width: 72px;
  height: 22px;
  border: 1px solid rgba(42,23,18,.05);
  border-radius: 4px;
  background: rgba(255,255,255,.45);
  box-shadow: 0 6px 14px rgba(42,23,18,.08);
  transform: translateX(-50%) rotate(-5deg);
}

.about-browser::after,
.about-wireframe::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.6);
}

.about-browser p,
.about-wireframe small {
  display: block;
  margin: 0 0 .45rem;
  color: rgba(104,31,45,.65);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 400;
  text-transform: uppercase;
}

.about-browser {
  right: clamp(1.5rem, 7vw, 6rem);
  top: 45%;
  width: 220px;
  padding: .75rem;
  border-radius: 13px;
  background: rgba(244,229,201,.88);
  transform: rotate(-3deg);
  transition: transform .42s cubic-bezier(.2, .8, .2, 1), box-shadow .42s ease;
}

.about-browser:hover {
  transform: rotate(-1deg) translateY(-7px) scale(1.03);
  box-shadow: 0 30px 58px rgba(42,23,18,.2);
}

.about-browser div {
  display: flex;
  gap: 5px;
  margin-bottom: .6rem;
}

.about-browser div span {
  width: 8px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(104,31,45,.5);
}

.about-browser p {
  margin-bottom: .6rem;
}

.about-browser i,
.about-wireframe span {
  display: block;
  height: 18px;
  margin-top: .4rem;
  border-radius: 999px;
  background: rgba(42,23,18,.14);
}

.about-browser i:last-child {
  width: 58%;
  background: rgba(139,143,95,.18);
}

.about-wireframe {
  left: 28%;
  top: 13%;
  width: 190px;
  padding: .75rem;
  border-radius: 12px;
  background: rgba(255,250,232,.84);
  transform: rotate(8deg);
  transition: transform .42s cubic-bezier(.2, .8, .2, 1), box-shadow .42s ease;
}

.about-wireframe:hover {
  transform: rotate(5deg) translateY(-6px) scale(1.03);
  box-shadow: 0 30px 58px rgba(42,23,18,.2);
}

.about-wireframe span:nth-of-type(2) { width: 74%; background: rgba(104,31,45,.14); }
.about-wireframe span:nth-of-type(3) { width: 48%; background: rgba(139,143,95,.18); }

.about-love-note {
  position: absolute;
  right: clamp(1.5rem, 6vw, 5.5rem);
  top: 8%;
  z-index: 8;
  width: min(300px, 24vw);
  color: rgba(42,23,18,.78);
  font-family: var(--hand);
  font-weight: 700;
  transform: rotate(4deg);
  pointer-events: none;
}

.about-love-note p {
  width: 17ch;
  margin: 0 0 .55rem;
  overflow: hidden;
  border-right: 2px solid rgba(104,31,45,.55);
  color: rgba(104,31,45,.78);
  font-size: clamp(1.25rem, 2vw, 1.7rem);
  line-height: 1;
  white-space: nowrap;
  animation: loveTyping 2.1s steps(22, end) both, loveCaret .8s step-end infinite;
}

.about-love-note ul {
  display: grid;
  gap: .22rem;
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: clamp(.98rem, 1.25vw, 1.18rem);
  line-height: 1.02;
}

.about-love-note li {
  opacity: 0;
  transform: translateY(5px);
  animation: loveLine .48s ease forwards;
}

.about-love-note li::before {
  content: "* ";
  color: rgba(104,31,45,.72);
}

.about-love-note li:nth-child(1) { animation-delay: 2.1s; }
.about-love-note li:nth-child(2) { animation-delay: 2.35s; }
.about-love-note li:nth-child(3) { animation-delay: 2.6s; }
.about-love-note li:nth-child(4) { animation-delay: 2.85s; }
.about-love-note li:nth-child(5) { animation-delay: 3.1s; }
.about-love-note li:nth-child(6) { animation-delay: 3.35s; }
.about-love-note li:nth-child(7) { animation-delay: 3.6s; }
.about-love-note li:nth-child(8) { animation-delay: 3.85s; }

.about-coffee {
  z-index: 1;
  width: 116px;
  aspect-ratio: 1.14;
  border: 12px solid rgba(92,50,32,.13);
  border-radius: 48% 52% 45% 55%;
  pointer-events: none;
}

.about-coffee::after {
  content: "";
  position: absolute;
  inset: 25%;
  border: 2px solid rgba(92,50,32,.1);
  border-radius: 50%;
}

.about-coffee-one {
  left: 20%;
  bottom: 17%;
  transform: rotate(-18deg);
}

.about-coffee-two {
  right: 20%;
  top: 33%;
  width: 82px;
  transform: rotate(12deg);
}

.about-clip {
  width: 28px;
  height: 66px;
  border: 4px solid rgba(42,23,18,.26);
  border-radius: 999px;
}

.about-clip::after {
  content: "";
  position: absolute;
  inset: 9px 6px;
  border: 3px solid rgba(42,23,18,.18);
  border-left: 0;
  border-radius: 999px;
}

.about-clip-one {
  left: 59%;
  top: 16%;
  transform: rotate(20deg);
}

.about-clip-two {
  right: 18%;
  bottom: 12%;
  transform: rotate(-18deg);
}

.about-doodle {
  z-index: 6;
  color: rgba(104,31,45,.68);
  font-family: var(--hand);
  font-weight: 700;
  pointer-events: none;
  filter: drop-shadow(0 8px 12px rgba(42,23,18,.08));
  animation: aboutBob 5.5s ease-in-out infinite;
}

.doodle-heart {
  left: 21%;
  top: 28%;
  font-size: 2.5rem;
  transform: rotate(-12deg);
}

.doodle-stars {
  right: 23%;
  top: 12%;
  color: rgba(139,143,95,.72);
  font-size: 1.9rem;
  transform: rotate(9deg);
  animation-delay: -1.6s;
}

.doodle-arrow {
  left: 58%;
  bottom: 16%;
  font-size: 2rem;
  transform: rotate(-7deg);
  animation-delay: -2.4s;
}

.doodle-calm {
  left: 5%;
  top: 55%;
  color: rgba(42,23,18,.52);
  font-size: 2rem;
  transform: rotate(8deg);
  animation-delay: -3s;
}

.paw-trail {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
}

.paw-trail-top {
  z-index: 10;
}

.about-cat-gif {
  position: absolute;
  right: clamp(1.1rem, 5vw, 5.5rem);
  bottom: clamp(4.2rem, 8vw, 7rem);
  z-index: 12;
  width: min(220px, 29vw);
  pointer-events: none;
  filter: drop-shadow(0 16px 22px rgba(42,23,18,.16));
}

.paw-print {
  position: absolute;
  width: 48px;
  height: 44px;
  opacity: 0;
  color: rgba(104,31,45,.46);
  filter: drop-shadow(0 3px 5px rgba(42,23,18,.08));
  transform: rotate(var(--paw-r, -18deg)) scale(var(--paw-s, 1));
  animation: pawStep 8.8s ease-in-out infinite;
}

.paw-print::before,
.paw-print::after {
  content: "";
  position: absolute;
  background: currentColor;
  mix-blend-mode: multiply;
}

.paw-print::before {
  left: 13px;
  top: 19px;
  width: 22px;
  height: 17px;
  border-radius: 48% 52% 54% 46%;
  transform: rotate(-8deg);
}

.paw-print::after {
  left: 3px;
  top: 0;
  width: 11px;
  height: 12px;
  border-radius: 50%;
  box-shadow:
    13px -5px 0 currentColor,
    27px 0 0 currentColor,
    34px 14px 0 currentColor;
  transform: rotate(10deg);
}

.paw-one {
  left: 16%;
  top: 62%;
  --paw-r: 18deg;
  animation-delay: 0s;
}

.paw-two {
  left: 31%;
  top: 72%;
  --paw-r: -34deg;
  --paw-s: .92;
  animation-delay: .55s;
}

.paw-three {
  left: 42%;
  top: 42%;
  --paw-r: 27deg;
  animation-delay: 1.1s;
}

.paw-four {
  left: 54%;
  top: 57%;
  --paw-r: -18deg;
  --paw-s: .95;
  animation-delay: 1.65s;
}

.paw-five {
  left: 66%;
  top: 34%;
  --paw-r: 36deg;
  animation-delay: 2.2s;
}

.paw-six {
  left: 73%;
  top: 66%;
  --paw-r: -42deg;
  --paw-s: .9;
  animation-delay: 2.75s;
}

.paw-seven {
  left: 82%;
  top: 25%;
  --paw-r: 12deg;
  animation-delay: 3.3s;
}

.paw-eight {
  left: 12%;
  top: 35%;
  --paw-r: -16deg;
  --paw-s: .86;
  animation-delay: 3.85s;
}

.paw-nine {
  left: 24%;
  top: 48%;
  --paw-r: 42deg;
  --paw-s: .94;
  animation-delay: 4.4s;
}

.paw-ten {
  left: 35%;
  top: 24%;
  --paw-r: -36deg;
  --paw-s: .88;
  animation-delay: 4.95s;
}

.paw-eleven {
  left: 49%;
  top: 76%;
  --paw-r: 24deg;
  animation-delay: 5.5s;
}

.paw-twelve {
  left: 61%;
  top: 21%;
  --paw-r: -12deg;
  --paw-s: .9;
  animation-delay: 6.05s;
}

.paw-thirteen {
  left: 70%;
  top: 49%;
  --paw-r: 47deg;
  --paw-s: .96;
  animation-delay: 6.6s;
}

.paw-fourteen {
  left: 78%;
  top: 77%;
  --paw-r: -28deg;
  --paw-s: .88;
  animation-delay: 7.15s;
}

.paw-fifteen {
  left: 88%;
  top: 45%;
  --paw-r: 18deg;
  --paw-s: .82;
  animation-delay: 7.7s;
}

.paw-sixteen {
  left: 6%;
  top: 78%;
  --paw-r: 33deg;
  --paw-s: .78;
  animation-delay: 8.25s;
}

.paw-top-one {
  left: 39%;
  top: 36%;
  --paw-r: -20deg;
  --paw-s: .72;
  animation-delay: 1.35s;
}

.paw-top-two {
  left: 49%;
  top: 43%;
  --paw-r: 18deg;
  --paw-s: .68;
  animation-delay: 2.05s;
}

.paw-top-three {
  left: 56%;
  top: 52%;
  --paw-r: -12deg;
  --paw-s: .74;
  animation-delay: 2.75s;
}

.paw-top-four {
  left: 46%;
  top: 61%;
  --paw-r: 31deg;
  --paw-s: .66;
  animation-delay: 3.45s;
}

.paw-top-five {
  left: 62%;
  top: 32%;
  --paw-r: -34deg;
  --paw-s: .62;
  animation-delay: 4.15s;
}

.about-canvas:has(.paw-trail) .about-book {
  animation: pawBookNudge 8.8s ease-in-out infinite;
}

.about-canvas:has(.paw-trail) .about-wireframe,
.about-canvas:has(.paw-trail) .about-browser {
  animation: pawPaperNudge 8.8s ease-in-out infinite;
}

@keyframes aboutBob {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -8px; }
}

@keyframes pawStep {
  0%, 7% {
    opacity: 0;
    translate: 0 4px;
  }
  10%, 32% {
    opacity: .78;
    translate: 0 0;
  }
  44%, 100% {
    opacity: 0;
    translate: 0 -2px;
  }
}

@keyframes pawBookNudge {
  0%, 35%, 48%, 100% {
    rotate: 0deg;
  }
  40% {
    rotate: -.35deg;
  }
}

@keyframes pawPaperNudge {
  0%, 18%, 30%, 100% {
    translate: 0 0;
  }
  23% {
    translate: 1px -2px;
  }
}

@keyframes loveTyping {
  from { width: 0; }
  to { width: 17ch; }
}

@keyframes loveCaret {
  50% { border-color: transparent; }
}

@keyframes loveLine {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.tape {
  position: absolute;
  top: -13px;
  width: 76px;
  height: 23px;
  border: 1px solid rgba(15,15,13,.06);
  border-radius: 4px;
  background: rgba(255,255,255,.46);
  box-shadow: 0 8px 18px rgba(39,31,21,.08);
  backdrop-filter: blur(3px);
}
.tape-left {
  left: 32px;
  transform: rotate(-8deg);
}
.tape-right {
  right: 34px;
  transform: rotate(7deg);
}

.section-heading p {
  margin: 0 0 .7rem;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 12px;
  text-transform: uppercase;
}

.section-heading h2 {
  margin: 0;
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(2.4rem, 5vw, 5rem);
  line-height: .96;
}

@keyframes paperDrift {
  0%, 100% { margin-top: 0; }
  50% { margin-top: -8px; }
}

.tabs {
  position: sticky;
  top: 62px;
  z-index: 30;
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  padding: .55rem;
  margin-bottom: 2rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(241,234,217,.76);
}
.tabs button {
  border: 0;
  border-radius: 999px;
  padding: .72rem 1rem;
  background: transparent;
  font: 12px var(--mono);
  cursor: pointer;
}
.tabs button.active { background: var(--black); color: var(--white); }

.section-heading {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 1rem;
  margin-bottom: 1.4rem;
}
.project-board {
  position: relative;
  padding: clamp(1.2rem, 2vw, 2rem) 0;
  overflow: visible;
  isolation: isolate;
}
.board-top {
  position: relative;
  z-index: 3;
  max-width: 44rem;
  margin-bottom: 1.5rem;
}
.board-top span,
.board-top p {
  display: block;
  margin: 0 0 .7rem;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 12px;
  text-transform: uppercase;
}
.board-top h3 {
  margin: 0 0 1rem;
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(2.4rem, 5vw, 5rem);
  line-height: .95;
}
.board-top p {
  text-transform: none;
  max-width: 34rem;
  color: rgba(15,15,13,.7);
}
.board-canvas {
  position: relative;
  min-height: clamp(640px, 66vw, 790px);
  overflow: hidden;
  border: 1px solid rgba(92,50,32,.14);
  border-radius: 28px 34px 31px 26px;
  background-color: rgba(232,211,184,.9);
  background-image:
    radial-gradient(ellipse at 78% 11%, rgba(255,226,167,.58), transparent 34%),
    radial-gradient(ellipse at 11% 78%, rgba(104,31,45,.17), transparent 31%),
    radial-gradient(ellipse at 54% 49%, rgba(255,246,226,.34), transparent 44%),
    radial-gradient(ellipse at 86% 84%, rgba(42,23,18,.18), transparent 38%),
    repeating-linear-gradient(2deg, rgba(255,255,255,.06) 0 1px, transparent 1px 8px),
    radial-gradient(circle, rgba(42,23,18,.06) .58px, transparent .9px),
    linear-gradient(180deg, rgba(248,235,211,.72), rgba(213,184,154,.58));
  background-size: auto, auto, auto, auto, 210px 210px, 15px 15px, auto;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.5), inset 0 -42px 100px rgba(104,31,45,.07), 0 34px 90px rgba(42,23,18,.16);
}
.board-canvas::before,
.board-canvas::after {
  content: "";
  position: absolute;
  pointer-events: none;
}
.board-canvas::before {
  content: none;
}
.board-canvas::after {
  inset: 0;
  z-index: 2;
  width: auto;
  height: auto;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.05) 0 1px, transparent 1px 5px),
    radial-gradient(circle, rgba(42,23,18,.045) .55px, transparent .8px);
  background-size: auto, 12px 12px;
  opacity: .5;
  transform: none;
  mix-blend-mode: multiply;
}

.archive-glow,
.archive-grain,
.archive-dust,
.archive-coffee,
.archive-tape,
.archive-doodle {
  position: absolute;
  pointer-events: none;
  user-select: none;
}

.archive-glow {
  right: -11%;
  top: -16%;
  z-index: 0;
  width: 520px;
  max-width: 62vw;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,226,167,.62), transparent 68%);
  animation: desktopGlowBreathe 12s ease-in-out infinite;
}

.archive-grain {
  inset: 0;
  z-index: 0;
  opacity: .2;
  background:
    radial-gradient(circle, rgba(42,23,18,.08) .65px, transparent .9px),
    linear-gradient(90deg, rgba(42,23,18,.03) 1px, transparent 1px),
    linear-gradient(180deg, rgba(42,23,18,.025) 1px, transparent 1px);
  background-size: 13px 13px, 70px 70px, 70px 70px;
}

.workspace-thoughts {
  position: absolute;
  right: clamp(2rem, 7vw, 6.6rem);
  bottom: min(300px, 42vw);
  z-index: 3;
  width: min(510px, 43vw);
  height: min(300px, 31vw);
  pointer-events: none;
  user-select: none;
}

.thought-window,
.thought-particle {
  position: absolute;
  pointer-events: none;
  user-select: none;
}

.thought-window {
  display: grid;
  gap: .18rem;
  min-width: 132px;
  padding: .62rem .72rem;
  border: 1px solid rgba(92,50,32,.12);
  border-radius: 13px 11px 14px 9px;
  background:
    linear-gradient(115deg, rgba(255,255,255,.2), transparent 44%),
    radial-gradient(circle, rgba(42,23,18,.045) .5px, transparent .85px),
    rgba(255,246,226,.66);
  background-size: auto, 12px 12px, auto;
  box-shadow: 0 20px 42px rgba(42,23,18,.12), inset 0 1px 0 rgba(255,255,255,.48);
  color: rgba(42,23,18,.6);
  backdrop-filter: blur(10px) saturate(1.05);
  opacity: .88;
  animation: thoughtDrift var(--thought-speed, 8s) ease-in-out infinite;
  animation-delay: var(--thought-delay, 0s);
  transform: translate3d(0, 0, 0) rotate(var(--thought-r, 0deg));
}

.thought-window::before {
  content: "";
  position: absolute;
  left: .58rem;
  top: .44rem;
  width: 28px;
  height: 7px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(104,31,45,.56), rgba(214,168,95,.58));
  opacity: .62;
}

.thought-window b {
  margin-top: .34rem;
  color: rgba(104,31,45,.72);
  font: 700 1.02rem var(--hand);
  line-height: .9;
}

.thought-window small {
  color: rgba(42,23,18,.52);
  font: 10px var(--mono);
  line-height: 1.1;
}

.thought-window i {
  display: block;
  height: 8px;
  overflow: hidden;
  border: 1px solid rgba(92,50,32,.13);
  border-radius: 999px;
  background: rgba(42,23,18,.07);
}

.thought-window i em {
  display: block;
  width: 64%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(104,31,45,.58), rgba(214,168,95,.58));
  animation: thoughtLoad 5.8s ease-in-out infinite;
}

.thought-window > em {
  display: block;
  height: 12px;
  margin: -.1rem 0 .08rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(104,31,45,.58) 0 11px, rgba(214,168,95,.58) 11px 25px, rgba(139,143,95,.5) 25px 38px, transparent 38px);
}

.thought-window-tabs {
  left: 4%;
  top: 8%;
  --thought-r: -4deg;
  --thought-speed: 9s;
}

.thought-window-mode {
  right: 6%;
  top: 0;
  --thought-r: 3deg;
  --thought-delay: -2s;
}

.thought-window-save {
  left: 22%;
  bottom: 10%;
  --thought-r: 2deg;
  --thought-speed: 7.8s;
  --thought-delay: -4s;
}

.thought-window-energy {
  right: 0;
  bottom: 22%;
  --thought-r: -3deg;
  --thought-speed: 8.7s;
  --thought-delay: -1s;
}

.thought-particle {
  width: 7px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(255,226,167,.78);
  box-shadow:
    0 0 24px rgba(255,226,167,.38),
    34px 18px 0 rgba(104,31,45,.16),
    -22px 42px 0 rgba(255,246,226,.46);
  opacity: .72;
  animation: thoughtParticle 7s ease-in-out infinite;
}

.thought-particle-one {
  left: 12%;
  bottom: 18%;
}

.thought-particle-two {
  right: 28%;
  top: 26%;
  animation-delay: -2.4s;
}

.work-comp-preview {
  position: absolute;
  right: clamp(2.4rem, 8vw, 7rem);
  bottom: 0;
  z-index: 4;
  width: min(455px, 39vw);
  max-height: 70%;
  object-fit: contain;
  pointer-events: none;
  user-select: none;
  filter: drop-shadow(0 28px 52px rgba(42,23,18,.18)) sepia(.08) saturate(.92);
  transform: rotate(1deg);
}

.work-comp-paws {
  position: absolute;
  right: clamp(2.8rem, 8.5vw, 7.4rem);
  bottom: 0;
  z-index: 6;
  width: min(455px, 39vw);
  height: min(420px, 58vw);
  pointer-events: none;
  user-select: none;
  transform: rotate(1deg);
}

.work-comp-paws .desktop-paw {
  position: absolute;
  color: rgba(104,31,45,.28);
  opacity: .72;
  animation: none;
}

.work-paw-one {
  left: 17%;
  top: 16%;
  --paw-r: -18deg;
  --paw-s: .68;
}

.work-paw-two {
  left: 29%;
  top: 25%;
  --paw-r: 22deg;
  --paw-s: .62;
}

.work-paw-three {
  left: 63%;
  top: 58%;
  --paw-r: -12deg;
  --paw-s: .58;
}

.work-paw-four {
  left: 75%;
  top: 68%;
  --paw-r: 24deg;
  --paw-s: .52;
}

.work-folder-cat {
  position: absolute;
  left: 43%;
  bottom: 1.2rem;
  z-index: 7;
  width: min(178px, 18vw);
  pointer-events: none;
  user-select: none;
  filter: drop-shadow(0 18px 28px rgba(42,23,18,.18)) sepia(.08) saturate(.9);
  transform: rotate(-3deg);
}

.memory-os-bar {
  position: absolute;
  left: 1rem;
  right: auto;
  top: 1rem;
  z-index: 10;
  display: flex;
  align-items: center;
  gap: .82rem;
  min-height: 34px;
  padding: .38rem .72rem;
  border: 1px solid rgba(92,50,32,.12);
  border-radius: 14px 12px 16px 11px;
  background:
    linear-gradient(115deg, rgba(255,255,255,.2), transparent 44%),
    rgba(245,230,205,.72);
  box-shadow: 0 18px 42px rgba(42,23,18,.1), inset 0 1px 0 rgba(255,255,255,.52);
  color: rgba(42,23,18,.56);
  font: 10px var(--mono);
  text-transform: lowercase;
  pointer-events: none;
  user-select: none;
  transform: rotate(-.25deg);
}

.memory-os-bar span {
  white-space: nowrap;
}

.memory-os-bar .memory-os-name {
  padding-right: .2rem;
  color: rgba(104,31,45,.78);
  font-weight: 500;
}

.memory-os-bar b {
  margin-left: .4rem;
  color: rgba(104,31,45,.52);
  font: 700 .94rem var(--hand);
  white-space: nowrap;
}

.hidden-memory-title {
  position: absolute;
  left: 38%;
  top: 10%;
  z-index: 7;
  display: grid;
  gap: .1rem;
  color: rgba(104,31,45,.68);
  pointer-events: none;
  user-select: none;
  transform: rotate(-2deg);
}

.hidden-memory-title span {
  max-width: 9ch;
  font: 400 clamp(2.1rem, 4.2vw, 4.5rem) var(--play);
  line-height: .72;
}

.hidden-memory-title b {
  margin-left: .9rem;
  color: rgba(42,23,18,.48);
  font: 700 1.05rem var(--hand);
  line-height: .9;
}

.memory-fragments,
.memory-set,
.memory-fragment,
.memory-particle {
  position: absolute;
  pointer-events: none;
  user-select: none;
}

.memory-fragments {
  inset: 0;
  z-index: 6;
}

.memory-set {
  inset: 0;
}

.memory-fragment {
  display: grid;
  align-content: center;
  min-width: 92px;
  min-height: 58px;
  padding: .7rem .76rem;
  border: 1px solid rgba(92,50,32,.13);
  border-radius: 9px 11px 8px 10px;
  background:
    radial-gradient(circle, rgba(42,23,18,.045) .5px, transparent .85px),
    linear-gradient(145deg, rgba(255,248,225,.86), rgba(224,199,170,.72));
  background-size: 12px 12px, auto;
  box-shadow: 0 18px 38px rgba(42,23,18,.13), inset 0 1px 0 rgba(255,255,255,.42);
  color: rgba(42,23,18,.62);
  font: 700 1.02rem var(--hand);
  line-height: .9;
  opacity: 0;
  filter: blur(1.5px) saturate(.84);
  transform: translate3d(0, 12px, 0) rotate(var(--memory-r, 0deg)) scale(.94);
  transition: opacity .8s ease, filter .8s ease, transform .9s cubic-bezier(.2,.8,.2,1);
}

.memory-fragment b,
.memory-fragment small {
  display: block;
  font-weight: 700;
  line-height: .9;
}

.memory-fragment small {
  margin-top: .28rem;
  color: rgba(42,23,18,.45);
  font-size: .84rem;
}

.memory-fragment::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -10px;
  width: 54px;
  height: 17px;
  border-radius: 4px;
  background: rgba(255,255,255,.4);
  box-shadow: 0 8px 18px rgba(42,23,18,.06);
  transform: translateX(-50%) rotate(var(--tape-r, -4deg));
}

.memory-particle {
  width: 7px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(255,226,167,.74);
  box-shadow: 0 0 24px rgba(255,226,167,.42), 22px 16px 0 rgba(104,31,45,.16), -18px 28px 0 rgba(255,246,226,.44);
  opacity: 0;
  transform: translateY(12px) scale(.6);
  transition: opacity .9s ease, transform 1s ease;
}

.board-canvas[data-active-memory="sproot"] .memory-sproot .memory-fragment,
.board-canvas.memory-sproot-discovered .memory-sproot .memory-fragment,
.board-canvas[data-active-memory="icrush"] .memory-icrush .memory-fragment,
.board-canvas.memory-icrush-discovered .memory-icrush .memory-fragment,
.board-canvas[data-active-memory="de-soi"] .memory-de-soi .memory-fragment,
.board-canvas.memory-de-soi-discovered .memory-de-soi .memory-fragment,
.board-canvas[data-active-memory="vaultwin"] .memory-vaultwin .memory-fragment,
.board-canvas.memory-vaultwin-discovered .memory-vaultwin .memory-fragment {
  opacity: .96;
  filter: blur(0) saturate(1);
  transform: translate3d(0, 0, 0) rotate(var(--memory-r, 0deg)) scale(1);
}

.board-canvas[data-active-memory="sproot"] .memory-sproot .memory-particle,
.board-canvas.memory-sproot-discovered .memory-sproot .memory-particle,
.board-canvas[data-active-memory="icrush"] .memory-icrush .memory-particle,
.board-canvas.memory-icrush-discovered .memory-icrush .memory-particle,
.board-canvas[data-active-memory="de-soi"] .memory-de-soi .memory-particle,
.board-canvas.memory-de-soi-discovered .memory-de-soi .memory-particle,
.board-canvas[data-active-memory="vaultwin"] .memory-vaultwin .memory-particle,
.board-canvas.memory-vaultwin-discovered .memory-vaultwin .memory-particle {
  opacity: 1;
  transform: translateY(0) scale(1);
  animation: memoryFloat 6.5s ease-in-out infinite;
}

.memory-set .memory-fragment:nth-child(2) { transition-delay: .08s; }
.memory-set .memory-fragment:nth-child(3) { transition-delay: .16s; }

.memory-sproot .scrap-one { left: 39%; top: 22%; --memory-r: -7deg; --tape-r: 7deg; }
.memory-sproot .scrap-two { left: 61%; top: 34%; --memory-r: 4deg; }
.memory-sproot .scrap-three { left: 48%; top: 64%; --memory-r: -2deg; }
.memory-sproot .particle-one { left: 55%; top: 25%; }
.memory-sproot .particle-two { left: 72%; top: 57%; animation-delay: -2s; }

.newspaper {
  width: 130px;
  min-height: 86px;
  border-radius: 4px;
  background:
    repeating-linear-gradient(0deg, rgba(42,23,18,.18) 0 1px, transparent 1px 7px),
    linear-gradient(145deg, rgba(246,239,221,.92), rgba(206,195,175,.76));
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
}

.graph-scrap {
  width: 126px;
  min-height: 82px;
  background:
    linear-gradient(90deg, rgba(42,23,18,.06) 1px, transparent 1px),
    linear-gradient(180deg, rgba(42,23,18,.06) 1px, transparent 1px),
    rgba(242,229,203,.86);
  background-size: 18px 18px, 18px 18px, auto;
}

.graph-scrap i {
  display: inline-block;
  width: 10px;
  height: 24px;
  margin-right: 5px;
  border-radius: 5px 5px 2px 2px;
  background: rgba(104,31,45,.45);
  vertical-align: bottom;
}

.graph-scrap i:nth-child(2) { height: 38px; background: rgba(139,143,95,.52); }
.graph-scrap i:nth-child(3) { height: 18px; background: rgba(42,23,18,.32); }

.browser-scrap {
  width: 160px;
  min-height: 88px;
  border-radius: 12px;
}

.browser-scrap em,
.pixel-window em,
.dark-window em {
  display: block;
  height: 12px;
  margin: -.24rem -.32rem .45rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(104,31,45,.62) 0 10px, rgba(214,168,95,.7) 10px 24px, rgba(139,143,95,.58) 24px 38px, transparent 38px);
}

.memory-icrush .sticker-one { left: 42%; top: 39%; --memory-r: 8deg; }
.memory-icrush .sticker-two { left: 62%; top: 18%; --memory-r: -4deg; }
.memory-icrush .sticker-three { left: 67%; top: 61%; --memory-r: 3deg; }
.memory-icrush .particle-one { left: 54%; top: 45%; background: rgba(214,165,167,.82); }
.memory-icrush .particle-two { left: 78%; top: 31%; background: rgba(255,226,167,.82); animation-delay: -1.5s; }

.pixel-sticker {
  min-width: 88px;
  min-height: 52px;
  border-radius: 4px;
  background: rgba(54,34,48,.86);
  color: rgba(255,226,167,.94);
  box-shadow: 0 0 28px rgba(214,165,167,.24), 0 18px 38px rgba(42,23,18,.18);
  font-family: var(--mono);
  font-size: 12px;
  text-transform: uppercase;
}

.arcade-note {
  background:
    linear-gradient(145deg, rgba(255,226,167,.8), rgba(183,111,118,.68)),
    radial-gradient(circle at 80% 16%, rgba(255,255,255,.32), transparent 24%);
}

.pixel-window {
  width: 156px;
  background: rgba(255,246,226,.82);
  box-shadow: 0 0 30px rgba(214,165,167,.2), 0 18px 38px rgba(42,23,18,.12);
}

.memory-de-soi .de-one { left: 40%; top: 24%; --memory-r: -4deg; }
.memory-de-soi .de-two { left: 64%; top: 43%; --memory-r: 6deg; }
.memory-de-soi .de-three { left: 50%; top: 68%; --memory-r: -6deg; }
.memory-de-soi .particle-one { left: 56%; top: 38%; background: rgba(255,226,167,.76); }
.memory-de-soi .particle-two { left: 75%; top: 66%; background: rgba(214,165,167,.48); animation-delay: -2.4s; }

.perfume-card {
  width: 118px;
  min-height: 138px;
  place-items: center;
  text-align: center;
  background:
    radial-gradient(ellipse at 50% 20%, rgba(255,226,167,.34), transparent 34%),
    linear-gradient(145deg, rgba(255,240,216,.9), rgba(216,181,166,.74));
}

.flower-card {
  width: 116px;
  min-height: 104px;
  color: rgba(104,31,45,.62);
}

.flower-card i {
  width: 38px;
  aspect-ratio: 1;
  margin: 0 auto .24rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(104,31,45,.52) 0 18%, rgba(214,165,167,.58) 20% 42%, transparent 43%);
  box-shadow: 15px 4px 0 rgba(214,165,167,.34), -12px 8px 0 rgba(139,143,95,.28);
}

.film-note {
  width: 146px;
  background:
    linear-gradient(90deg, rgba(42,23,18,.14) 0 8px, transparent 8px calc(100% - 8px), rgba(42,23,18,.14) calc(100% - 8px)),
    linear-gradient(145deg, rgba(94,49,41,.78), rgba(218,172,127,.74));
  color: rgba(255,246,226,.9);
}

.memory-vaultwin .vault-one { left: 42%; top: 18%; --memory-r: 3deg; }
.memory-vaultwin .vault-two { left: 69%; top: 36%; --memory-r: -5deg; }
.memory-vaultwin .vault-three { left: 53%; top: 68%; --memory-r: 5deg; }
.memory-vaultwin .particle-one { left: 58%; top: 28%; background: rgba(174,178,208,.78); }
.memory-vaultwin .particle-two { left: 78%; top: 58%; background: rgba(255,246,226,.54); animation-delay: -1.8s; }

.holo-note,
.archive-chip,
.dark-window {
  border-color: rgba(255,246,226,.16);
  background:
    linear-gradient(135deg, rgba(255,255,255,.16), transparent 42%),
    linear-gradient(145deg, rgba(63,49,70,.88), rgba(42,23,18,.9));
  color: rgba(255,246,226,.84);
  box-shadow: 0 0 34px rgba(174,178,208,.14), 0 22px 46px rgba(42,23,18,.2);
}

.holo-note {
  width: 148px;
  min-height: 86px;
}

.archive-chip {
  width: 128px;
  min-height: 74px;
}

.archive-chip i {
  display: block;
  width: 52px;
  height: 22px;
  margin-bottom: .34rem;
  border: 1px solid rgba(255,246,226,.2);
  border-radius: 7px;
  background: repeating-linear-gradient(90deg, rgba(174,178,208,.28) 0 3px, transparent 3px 7px);
}

.dark-window {
  width: 158px;
  min-height: 94px;
}

.creative-status-widget {
  position: absolute;
  right: clamp(2.1rem, 7vw, 6rem);
  top: 18%;
  z-index: 9;
  width: min(245px, 28vw);
  overflow: visible;
  border: 1px solid rgba(92,50,32,.12);
  border-radius: 10px 13px 11px 9px;
  background:
    repeating-linear-gradient(0deg, transparent 0 25px, rgba(92,50,32,.08) 26px, transparent 27px),
    radial-gradient(circle at 82% 18%, rgba(255,226,167,.28), transparent 34%),
    linear-gradient(145deg, rgba(255,246,219,.92), rgba(230,207,174,.82));
  background-size: auto, auto, auto;
  box-shadow: 0 22px 50px rgba(42,23,18,.16), inset 0 1px 0 rgba(255,255,255,.45);
  transform: rotate(-3.5deg);
}

.creative-status-widget::before,
.creative-status-widget::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.creative-status-widget::before {
  left: 50%;
  top: -15px;
  z-index: 2;
  width: 88px;
  height: 28px;
  border: 1px solid rgba(92,50,32,.06);
  border-radius: 4px;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0 5px, transparent 5px 10px),
    rgba(255,255,255,.44);
  box-shadow: 0 10px 18px rgba(42,23,18,.08);
  transform: translateX(-50%) rotate(5deg);
}

.creative-status-widget::after {
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(112deg, rgba(255,255,255,.24), transparent 36%),
    radial-gradient(circle, rgba(42,23,18,.055) .5px, transparent .85px);
  background-size: auto, 12px 12px;
  mix-blend-mode: multiply;
  opacity: .72;
}

.status-widget-bar,
.status-widget-body {
  position: relative;
  z-index: 1;
}

.status-widget-bar {
  display: flex;
  align-items: center;
  gap: .42rem;
  padding: .8rem .95rem;
  border-bottom: 1px solid rgba(42,23,18,.1);
  background: rgba(251,242,223,.48);
}

.status-widget-bar span {
  width: 10px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(104,31,45,.72);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
}

.status-widget-bar span:nth-child(2) { background: rgba(214,168,95,.86); }
.status-widget-bar span:nth-child(3) { background: rgba(139,143,95,.74); }

.status-widget-bar i {
  margin-left: auto;
  color: rgba(42,23,18,.48);
  font: 10px var(--mono);
  font-style: normal;
}

.status-widget-body {
  display: grid;
  gap: .55rem;
  padding: 1.25rem 1rem 1rem;
}

.status-handwritten {
  margin: 0;
  color: rgba(104,31,45,.72);
  font: 700 1.2rem var(--hand);
  line-height: .92;
  transform: rotate(1deg);
}

.status-meter {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .45rem .7rem;
  padding: .82rem;
  border: 1px solid rgba(42,23,18,.1);
  border-radius: 16px;
  background: rgba(255,250,237,.62);
  box-shadow: 0 16px 34px rgba(42,23,18,.08);
}

.status-meter span,
.status-list span,
.status-inspired span,
.status-indicators b {
  color: rgba(42,23,18,.58);
  font: 10px var(--mono);
  text-transform: lowercase;
}

.status-meter b {
  color: rgba(104,31,45,.8);
  font: 700 1.05rem var(--hand);
}

.status-meter i {
  grid-column: 1 / -1;
  display: block;
  height: 9px;
  overflow: hidden;
  border: 1px solid rgba(42,23,18,.12);
  border-radius: 999px;
  background: rgba(42,23,18,.08);
}

.status-meter em {
  display: block;
  width: 82%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(104,31,45,.72), rgba(214,168,95,.72));
  animation: desktopLoadPulse 5.2s ease-in-out infinite;
}

.status-list {
  display: grid;
  gap: .22rem;
  margin: 0;
  padding: .2rem 0 0 1rem;
  list-style: none;
}

.status-list li {
  position: relative;
  padding: 0 0 0 .1rem;
  background: transparent;
}

.status-list li::before {
  content: "";
  position: absolute;
  left: -.74rem;
  top: .44rem;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(104,31,45,.42);
}

.status-list b {
  color: rgba(104,31,45,.72);
  font: 700 1rem var(--hand);
  line-height: .92;
  text-align: right;
}

.status-list span {
  color: rgba(42,23,18,.62);
  font: 700 1rem var(--hand);
  line-height: .95;
  text-transform: none;
}

.status-inspired {
  margin: .3rem 0 0;
  padding-top: .5rem;
  border-top: 1px dashed rgba(92,50,32,.18);
  background: transparent;
  color: rgba(42,23,18,.58);
  font: 700 1.02rem var(--hand);
  line-height: .95;
  transform: rotate(-1deg);
}

.status-indicators {
  display: flex;
  align-items: center;
  gap: .36rem;
  padding: .55rem .65rem;
  border-radius: 999px;
  background: rgba(42,23,18,.72);
  color: rgba(255,246,226,.92);
}

.status-indicators span {
  width: 7px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(255,246,226,.88);
  animation: statusDotBlink 1.6s ease-in-out infinite;
}

.status-indicators span:nth-child(2) { animation-delay: .2s; opacity: .72; }
.status-indicators span:nth-child(3) { animation-delay: .4s; opacity: .54; }

.status-indicators b {
  margin-left: .25rem;
  color: rgba(255,246,226,.78);
  text-transform: none;
}

.archive-dust {
  z-index: 3;
  width: 7px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(255,244,211,.55);
  box-shadow: 32px 18px 0 rgba(255,244,211,.34), -20px 48px 0 rgba(104,31,45,.12), 68px -26px 0 rgba(42,23,18,.1);
  animation: desktopDustDrift 11s ease-in-out infinite;
}
.dust-a { left: 17%; top: 21%; }
.dust-b { right: 19%; top: 55%; animation-delay: -4s; }

.desktop-paws,
.desktop-paw {
  position: absolute;
  pointer-events: none;
  user-select: none;
}

.desktop-paws {
  inset: 0;
  z-index: 4;
}

.desktop-paw {
  width: 31px;
  height: 28px;
  color: rgba(104,31,45,.28);
  opacity: 0;
  filter: drop-shadow(0 3px 5px rgba(42,23,18,.06));
  transform: rotate(var(--paw-r, -12deg)) scale(var(--paw-s, 1));
  animation: desktopPawAppear 13s ease-in-out infinite;
}

.desktop-paw::before,
.desktop-paw::after {
  content: "";
  position: absolute;
  background: currentColor;
}

.desktop-paw::before {
  left: 9px;
  top: 13px;
  width: 14px;
  height: 11px;
  border-radius: 48% 52% 54% 46%;
}

.desktop-paw::after {
  left: 3px;
  top: 1px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  box-shadow:
    8px -3px 0 currentColor,
    17px 0 0 currentColor,
    22px 9px 0 currentColor;
}

.paw-a {
  left: 70%;
  top: 63%;
  --paw-r: 18deg;
  animation-delay: -1s;
}

.paw-b {
  left: 74%;
  top: 67%;
  --paw-r: -16deg;
  --paw-s: .88;
  animation-delay: .6s;
}

.paw-c {
  left: 78%;
  top: 71%;
  --paw-r: 21deg;
  --paw-s: .82;
  animation-delay: 2.1s;
}

.archive-coffee {
  z-index: 2;
  width: 116px;
  aspect-ratio: 1.16;
  border: 11px solid rgba(92,50,32,.12);
  border-radius: 48% 52% 45% 55%;
}
.coffee-a { left: 38%; bottom: 8%; transform: rotate(-18deg); }
.coffee-b { right: 8%; top: 17%; width: 78px; transform: rotate(16deg); }

.archive-tape {
  z-index: 8;
  width: 108px;
  height: 25px;
  border: 1px solid rgba(42,23,18,.06);
  border-radius: 5px;
  background: rgba(255,255,255,.42);
  box-shadow: 0 9px 20px rgba(42,23,18,.08);
}
.tape-a { left: 42%; top: 18%; transform: rotate(-11deg); }
.tape-b { right: 22%; bottom: 31%; transform: rotate(9deg); }

.archive-doodle {
  z-index: 9;
  color: rgba(104,31,45,.66);
  font-family: var(--hand);
  font-weight: 700;
  filter: drop-shadow(0 8px 12px rgba(42,23,18,.08));
}
.archive-heart { left: 43%; top: 45%; font-size: 2.1rem; transform: rotate(-11deg); }
.archive-star { right: 21%; top: 21%; font-size: 1.8rem; color: rgba(139,143,95,.7); }
.archive-arrow { right: 17%; bottom: 22%; font-size: 1.15rem; transform: rotate(-7deg); }
.desktop-memory {
  position: absolute;
  z-index: 4;
  max-width: 15ch;
  color: rgba(42,23,18,.44);
  font: 700 1.05rem var(--hand);
  line-height: .95;
  pointer-events: none;
  user-select: none;
  filter: drop-shadow(0 8px 12px rgba(42,23,18,.06));
}
.memory-one {
  left: 34%;
  top: 22%;
  transform: rotate(-5deg);
}
.memory-two {
  left: 58%;
  top: 77%;
  color: rgba(104,31,45,.48);
  transform: rotate(4deg);
}
.memory-three {
  left: 36%;
  top: 84%;
  color: rgba(139,143,95,.58);
  transform: rotate(-7deg);
}

.memory-status-strip {
  position: absolute;
  right: 4%;
  bottom: 4%;
  z-index: 7;
  max-width: 32ch;
  padding: .5rem .68rem;
  border: 1px dashed rgba(92,50,32,.16);
  border-radius: 999px;
  background: rgba(255,246,226,.42);
  color: rgba(42,23,18,.52);
  box-shadow: 0 14px 30px rgba(42,23,18,.08);
  font: 700 .98rem var(--hand);
  line-height: .9;
  pointer-events: none;
  user-select: none;
  transform: rotate(1.5deg);
}

.midnight-popup {
  left: 69%;
  top: 31%;
  transform: rotate(2deg);
}

.desktop-music-widget {
  right: 8%;
  bottom: 13%;
}
.desktop-cursor,
.desktop-file,
.desktop-popup,
.desktop-caty-gif,
.desktop-heart-sticker,
.desktop-star-sticker,
.desktop-music-widget,
.desktop-sticky-note {
  position: absolute;
  z-index: 7;
  pointer-events: none;
  user-select: none;
}

.desktop-cursor {
  left: 57%;
  top: 28%;
  width: 2px;
  height: 24px;
  border-radius: 999px;
  background: rgba(104,31,45,.58);
  box-shadow: 0 0 14px rgba(104,31,45,.16);
  animation: desktopCursorBlink 1.35s steps(1, end) infinite;
}

.desktop-file {
  display: grid;
  justify-items: center;
  gap: .32rem;
  width: 92px;
  color: rgba(42,23,18,.64);
  font: 10px var(--mono);
  text-align: center;
  line-height: 1.15;
  filter: drop-shadow(0 9px 14px rgba(42,23,18,.08));
}

.desktop-file i {
  position: relative;
  display: block;
  width: 38px;
  height: 48px;
  border: 1px solid rgba(42,23,18,.13);
  border-radius: 4px;
  background: linear-gradient(145deg, rgba(255,250,237,.96), rgba(234,216,188,.9));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.65), 0 12px 22px rgba(42,23,18,.08);
}

.desktop-file i::before {
  content: "";
  position: absolute;
  right: -1px;
  top: -1px;
  width: 13px;
  height: 13px;
  border-left: 1px solid rgba(42,23,18,.1);
  border-bottom: 1px solid rgba(42,23,18,.1);
  border-radius: 0 4px 0 3px;
  background: rgba(255,255,255,.52);
}

.desktop-file i::after {
  content: "";
  position: absolute;
  left: 9px;
  top: 22px;
  width: 19px;
  height: 2px;
  border-radius: 999px;
  background: rgba(104,31,45,.24);
  box-shadow: 0 7px 0 rgba(42,23,18,.12), 0 14px 0 rgba(139,143,95,.18);
}

.file-thoughts { left: 34%; top: 36%; transform: rotate(4deg); }
.file-psd { left: 80%; top: 50%; transform: rotate(-5deg); }
.file-sketch { left: 45%; top: 72%; transform: rotate(3deg); }

.desktop-popup {
  display: grid;
  gap: .18rem;
  min-width: 148px;
  padding: .72rem .82rem;
  border: 1px solid rgba(255,255,255,.52);
  border-radius: 12px;
  background: rgba(255,250,237,.64);
  color: rgba(42,23,18,.64);
  box-shadow: 0 18px 44px rgba(42,23,18,.12);
  backdrop-filter: blur(16px) saturate(1.12);
  animation: desktopSavedToast 9s ease-in-out infinite;
}

.desktop-popup b {
  color: rgba(104,31,45,.72);
  font: 700 1.02rem var(--hand);
  line-height: .9;
}

.desktop-popup span {
  font: 10px var(--mono);
}

.popup-one { right: 8%; top: 8%; }

.desktop-caty-gif {
  left: 56%;
  top: 44%;
  z-index: 8;
  width: min(280px, 26vw);
  filter: drop-shadow(0 18px 26px rgba(42,23,18,.16));
  transform: translate(-50%, -50%) rotate(2deg);
}

.desktop-heart-sticker {
  left: 84%;
  top: 40%;
  color: rgba(104,31,45,.66);
  font: 700 2rem var(--hand);
  transform: rotate(11deg);
}

.desktop-star-sticker {
  color: rgba(139,143,95,.72);
  font: 700 1.35rem var(--hand);
}

.star-one { left: 38%; top: 74%; transform: rotate(-8deg); }
.star-two { left: 55%; top: 20%; transform: rotate(9deg); color: rgba(104,31,45,.42); }

.desktop-music-widget {
  right: 8%;
  bottom: 13%;
  display: flex;
  align-items: end;
  gap: .32rem;
  padding: .62rem .72rem;
  border: 1px solid rgba(42,23,18,.11);
  border-radius: 999px;
  background: rgba(42,23,18,.72);
  color: rgba(255,246,226,.9);
  box-shadow: 0 18px 38px rgba(42,23,18,.18);
}

.desktop-thought,
.desktop-cassette {
  position: absolute;
  z-index: 7;
  pointer-events: none;
  user-select: none;
}

.desktop-thought {
  color: rgba(42,23,18,.5);
  font: 700 1.12rem var(--hand);
  line-height: .92;
  filter: drop-shadow(0 8px 12px rgba(42,23,18,.06));
}

.thought-one {
  left: 38%;
  top: 27%;
  transform: rotate(-7deg);
  color: rgba(104,31,45,.56);
}

.thought-two {
  left: 68%;
  top: 16%;
  max-width: 11ch;
  transform: rotate(5deg);
}

.thought-three {
  left: 57%;
  top: 43%;
  transform: rotate(-3deg);
  color: rgba(139,143,95,.66);
}

.desktop-cassette {
  left: 47%;
  top: 56%;
  width: 142px;
  height: 78px;
  border: 1px solid rgba(42,23,18,.13);
  border-radius: 13px 11px 14px 10px;
  background:
    linear-gradient(145deg, rgba(239,222,197,.92), rgba(196,165,139,.82)),
    radial-gradient(circle at 28% 50%, rgba(42,23,18,.12) 0 18%, transparent 19%),
    radial-gradient(circle at 72% 50%, rgba(42,23,18,.12) 0 18%, transparent 19%);
  box-shadow: 0 22px 48px rgba(42,23,18,.14);
  transform: rotate(5deg);
}

.desktop-cassette::before {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 18px;
  height: 28px;
  border: 1px solid rgba(42,23,18,.12);
  border-radius: 999px;
  background: rgba(255,255,255,.34);
}

.desktop-cassette i {
  position: absolute;
  top: 25px;
  width: 16px;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 4px solid rgba(104,31,45,.34);
  background: rgba(255,250,237,.7);
}

.desktop-cassette i:first-child { left: 35px; }
.desktop-cassette i:nth-child(2) { right: 35px; }

.desktop-cassette b {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 9px;
  color: rgba(42,23,18,.58);
  font: 10px var(--mono);
  text-align: center;
}

.desktop-music-widget b {
  margin-right: .2rem;
  font: 10px var(--mono);
}

.desktop-music-widget i {
  width: 4px;
  height: 12px;
  border-radius: 999px;
  background: rgba(255,246,226,.78);
  animation: desktopMusicBars 1.2s ease-in-out infinite;
}

.desktop-music-widget i:nth-of-type(2) { height: 18px; animation-delay: -.25s; }
.desktop-music-widget i:nth-of-type(3) { height: 9px; animation-delay: -.5s; }

.desktop-sticky-note {
  width: 116px;
  min-height: 70px;
  padding: .78rem .82rem;
  border: 1px solid rgba(42,23,18,.1);
  border-radius: 10px 10px 14px 8px;
  background: rgba(255,247,189,.78);
  box-shadow: 0 18px 38px rgba(42,23,18,.11);
  color: rgba(42,23,18,.62);
  font: 700 1.05rem var(--hand);
  line-height: .9;
  pointer-events: auto;
  cursor: grab;
}

.desktop-sticky-note::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -10px;
  width: 56px;
  height: 18px;
  border-radius: 4px;
  background: rgba(255,255,255,.38);
  box-shadow: 0 8px 16px rgba(42,23,18,.06);
  transform: translateX(-50%) rotate(-4deg);
}

.desktop-sticky-note.dragging {
  cursor: grabbing;
}

.sticky-one { left: 31%; top: 66%; transform: rotate(-5deg); }
.figma-toolbar {
  position: absolute;
  left: 1rem;
  top: 1rem;
  z-index: 6;
  display: flex;
  gap: .35rem;
  padding: .42rem;
  border: 1px solid rgba(42,23,18,.12);
  border-radius: 999px;
  background: rgba(251,242,223,.76);
  box-shadow: 0 12px 24px rgba(15,15,13,.08);
  backdrop-filter: blur(14px);
}
.figma-toolbar span {
  width: 26px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--black);
  opacity: .78;
}
.figma-toolbar span:nth-child(2) { background: var(--orange); }
.figma-toolbar span:nth-child(3) { background: var(--blue); }
.figma-toolbar span:nth-child(4) { background: var(--green); }
.project-card {
  position: absolute;
  z-index: 5;
  display: grid;
  justify-items: center;
  gap: .55rem;
  width: var(--w, min(310px, 31vw));
  padding: .25rem;
  border: 0;
  border-radius: 6px;
  background: transparent;
  box-shadow: none;
  text-decoration: none;
  color: rgba(42,23,18,.82);
  left: var(--left, 0);
  top: var(--top, 0);
  transform: translate3d(var(--px, 0), calc(var(--py, 0) + var(--lift, 0px)), 0) rotate(var(--r, 0)) scale(calc(var(--s, 1) * var(--mag, 1)));
  transition: transform .34s cubic-bezier(.2, .8, .2, 1), filter .35s ease, opacity .35s ease;
  will-change: transform;
}
.desktop-folder::after {
  content: none;
}
.folder-icon {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 1.25 / 1;
  border: 1px solid var(--folder-border, rgba(104,31,45,.18));
  border-radius: 8px 8px 10px 10px;
  background:
    linear-gradient(145deg, var(--folder-top, rgba(244,229,201,.98)), var(--folder-bottom, rgba(211,175,139,.94)));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.68),
    0 18px 34px rgba(42,23,18,.13),
    0 0 0 rgba(255,226,167,0);
  transition: box-shadow .34s ease, filter .34s ease;
}
.folder-icon::before {
  content: "";
  position: absolute;
  left: 9%;
  top: -11%;
  width: 42%;
  height: 28%;
  border: 1px solid var(--folder-border, rgba(104,31,45,.15));
  border-bottom: 0;
  border-radius: 8px 8px 0 0;
  background: linear-gradient(145deg, var(--folder-tab-top, rgba(248,237,210,.98)), var(--folder-tab-bottom, rgba(219,185,149,.94)));
}
.folder-icon::after {
  content: "";
  position: absolute;
  inset: 22% 8% 10%;
  border-radius: 7px;
  background: linear-gradient(145deg, rgba(255,246,226,.34), rgba(255,255,255,0));
}
.desktop-folder strong {
  display: block;
  max-width: 100%;
  padding: .28rem .48rem;
  border-radius: 4px;
  background: var(--folder-label-bg, rgba(251,242,223,.62));
  color: var(--folder-label-color, rgba(42,23,18,.78));
  font: 500 12px var(--mono);
  letter-spacing: 0;
  text-align: center;
  box-shadow: 0 7px 16px rgba(42,23,18,.06);
  transition: background .34s ease, color .34s ease;
}
.project-card.is-hidden { display: none; }
.project-card:hover {
  z-index: 12;
  --lift: -6px;
  --mag: 1;
}
.desktop-folder::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 4%;
  z-index: -1;
  width: 118%;
  aspect-ratio: 1.18 / 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,226,167,.42), transparent 68%);
  opacity: 0;
  filter: blur(8px);
  transform: translateX(-50%) scale(.88);
  transition: opacity .38s ease, transform .38s ease;
}
.desktop-folder:hover::before,
.desktop-folder:focus-visible::before {
  opacity: 1;
  transform: translateX(-50%) scale(1);
}
.project-card:hover .folder-icon {
  filter: brightness(1.05) saturate(1.02);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.74),
    0 28px 52px rgba(42,23,18,.22),
    0 0 36px rgba(255,226,167,.2);
}
.project-card:hover strong {
  background: rgba(104,31,45,.86);
  color: rgba(255,246,226,.96);
}
.project-card.is-near {
  --mag: 1;
}
.project-card.is-dimmed {
  opacity: .78;
  filter: saturate(.9);
}
.case-window-layer {
  position: fixed;
  inset: 0;
  z-index: 260;
  pointer-events: none;
  overflow: hidden;
  isolation: isolate;
}

.case-window-layer.is-open {
  pointer-events: auto;
}

.case-window-layer.is-closing {
  pointer-events: auto;
}

.case-window-layer::before,
.case-window-layer::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  transition: opacity .78s cubic-bezier(.16, 1, .3, 1);
}

.case-window-layer::before {
  z-index: 0;
  background:
    radial-gradient(ellipse at 50% 42%, rgba(255,246,226,.24), transparent 34%),
    radial-gradient(ellipse at 24% 70%, rgba(104,31,45,.18), transparent 38%),
    radial-gradient(ellipse at 82% 18%, rgba(42,23,18,.14), transparent 34%),
    radial-gradient(ellipse at center, transparent 0 46%, rgba(42,23,18,.3) 100%),
    linear-gradient(135deg, rgba(244,229,201,.44), rgba(104,31,45,.16));
  backdrop-filter: blur(7px) saturate(.94) brightness(.9);
}

.case-window-layer::after {
  z-index: 1;
  background:
    radial-gradient(circle, rgba(255,255,255,.16) 0 .7px, transparent 1px),
    repeating-linear-gradient(0deg, rgba(42,23,18,.025) 0 1px, transparent 1px 6px);
  background-size: 18px 18px, auto;
  mix-blend-mode: multiply;
}

.case-window-layer.is-open::before {
  opacity: 1;
}

.case-window-layer.is-open::after {
  opacity: .34;
}

.case-window {
  position: absolute;
  z-index: 2;
  left: 0;
  top: 0;
  width: min(760px, calc(100vw - 2rem));
  max-height: min(680px, calc(100vh - 2rem));
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.58);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255,250,237,.72), rgba(234,220,199,.56)),
    radial-gradient(circle at 82% 12%, rgba(255,226,167,.38), transparent 34%);
  box-shadow: 0 44px 120px rgba(42,23,18,.28), inset 0 1px 0 rgba(255,255,255,.72);
  backdrop-filter: blur(22px) saturate(1.14);
  opacity: 0;
  pointer-events: none;
  filter: blur(8px);
  transform: translate3d(var(--case-x, calc(50vw - 50%)), var(--case-y, calc(50vh - 50%)), 0) translateY(12px) scale(.96);
  transition:
    opacity .72s cubic-bezier(.16, 1, .3, 1),
    transform .82s cubic-bezier(.16, 1, .3, 1),
    filter .76s cubic-bezier(.16, 1, .3, 1);
  will-change: opacity, transform, filter;
}

.case-window-layer.is-open .case-window {
  opacity: 1;
  pointer-events: auto;
  filter: blur(0);
  transform: translate3d(var(--case-x, calc(50vw - 50%)), var(--case-y, calc(50vh - 50%)), 0) scale(1);
}

.case-window-layer.is-closing .case-window {
  opacity: 0;
  pointer-events: none;
  filter: blur(8px);
  transform: translate3d(var(--case-x, calc(50vw - 50%)), var(--case-y, calc(50vh - 50%)), 0) translateY(12px) scale(.96);
}

.case-window.is-dragging {
  transition: none;
  cursor: grabbing;
}

.case-window-bar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: .8rem;
  padding: .72rem .82rem;
  border-bottom: 1px solid rgba(42,23,18,.11);
  background: rgba(251,242,223,.54);
  cursor: grab;
  user-select: none;
}

.window-dots {
  display: flex;
  gap: .38rem;
}

.window-dots span {
  width: 10px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(104,31,45,.78);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
}

.window-dots span:nth-child(2) { background: rgba(214,168,95,.88); }
.window-dots span:nth-child(3) { background: rgba(139,143,95,.82); }

.case-window-bar p {
  margin: 0;
  color: rgba(42,23,18,.72);
  font: 500 12px var(--mono);
  text-align: center;
}

.case-window-close {
  width: 28px;
  aspect-ratio: 1;
  border: 1px solid rgba(42,23,18,.1);
  border-radius: 50%;
  background: rgba(255,255,255,.46);
  color: rgba(42,23,18,.72);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
}

.case-window-content {
  position: relative;
  min-height: 560px;
  padding: clamp(1rem, 2.5vw, 1.7rem);
  overflow: auto;
  background:
    radial-gradient(circle, rgba(42,23,18,.055) .55px, transparent .85px),
    linear-gradient(180deg, rgba(255,255,255,.18), transparent);
  background-size: 13px 13px, auto;
}

.case-window-content::before,
.case-window-content::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.case-window-content::before {
  right: 8%;
  top: 8%;
  width: 130px;
  aspect-ratio: 1.12;
  border: 10px solid rgba(92,50,32,.1);
  border-radius: 48% 52% 45% 55%;
  transform: rotate(12deg);
}

.case-window-content::after {
  left: 7%;
  bottom: 9%;
  width: 90px;
  height: 24px;
  border-radius: 6px;
  background: rgba(255,255,255,.38);
  box-shadow: 0 12px 28px rgba(42,23,18,.08);
  transform: rotate(-8deg);
}

.case-paper,
.case-mockup,
.case-note,
.case-tags,
.case-link {
  position: absolute;
  z-index: 2;
}

.case-paper {
  left: 5%;
  top: 6%;
  width: min(315px, 46%);
  padding: 1.25rem;
  border: 1px solid rgba(42,23,18,.11);
  border-radius: 7px;
  background: rgba(255,250,237,.88);
  box-shadow: 0 24px 54px rgba(42,23,18,.13);
  transform: rotate(-2deg);
}

.case-kicker {
  color: rgba(104,31,45,.68);
  font: 11px var(--mono);
  text-transform: uppercase;
}

.case-paper h3 {
  margin: .45rem 0 .65rem;
  font-family: var(--display);
  font-size: clamp(2.1rem, 4vw, 3.4rem);
  font-weight: 400;
  line-height: .9;
}

.case-paper p {
  margin: 0;
  color: rgba(42,23,18,.68);
  font-size: .98rem;
  line-height: 1.5;
}

.case-mockup {
  padding: .55rem;
  border: 1px solid rgba(42,23,18,.1);
  border-radius: 7px;
  background: rgba(255,250,237,.9);
  box-shadow: 0 28px 62px rgba(42,23,18,.16);
}

.case-mockup img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 5px;
}

.case-mockup-large {
  right: 6%;
  top: 13%;
  width: min(330px, 45%);
  aspect-ratio: 1.2 / 1;
  transform: rotate(3deg);
}

.case-mockup-small {
  left: 14%;
  bottom: 12%;
  width: min(230px, 34%);
  aspect-ratio: 1.05 / 1;
  transform: rotate(4deg);
}

.case-tape {
  position: absolute;
  top: -13px;
  width: 76px;
  height: 23px;
  border-radius: 4px;
  background: rgba(255,255,255,.42);
  box-shadow: 0 8px 18px rgba(42,23,18,.08);
}

.case-tape-left {
  left: 38%;
  transform: rotate(-7deg);
}

.case-tape-right {
  right: 24%;
  transform: rotate(8deg);
}

.case-note {
  right: 11%;
  bottom: 22%;
  width: min(230px, 32%);
  padding: 1rem;
  border: 1px solid rgba(42,23,18,.12);
  border-radius: 16px 16px 16px 4px;
  background: rgba(255,247,189,.84);
  box-shadow: 0 22px 48px rgba(42,23,18,.13);
  color: rgba(42,23,18,.72);
  font-family: var(--hand);
  font-weight: 700;
  transform: rotate(-5deg);
}

.case-note span {
  display: block;
  margin-bottom: .3rem;
  color: rgba(104,31,45,.62);
  font: 11px var(--mono);
  text-transform: uppercase;
}

.case-note p {
  margin: 0;
  font-size: 1.15rem;
  line-height: 1;
}

.case-tags {
  left: 46%;
  bottom: 8%;
  display: flex;
  flex-wrap: wrap;
  gap: .42rem;
  max-width: 280px;
  margin: 0;
  padding: 0;
  list-style: none;
  transform: rotate(-2deg);
}

.case-tags li {
  padding: .42rem .58rem;
  border: 1px dashed rgba(42,23,18,.18);
  border-radius: 999px;
  background: rgba(251,242,223,.72);
  color: rgba(42,23,18,.62);
  font: 11px var(--mono);
}

.case-link {
  right: 1.2rem;
  bottom: 1rem;
  padding: .62rem .85rem;
  border-radius: 999px;
  background: rgba(104,31,45,.88);
  color: rgba(255,246,226,.96);
  font: 12px var(--mono);
  text-decoration: none;
  box-shadow: 0 16px 34px rgba(104,31,45,.18);
}

@keyframes desktopLightFlicker {
  0%, 100% { opacity: .92; }
  45% { opacity: .78; }
  62% { opacity: .96; }
}

@keyframes desktopGlowBreathe {
  0%, 100% {
    opacity: .74;
    transform: scale(1);
  }
  50% {
    opacity: .9;
    transform: scale(1.035);
  }
}

@keyframes desktopDustDrift {
  0%, 100% {
    opacity: .62;
    transform: translate3d(0, 0, 0);
  }
  50% {
    opacity: .86;
    transform: translate3d(8px, -12px, 0);
  }
}

@keyframes desktopCursorBlink {
  0%, 52% { opacity: .85; }
  53%, 100% { opacity: 0; }
}

@keyframes desktopSavedToast {
  0%, 100% {
    opacity: .72;
    translate: 0 0;
  }
  45% {
    opacity: .92;
    translate: 0 -3px;
  }
}

@keyframes desktopLoadPulse {
  0%, 100% { transform: translateX(-18%); }
  50% { transform: translateX(22%); }
}

@keyframes thoughtDrift {
  0%, 100% {
    opacity: .7;
    transform: translate3d(0, 8px, 0) rotate(var(--thought-r, 0deg));
  }
  35% {
    opacity: .96;
    transform: translate3d(10px, -8px, 0) rotate(calc(var(--thought-r, 0deg) + 1.2deg));
  }
  70% {
    opacity: .84;
    transform: translate3d(-7px, -2px, 0) rotate(calc(var(--thought-r, 0deg) - .8deg));
  }
}

@keyframes thoughtLoad {
  0%, 100% { transform: translateX(-18%) scaleX(.74); }
  50% { transform: translateX(28%) scaleX(1); }
}

@keyframes thoughtParticle {
  0%, 100% {
    opacity: .28;
    transform: translate3d(0, 10px, 0) scale(.72);
  }
  45% {
    opacity: .9;
    transform: translate3d(12px, -12px, 0) scale(1);
  }
}

@keyframes statusDotBlink {
  0%, 100% { transform: scale(.72); opacity: .42; }
  50% { transform: scale(1); opacity: 1; }
}

@keyframes desktopMusicBars {
  0%, 100% { transform: scaleY(.72); }
  50% { transform: scaleY(1.08); }
}

@keyframes memoryFloat {
  0%, 100% { translate: 0 0; opacity: .78; }
  50% { translate: 0 -10px; opacity: 1; }
}

@keyframes desktopPawAppear {
  0%, 62%, 100% {
    opacity: 0;
    translate: 0 5px;
  }
  68%, 82% {
    opacity: .72;
    translate: 0 0;
  }
  90% {
    opacity: 0;
    translate: 0 -2px;
  }
}

@media (max-width: 900px) {
  .project-board {
    padding: 1rem;
  }
  .board-canvas {
    min-height: auto;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem .75rem;
    padding: 4.2rem 1rem 1.4rem;
  }
  .board-canvas::after,
  .archive-glow,
  .archive-grain,
  .workspace-thoughts,
  .work-comp-preview,
  .work-comp-paws,
  .work-folder-cat,
  .archive-dust,
  .archive-coffee,
  .archive-tape,
  .archive-doodle,
  .desktop-memory,
  .desktop-cursor,
  .desktop-file,
  .desktop-popup,
  .desktop-caty-gif,
  .desktop-heart-sticker,
  .desktop-star-sticker,
  .desktop-thought,
  .desktop-cassette,
  .hidden-memory-title,
  .memory-os-bar,
  .memory-status-strip,
  .memory-fragments,
  .desktop-music-widget,
  .desktop-sticky-note { display: none; }
  .project-card {
    position: static;
    width: min(132px, 100%);
    justify-self: center;
    transform: none !important;
    animation: none;
  }
  .desktop-folder strong {
    font-size: 11px;
  }
  .creative-status-widget {
    position: relative;
    right: auto;
    top: auto;
    grid-column: 1 / -1;
    width: 100%;
    transform: none;
  }
  .case-window {
    width: calc(100vw - 1rem);
    max-height: calc(100vh - 1rem);
  }
  .case-window-content {
    min-height: auto;
    display: grid;
    gap: 1rem;
    padding: 1rem;
  }
  .case-paper,
  .case-mockup,
  .case-note,
  .case-tags,
  .case-link {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: 100%;
    max-width: none;
    transform: none;
  }
  .case-mockup-large,
  .case-mockup-small {
    aspect-ratio: 4 / 3;
  }
  .case-tags {
    display: flex;
  }
  .case-link {
    justify-self: start;
  }
}

.scrapbook-section {
  position: relative;
  padding: 5rem 0 7.5rem;
  overflow: visible;
  background:
    radial-gradient(ellipse at 10% 4%, rgba(255,246,226,.74), transparent 30%),
    radial-gradient(ellipse at 88% 12%, rgba(104,31,45,.13), transparent 22%),
    radial-gradient(ellipse at 45% 78%, rgba(139,143,95,.1), transparent 28%),
    repeating-linear-gradient(92deg, rgba(42,23,18,.03) 0 1px, transparent 1px 11px),
    linear-gradient(180deg, rgba(239,225,202,.72), rgba(226,203,173,.62) 56%, rgba(240,226,203,.85));
}

.capture-edge-decoration {
  position: absolute;
  left: max(-2.25rem, -2.5vw);
  top: clamp(8rem, 22vw, 18rem);
  z-index: 18;
  width: clamp(150px, 17vw, 260px);
  height: auto;
  pointer-events: auto;
  user-select: none;
  filter: drop-shadow(0 26px 34px rgba(42,23,18,.2));
  transform: rotate(-8deg) translate3d(0, 0, 0);
  transform-origin: 34% 50%;
  transition: transform .65s cubic-bezier(.18,.9,.18,1), filter .65s ease;
}

.capture-edge-decoration:hover {
  filter: drop-shadow(0 34px 44px rgba(42,23,18,.25));
  transform: rotate(-5deg) translate3d(.55rem, -1rem, 0);
}

.scrapbook-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle, rgba(42,23,18,.055) .7px, transparent 1px),
    linear-gradient(115deg, transparent 0 48%, rgba(255,255,255,.12) 49%, transparent 51%);
  background-size: 18px 18px, auto;
  opacity: .6;
  mix-blend-mode: multiply;
}
.scrapbook-heading {
  position: relative;
  z-index: 6;
  max-width: 56rem;
  margin: 0 auto 2.5rem;
  text-align: center;
}
.scrapbook-heading .section-subtitle {
  max-width: 40rem;
  margin: 1rem auto 0;
  color: rgba(15,15,13,.6);
  font-family: var(--mono);
  font-size: .95rem;
  line-height: 1.7;
}
.scrapbook-stage {
  position: relative;
  width: min(1220px, 92vw);
  min-height: 780px;
  margin: 0 auto;
}

.paper-layer,
.scrapbook-dust,
.browser-memory-tab,
.memory-piece,
.film-strip,
.hand-note,
.scrap-doodle {
  position: absolute;
}

.paper-layer,
.scrapbook-dust,
.scrap-doodle {
  pointer-events: none;
  user-select: none;
}

.paper-layer {
  z-index: 0;
  border: 1px solid rgba(92,50,32,.08);
  border-radius: 10px 13px 9px 12px;
  background:
    radial-gradient(circle, rgba(42,23,18,.05) .55px, transparent .85px),
    linear-gradient(145deg, rgba(255,249,232,.66), rgba(217,191,159,.42));
  background-size: 13px 13px, auto;
  box-shadow: 0 28px 72px rgba(42,23,18,.12);
}

.layer-one {
  left: 11%;
  top: 12%;
  width: 46%;
  height: 360px;
  transform: rotate(-4deg);
}

.layer-two {
  right: 5%;
  top: 18%;
  width: 44%;
  height: 420px;
  background-color: rgba(255,246,226,.4);
  transform: rotate(5deg);
}

.layer-three {
  left: 24%;
  bottom: 4%;
  width: 58%;
  height: 320px;
  transform: rotate(1.5deg);
}

.scrapbook-dust {
  z-index: 5;
  width: 7px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(255,246,226,.76);
  box-shadow:
    28px 14px 0 rgba(255,226,167,.42),
    -22px 36px 0 rgba(104,31,45,.14),
    48px 62px 0 rgba(255,246,226,.5);
  opacity: .62;
  animation: scrapbookDust 9s ease-in-out infinite;
}

.dust-one { left: 17%; top: 23%; }
.dust-two { right: 24%; top: 11%; animation-delay: -3s; }
.dust-three { left: 48%; bottom: 22%; animation-delay: -5.4s; }

.browser-memory-tab {
  z-index: 4;
  display: flex;
  align-items: center;
  gap: .38rem;
  min-width: 210px;
  padding: .58rem .72rem;
  border: 1px solid rgba(92,50,32,.12);
  border-radius: 12px 12px 4px 4px;
  background: rgba(255,250,237,.62);
  box-shadow: 0 18px 42px rgba(42,23,18,.1);
  backdrop-filter: blur(12px);
  color: rgba(42,23,18,.52);
  transform: rotate(var(--tab-r, 0deg));
}

.browser-memory-tab span {
  width: 9px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(104,31,45,.7);
}

.browser-memory-tab span:nth-child(2) { background: rgba(214,168,95,.8); }
.browser-memory-tab span:nth-child(3) { background: rgba(139,143,95,.72); }

.browser-memory-tab b {
  margin-left: .26rem;
  font: 10px var(--mono);
  font-weight: 400;
}

.tab-one { left: 8%; top: 3%; --tab-r: -2deg; }
.tab-two { right: 10%; top: 6%; --tab-r: 3deg; }

.memory-piece {
  position: absolute;
  z-index: 3;
  display: block;
  overflow: hidden;
  border: 1px solid rgba(42,23,18,.1);
  background:
    radial-gradient(circle, rgba(42,23,18,.045) .55px, transparent .9px),
    linear-gradient(180deg, rgba(255,250,237,.98), rgba(239,223,195,.95));
  background-size: 12px 12px, auto;
  box-shadow: 0 30px 78px rgba(42,23,18,.18), inset 0 1px 0 rgba(255,255,255,.62);
  transform: translate3d(0, 0, 0) rotate(var(--r, 0deg));
  transition: transform .7s cubic-bezier(.18,.9,.18,1), box-shadow .7s ease, filter .7s ease;
  animation: paperFloat var(--float-speed, 11s) ease-in-out infinite;
  animation-delay: var(--float-delay, 0s);
}

.memory-piece::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(115deg, rgba(255,255,255,.28), transparent 38%),
    radial-gradient(ellipse at 50% 100%, rgba(104,31,45,.12), transparent 44%);
  mix-blend-mode: screen;
  opacity: .72;
}

.memory-piece img,
.film-strip img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: sepia(.12) saturate(.82) contrast(1.03);
  transition: transform .8s cubic-bezier(.18,.9,.18,1), filter .8s ease;
}

.polaroid {
  width: 270px;
  padding: .82rem .82rem 4.45rem;
  border-radius: 8px 8px 10px 10px;
}

.polaroid img {
  aspect-ratio: 1 / 1.12;
  border-radius: 4px;
}

.wide-polaroid {
  width: 360px;
  padding-bottom: 3.95rem;
}

.wide-polaroid img {
  aspect-ratio: 1.34 / 1;
}

.small-polaroid {
  width: 220px;
}

.taped-photo {
  width: 330px;
  padding: .55rem;
  border-radius: 7px;
}

.taped-photo img {
  aspect-ratio: 1.32 / 1;
  border-radius: 4px;
}

.memory-caption {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: .7rem;
  z-index: 2;
  color: rgba(42,23,18,.68);
}

.memory-caption small {
  display: block;
  margin-bottom: .12rem;
  color: rgba(104,31,45,.66);
  font: 10px var(--mono);
  text-transform: lowercase;
}

.memory-caption p {
  margin: 0;
  font: 700 1.16rem var(--hand);
  line-height: .9;
}

.photo-tape {
  position: absolute;
  z-index: 6;
  width: 82px;
  height: 25px;
  border-radius: 4px;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0 6px, transparent 6px 12px),
    rgba(255,255,255,.46);
  box-shadow: 0 8px 18px rgba(42,23,18,.08);
  pointer-events: none;
}

.tape-left { left: 24px; top: -8px; transform: rotate(-9deg); }
.tape-right { right: 36px; top: -9px; transform: rotate(8deg); }
.tape-top { left: 50%; top: -12px; transform: translateX(-50%) rotate(3deg); }
.tape-corner { right: -18px; top: 24px; transform: rotate(45deg); }

.memory-hover-note {
  z-index: 7;
  position: absolute;
  left: 50%;
  bottom: 1rem;
  max-width: 210px;
  padding: .72rem .82rem;
  border: 1px solid rgba(92,50,32,.12);
  border-radius: 14px 14px 14px 4px;
  background: rgba(255,247,189,.86);
  box-shadow: 0 20px 44px rgba(42,23,18,.14);
  color: rgba(42,23,18,.68);
  font: 700 1.04rem var(--hand);
  line-height: .92;
  opacity: 0;
  filter: blur(2px);
  transform: translate(-50%, 18px) rotate(-4deg);
  transition: opacity .75s ease, filter .75s ease, transform .85s cubic-bezier(.18,.9,.18,1);
}

.memory-piece:hover,
.memory-piece:focus-visible {
  z-index: 12;
  box-shadow: 0 42px 96px rgba(42,23,18,.24), 0 0 52px rgba(255,226,167,.18);
  filter: saturate(1.02);
  transform: translate3d(0, -14px, 0) rotate(var(--hover-r, var(--r, 0deg)));
}

.memory-piece:hover img,
.memory-piece:focus-visible img,
.film-strip:hover img,
.film-strip:focus-visible img {
  filter: sepia(.08) saturate(.98) contrast(1.06);
  transform: scale(1.045);
}

.memory-piece:hover .memory-hover-note,
.memory-piece:focus-visible .memory-hover-note {
  opacity: 1;
  filter: blur(0);
  transform: translate(-50%, 0) rotate(-4deg);
}

.memory-one { left: 7%; top: 14%; --r: -7deg; --hover-r: -4deg; --float-delay: -1s; }
.memory-two { left: 36%; top: 4%; --r: 4deg; --hover-r: 2deg; --float-speed: 12s; }
.memory-three { right: 10%; top: 19%; --r: 8deg; --hover-r: 5deg; --float-delay: -3.2s; }
.memory-four { left: 12%; bottom: 11%; --r: 5deg; --hover-r: 2deg; --float-delay: -5s; }
.memory-five { right: 6%; bottom: 5%; --r: -5deg; --hover-r: -2deg; --float-speed: 13s; }
.memory-film { --r: -3deg; }

.film-strip {
  left: 39%;
  top: 39%;
  z-index: 7;
  display: grid;
  grid-template-columns: repeat(3, 82px);
  gap: .48rem;
  padding: .72rem .82rem 2.6rem;
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(42,23,18,.82) 0 13px, transparent 13px calc(100% - 13px), rgba(42,23,18,.82) calc(100% - 13px)),
    linear-gradient(180deg, rgba(59,33,29,.96), rgba(42,23,18,.92));
  box-shadow: 0 30px 78px rgba(42,23,18,.24);
  transform: rotate(-3deg);
  transition: transform .7s cubic-bezier(.18,.9,.18,1), box-shadow .7s ease;
}

.film-strip::before,
.film-strip::after {
  content: "";
  position: absolute;
  left: 6px;
  right: 6px;
  height: 8px;
  background: repeating-linear-gradient(90deg, rgba(255,246,226,.36) 0 7px, transparent 7px 15px);
}

.film-strip::before { top: 6px; }
.film-strip::after { bottom: 6px; }

.film-strip span {
  position: relative;
  z-index: 1;
  display: block;
  width: 82px;
  aspect-ratio: 1.1 / 1;
  overflow: hidden;
  border-radius: 3px;
  background: rgba(255,246,226,.24);
}

.film-strip em {
  position: absolute;
  left: 1.1rem;
  right: 1.1rem;
  bottom: .72rem;
  z-index: 1;
  color: rgba(255,246,226,.84);
  font: 10px var(--mono);
  font-style: normal;
}

.film-strip:hover,
.film-strip:focus-visible {
  z-index: 13;
  box-shadow: 0 42px 96px rgba(42,23,18,.28);
  transform: translateY(-12px) rotate(-1deg);
}

.hand-note {
  z-index: 8;
  width: 178px;
  padding: .9rem .95rem;
  border: 1px solid rgba(92,50,32,.11);
  border-radius: 13px 12px 14px 8px;
  background:
    repeating-linear-gradient(0deg, transparent 0 26px, rgba(104,31,45,.08) 27px, transparent 28px),
    rgba(255,247,189,.8);
  box-shadow: 0 22px 52px rgba(42,23,18,.13);
  color: rgba(42,23,18,.66);
  transform: rotate(var(--note-r, 0deg));
  transition: opacity .8s ease, transform .8s cubic-bezier(.18,.9,.18,1), box-shadow .8s ease;
  animation: paperFloat 12s ease-in-out infinite;
}

.hand-note::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -11px;
  width: 62px;
  height: 20px;
  border-radius: 4px;
  background: rgba(255,255,255,.42);
  box-shadow: 0 8px 16px rgba(42,23,18,.06);
  transform: translateX(-50%) rotate(-5deg);
}

.hand-note span {
  display: block;
  margin-bottom: .35rem;
  color: rgba(104,31,45,.62);
  font: 10px var(--mono);
  text-transform: lowercase;
}

.hand-note p {
  margin: 0;
  font: 700 1.08rem var(--hand);
  line-height: .95;
}

.hand-note:hover,
.hand-note:focus-visible {
  z-index: 14;
  box-shadow: 0 34px 78px rgba(42,23,18,.18);
  transform: translateY(-10px) rotate(var(--note-hover-r, var(--note-r, 0deg)));
}

.note-one { left: 27%; top: 31%; --note-r: -8deg; --note-hover-r: -5deg; }
.note-two { right: 26%; top: 30%; --note-r: 5deg; --note-hover-r: 3deg; animation-delay: -2.6s; }
.note-three { left: 36%; bottom: 9%; --note-r: 2deg; --note-hover-r: -1deg; animation-delay: -4.4s; }

.scrap-doodle {
  z-index: 9;
  color: rgba(104,31,45,.62);
  font-family: var(--hand);
  font-weight: 700;
  filter: drop-shadow(0 8px 14px rgba(42,23,18,.08));
  animation: doodleDrift 8s ease-in-out infinite;
}

.doodle-memory-heart { left: 5%; top: 48%; font-size: 2.8rem; transform: rotate(-11deg); }
.doodle-memory-star { right: 7%; top: 8%; font-size: 2rem; color: rgba(139,143,95,.72); animation-delay: -2s; }
.doodle-memory-arrow { left: 52%; bottom: 6%; font-size: 1.5rem; transform: rotate(9deg); animation-delay: -3.5s; }
.doodle-memory-loop {
  right: 33%;
  bottom: 22%;
  width: 78px;
  height: 36px;
  border: 2px solid rgba(104,31,45,.32);
  border-left-color: transparent;
  border-radius: 50%;
  transform: rotate(-18deg);
}

.memory-piece.reveal,
.film-strip.reveal,
.hand-note.reveal {
  opacity: 0;
  transform: translateY(34px) rotate(var(--r, var(--note-r, -2deg)));
  transition: opacity .85s ease, transform .9s cubic-bezier(.18,.9,.18,1), box-shadow .7s ease, filter .7s ease;
}

.memory-piece.reveal.in-view,
.film-strip.reveal.in-view,
.hand-note.reveal.in-view {
  opacity: 1;
  transform: translateY(0) rotate(var(--r, var(--note-r, -2deg)));
}

.hand-note.reveal,
.hand-note.reveal.in-view {
  transform: translateY(var(--reveal-y, 0)) rotate(var(--note-r, 0deg));
}

.memory-piece.reveal.in-view:hover,
.memory-piece.reveal.in-view:focus-visible {
  transform: translate3d(0, -14px, 0) rotate(var(--hover-r, var(--r, 0deg)));
}

.film-strip.reveal.in-view:hover,
.film-strip.reveal.in-view:focus-visible {
  transform: translateY(-12px) rotate(-1deg);
}

.hand-note.reveal.in-view:hover,
.hand-note.reveal.in-view:focus-visible {
  transform: translateY(-10px) rotate(var(--note-hover-r, var(--note-r, 0deg)));
}

@keyframes paperFloat {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 7px; }
}

@keyframes scrapbookDust {
  0%, 100% { opacity: .34; transform: translateY(0) scale(.8); }
  45% { opacity: .82; transform: translateY(-18px) scale(1); }
}

@keyframes doodleDrift {
  0%, 100% { translate: 0 0; }
  50% { translate: 5px -8px; }
}

@media (max-width: 980px) {
  .scrapbook-stage {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.3rem;
    min-height: auto;
  }

  .paper-layer,
  .scrapbook-dust,
  .browser-memory-tab,
  .scrap-doodle {
    display: none;
  }

  .memory-piece,
  .film-strip,
  .hand-note {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: 100%;
    transform: none;
    animation: none;
  }

  .polaroid,
  .wide-polaroid,
  .small-polaroid {
    padding-bottom: 4.1rem;
  }

  .film-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .film-strip span {
    width: 100%;
  }

  .note-three {
    grid-column: 1 / -1;
    width: min(360px, 100%);
    justify-self: center;
  }
}

@media (max-width: 640px) {
  .scrapbook-section {
    padding: 4rem 0 5rem;
  }

  .scrapbook-stage {
    grid-template-columns: 1fr;
  }

  .memory-hover-note {
    left: 1rem;
    right: 1rem;
    max-width: none;
    transform: translateY(14px) rotate(-2deg);
  }

  .memory-piece:hover .memory-hover-note,
  .memory-piece:focus-visible .memory-hover-note {
    transform: translateY(0) rotate(-2deg);
  }
}

.inspiration-archive {
  overflow: hidden;
  background:
    radial-gradient(ellipse at 14% 8%, rgba(255,246,226,.88), transparent 30%),
    radial-gradient(ellipse at 82% 16%, rgba(104,31,45,.16), transparent 26%),
    radial-gradient(ellipse at 50% 76%, rgba(139,143,95,.12), transparent 34%),
    repeating-linear-gradient(92deg, rgba(42,23,18,.032) 0 1px, transparent 1px 12px),
    linear-gradient(180deg, rgba(239,225,202,.82), rgba(221,196,164,.7) 58%, rgba(240,226,203,.9));
}

.inspiration-archive::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at center, transparent 0 52%, rgba(42,23,18,.12) 100%),
    radial-gradient(circle, rgba(255,255,255,.18) 0 .65px, transparent 1px);
  background-size: auto, 19px 19px;
  mix-blend-mode: multiply;
  opacity: .55;
}

.inspiration-archive .scrapbook-heading {
  margin-bottom: 1.4rem;
}

.inspiration-archive .scrapbook-heading h2 {
  max-width: 860px;
}

.inspiration-stage {
  min-height: 980px;
  isolation: isolate;
}

.inspiration-stage .paper-layer {
  opacity: .72;
}

.archive-placeholder,
.vinyl-cover {
  display: grid;
  place-items: center;
  min-height: 100%;
  border: 1px dashed rgba(104,31,45,.24);
  border-radius: 5px;
  background:
    radial-gradient(circle, rgba(255,255,255,.2) .7px, transparent 1px),
    linear-gradient(135deg, rgba(104,31,45,.12), rgba(255,246,226,.62) 45%, rgba(42,23,18,.1));
  background-size: 12px 12px, auto;
  color: rgba(42,23,18,.58);
  font: 11px var(--mono);
  line-height: 1.35;
  text-align: center;
  text-transform: lowercase;
}

.archive-label {
  position: absolute;
  left: .9rem;
  right: .9rem;
  bottom: .75rem;
  z-index: 2;
  color: rgba(42,23,18,.58);
  font: 10px var(--mono);
  text-transform: lowercase;
}

.archive-kdrama { left: 5%; top: 13%; --r: -6deg; --hover-r: -3deg; --float-delay: -1s; }
.archive-perfume { left: 34%; top: 7%; width: 270px; --r: 5deg; --hover-r: 2deg; --float-speed: 12s; }
.archive-language { right: 9%; top: 15%; --r: 8deg; --hover-r: 4deg; --float-delay: -3.2s; }
.archive-film { left: 10%; bottom: 16%; --r: 4deg; --hover-r: 1deg; --float-delay: -5s; }
.archive-editorial { right: 6%; bottom: 7%; --r: -5deg; --hover-r: -2deg; --float-speed: 13s; }
.archive-filmstrip { left: 37%; top: 38%; }

.archive-kdrama .archive-placeholder { aspect-ratio: 1 / 1.12; }
.archive-language .archive-placeholder { aspect-ratio: 1 / 1.12; }
.archive-editorial .archive-placeholder { aspect-ratio: 1.34 / 1; }
.archive-perfume .archive-placeholder,
.archive-film .archive-placeholder { aspect-ratio: 1.32 / 1; }

.archive-filmstrip span {
  display: grid;
  place-items: center;
}

.archive-filmstrip i {
  padding: .35rem;
  color: rgba(255,246,226,.68);
  font: 9px var(--mono);
  font-style: normal;
  text-align: center;
}

.archive-vinyl,
.archive-browser-window,
.archive-map-card,
.archive-type-card,
.archive-coffee-card,
.archive-dance-card {
  position: absolute;
  z-index: 6;
  border: 1px solid rgba(92,50,32,.12);
  background:
    radial-gradient(circle, rgba(42,23,18,.042) .55px, transparent .9px),
    linear-gradient(145deg, rgba(255,250,237,.9), rgba(225,202,172,.84));
  background-size: 12px 12px, auto;
  box-shadow: 0 28px 72px rgba(42,23,18,.16);
  color: rgba(42,23,18,.66);
  transform: rotate(var(--r, 0deg));
  transition: transform .8s cubic-bezier(.18,.9,.18,1), box-shadow .8s ease, filter .8s ease;
  animation: paperFloat var(--float-speed, 12s) ease-in-out infinite;
  animation-delay: var(--float-delay, 0s);
}

.archive-vinyl:hover,
.archive-vinyl:focus-visible,
.archive-browser-window:hover,
.archive-browser-window:focus-visible,
.archive-map-card:hover,
.archive-map-card:focus-visible,
.archive-type-card:hover,
.archive-type-card:focus-visible,
.archive-coffee-card:hover,
.archive-coffee-card:focus-visible,
.archive-dance-card:hover,
.archive-dance-card:focus-visible {
  z-index: 16;
  box-shadow: 0 42px 96px rgba(42,23,18,.22), 0 0 52px rgba(255,226,167,.16);
  transform: translateY(-12px) rotate(var(--hover-r, var(--r, 0deg)));
}

.archive-vinyl:hover .memory-hover-note,
.archive-vinyl:focus-visible .memory-hover-note,
.archive-browser-window:hover .memory-hover-note,
.archive-browser-window:focus-visible .memory-hover-note,
.archive-map-card:hover .memory-hover-note,
.archive-map-card:focus-visible .memory-hover-note,
.archive-type-card:hover .memory-hover-note,
.archive-type-card:focus-visible .memory-hover-note,
.archive-coffee-card:hover .memory-hover-note,
.archive-coffee-card:focus-visible .memory-hover-note,
.archive-dance-card:hover .memory-hover-note,
.archive-dance-card:focus-visible .memory-hover-note {
  opacity: 1;
  filter: blur(0);
  transform: translate(-50%, 0) rotate(-4deg);
}

.archive-vinyl {
  left: 26%;
  top: 26%;
  width: 210px;
  min-height: 160px;
  padding: 1rem;
  border-radius: 10px;
  --r: -10deg;
  --hover-r: -6deg;
  --float-delay: -2.2s;
}

.vinyl-disc {
  position: absolute;
  right: -34px;
  top: 32px;
  width: 102px;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255,246,226,.72) 0 9%, #681f2d 10% 17%, #151111 18% 100%),
    repeating-radial-gradient(circle, rgba(255,255,255,.08) 0 1px, transparent 1px 5px);
  box-shadow: 0 20px 38px rgba(42,23,18,.24);
}

.vinyl-cover {
  width: 116px;
  aspect-ratio: 1;
}

.archive-vinyl p {
  margin: .8rem 0 0;
  font: 700 1.1rem var(--hand);
}

.archive-browser-window {
  right: 23%;
  top: 3%;
  width: 260px;
  padding: 0 0 .9rem;
  border-radius: 12px 12px 8px 8px;
  overflow: hidden;
  --r: -2deg;
  --hover-r: 0deg;
  --float-speed: 13s;
}

.archive-browser-window > div {
  display: flex;
  align-items: center;
  gap: .35rem;
  padding: .55rem .7rem;
  border-bottom: 1px solid rgba(42,23,18,.1);
  background: rgba(255,246,226,.54);
}

.archive-browser-window > div span {
  width: 8px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(104,31,45,.68);
}

.archive-browser-window > div b {
  margin-left: .3rem;
  font: 10px var(--mono);
  font-weight: 400;
}

.archive-browser-window p,
.archive-browser-window small {
  display: block;
  margin: .85rem .9rem 0;
}

.archive-browser-window p {
  font: 700 1.12rem var(--hand);
  line-height: .95;
}

.archive-browser-window small,
.archive-type-card small {
  color: rgba(42,23,18,.46);
  font: 10px/1.5 var(--mono);
}

.archive-map-card {
  left: 3%;
  top: 50%;
  width: 230px;
  padding: 1rem;
  border-radius: 8px 14px 10px 8px;
  --r: 7deg;
  --hover-r: 3deg;
  --float-delay: -6s;
}

.archive-map-card::before {
  content: "";
  display: block;
  height: 88px;
  margin-bottom: .8rem;
  border-radius: 8px;
  background:
    linear-gradient(28deg, transparent 0 34%, rgba(104,31,45,.22) 35% 37%, transparent 38%),
    linear-gradient(126deg, transparent 0 54%, rgba(139,143,95,.24) 55% 57%, transparent 58%),
    rgba(255,246,226,.46);
}

.archive-map-card b,
.archive-dance-card b,
.archive-coffee-card b {
  display: block;
  margin-bottom: .45rem;
  color: rgba(104,31,45,.68);
  font: 10px var(--mono);
  text-transform: lowercase;
}

.archive-map-card p,
.archive-dance-card p,
.archive-coffee-card p,
.archive-type-card p {
  margin: 0;
  font: 700 1.08rem var(--hand);
  line-height: .95;
}

.archive-type-card {
  right: 33%;
  bottom: 23%;
  width: 188px;
  padding: 1rem;
  border-radius: 10px;
  --r: 6deg;
  --hover-r: 2deg;
  --float-delay: -4s;
}

.archive-type-card > span {
  display: block;
  margin-bottom: .4rem;
  color: rgba(42,23,18,.78);
  font: 3.2rem/.8 var(--display);
}

.archive-coffee-card {
  left: 49%;
  bottom: 3%;
  width: 220px;
  padding: 1rem 1rem 1rem 4.6rem;
  border-radius: 12px;
  --r: -3deg;
  --hover-r: -1deg;
  --float-speed: 14s;
}

.archive-coffee-card > span:first-child {
  position: absolute;
  left: 1rem;
  top: 1.2rem;
  width: 48px;
  aspect-ratio: 1;
  border: 8px solid rgba(92,50,32,.2);
  border-radius: 50%;
}

.archive-dance-card {
  right: 4%;
  top: 46%;
  width: 206px;
  padding: 1rem;
  border-radius: 999px 999px 24px 24px;
  --r: 9deg;
  --hover-r: 5deg;
  --float-delay: -7.2s;
}

.inspiration-archive .doodle-memory-heart { left: 12%; top: 37%; }
.inspiration-archive .doodle-memory-star { right: 12%; top: 8%; }
.inspiration-archive .doodle-memory-arrow { left: 58%; bottom: 13%; }
.inspiration-archive .doodle-memory-loop { right: 20%; bottom: 18%; }

.archive-vinyl.reveal,
.archive-browser-window.reveal,
.archive-map-card.reveal,
.archive-type-card.reveal,
.archive-coffee-card.reveal,
.archive-dance-card.reveal {
  opacity: 0;
  transform: translateY(34px) rotate(var(--r, -2deg));
  transition: opacity .85s ease, transform .9s cubic-bezier(.18,.9,.18,1), box-shadow .8s ease, filter .8s ease;
}

.archive-vinyl.reveal.in-view,
.archive-browser-window.reveal.in-view,
.archive-map-card.reveal.in-view,
.archive-type-card.reveal.in-view,
.archive-coffee-card.reveal.in-view,
.archive-dance-card.reveal.in-view {
  opacity: 1;
  transform: translateY(0) rotate(var(--r, -2deg));
}

@media (max-width: 980px) {
  .inspiration-stage {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .archive-vinyl,
  .archive-browser-window,
  .archive-map-card,
  .archive-type-card,
  .archive-coffee-card,
  .archive-dance-card {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: 100%;
    transform: none;
    animation: none;
  }

  .archive-coffee-card {
    padding-left: 4.6rem;
  }
}

@media (max-width: 640px) {
  .inspiration-stage {
    grid-template-columns: 1fr;
  }
}

.footer {
  width: min(1160px, 92vw);
  margin: 0 auto;
  display: flex;
  justify-content: center;
  gap: 1.2rem;
  padding: 2rem 0 4rem;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 12px;
}
.footer a { text-decoration: none; }

.privacy-page {
  min-height: 100vh;
  overflow-x: hidden;
}

.privacy-page::before {
  opacity: .72;
}

.privacy-nav {
  position: sticky;
  top: 0;
  z-index: 90;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: min(1160px, 92vw);
  margin: 0 auto;
  padding: 1rem 0;
  color: var(--espresso);
}

.privacy-actions {
  display: flex;
  align-items: center;
  gap: .75rem;
}

.privacy-back {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: .7rem .95rem;
  border: 1px solid rgba(42,23,18,.14);
  border-radius: 999px;
  background: rgba(251,242,223,.72);
  color: rgba(42,23,18,.72);
  box-shadow: 0 14px 34px rgba(42,23,18,.08);
  backdrop-filter: blur(12px);
  font: 12px var(--mono);
  text-transform: lowercase;
}

.privacy-back:hover {
  background: rgba(255,247,189,.82);
  text-decoration: none;
  transform: translateY(-1px);
}

.privacy-main {
  position: relative;
  isolation: isolate;
  width: min(1040px, 92vw);
  min-height: 78vh;
  margin: 0 auto;
  padding: clamp(3.5rem, 8vw, 7rem) 0 clamp(4rem, 8vw, 6.5rem);
}

.privacy-hero {
  position: relative;
  z-index: 3;
  max-width: 760px;
  margin: 0 auto clamp(2rem, 5vw, 3.6rem);
  text-align: center;
}

.privacy-hero p {
  margin: 0 0 .55rem;
  color: rgba(104,31,45,.68);
  font: 700 1.2rem var(--hand);
}

.privacy-hero h1 {
  margin: 0;
  color: rgba(42,23,18,.92);
  font: clamp(3.6rem, 12vw, 8.5rem) / .82 var(--display);
  letter-spacing: 0;
}

.privacy-meta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 1.2rem;
  padding: .62rem .82rem;
  border: 1px dashed rgba(104,31,45,.18);
  border-radius: 999px;
  background: rgba(255,250,237,.54);
  color: rgba(42,23,18,.58);
  font: 11px var(--mono);
}

.privacy-policy-stack {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.4rem);
}

.privacy-section {
  position: relative;
  min-height: 220px;
  padding: clamp(1.35rem, 3vw, 2rem);
  border: 1px solid rgba(92,50,32,.1);
  border-radius: 12px 12px 18px 10px;
  background:
    radial-gradient(circle, rgba(42,23,18,.04) .6px, transparent .95px),
    linear-gradient(145deg, rgba(255,250,237,.92), rgba(239,222,197,.78));
  background-size: 13px 13px, auto;
  box-shadow: 0 28px 72px rgba(42,23,18,.13), inset 0 1px 0 rgba(255,255,255,.58);
  transform: rotate(var(--privacy-r, 0deg));
  transition: transform .45s cubic-bezier(.18,.9,.18,1), box-shadow .45s ease;
}

.privacy-section:nth-child(1) { --privacy-r: -1.6deg; }
.privacy-section:nth-child(2) { --privacy-r: 1.3deg; margin-top: 1.6rem; }
.privacy-section:nth-child(3) { --privacy-r: 1deg; }
.privacy-section:nth-child(4) { --privacy-r: -1.2deg; margin-top: 1.4rem; }
.privacy-contact-card {
  grid-column: 1 / -1;
  width: min(680px, 100%);
  justify-self: center;
  min-height: 180px;
  --privacy-r: .8deg;
}

.privacy-section:hover {
  z-index: 5;
  box-shadow: 0 38px 90px rgba(42,23,18,.17), 0 0 48px rgba(255,226,167,.18);
  transform: translateY(-6px) rotate(0deg);
}

.privacy-pin {
  position: absolute;
  left: 50%;
  top: -12px;
  width: 70px;
  height: 22px;
  border-radius: 4px;
  background: rgba(255,255,255,.44);
  box-shadow: 0 9px 18px rgba(42,23,18,.07);
  transform: translateX(-50%) rotate(-5deg);
}

.privacy-title {
  margin: .15rem 0 .8rem;
  color: rgba(104,31,45,.74);
  font: 700 clamp(1.25rem, 3vw, 1.75rem) / .9 var(--hand);
}

.privacy-section p {
  margin: 0;
  color: rgba(42,23,18,.68);
  font: 1rem / 1.75 var(--body);
}

.privacy-section a {
  color: rgba(104,31,45,.88);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.privacy-paper,
.privacy-doodle {
  position: absolute;
  pointer-events: none;
  user-select: none;
}

.privacy-paper {
  z-index: 0;
  border: 1px solid rgba(92,50,32,.08);
  border-radius: 14px;
  background:
    radial-gradient(circle, rgba(42,23,18,.035) .55px, transparent .9px),
    linear-gradient(145deg, rgba(255,249,232,.46), rgba(217,191,159,.28));
  background-size: 14px 14px, auto;
  box-shadow: 0 30px 80px rgba(42,23,18,.1);
}

.privacy-paper-one {
  left: -4%;
  top: 18%;
  width: min(360px, 44vw);
  height: 320px;
  transform: rotate(-7deg);
}

.privacy-paper-two {
  right: -5%;
  bottom: 8%;
  width: min(440px, 48vw);
  height: 360px;
  transform: rotate(5deg);
}

.privacy-doodle {
  z-index: 4;
  color: rgba(104,31,45,.55);
  font-family: var(--hand);
  font-weight: 700;
  filter: drop-shadow(0 8px 12px rgba(42,23,18,.08));
  animation: doodleDrift 8s ease-in-out infinite;
}

.privacy-heart { left: 2%; top: 11%; font-size: 3rem; transform: rotate(-13deg); }
.privacy-star { right: 7%; top: 18%; font-size: 2rem; color: rgba(139,143,95,.72); animation-delay: -2s; }
.privacy-arrow { left: 50%; bottom: 2%; font-size: 1.8rem; transform: rotate(10deg); animation-delay: -4s; }

.privacy-footer {
  padding-top: 0;
}

.privacy-footer .footer-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  color: rgba(42,23,18,.62);
}

.resume-page {
  min-height: 100vh;
  overflow-x: hidden;
}

.resume-main {
  position: relative;
  isolation: isolate;
  width: min(1120px, 92vw);
  margin: 0 auto;
  padding: clamp(3rem, 7vw, 6rem) 0 clamp(4rem, 8vw, 7rem);
}

.resume-nav {
  color: var(--espresso);
}

.resume-hero {
  position: relative;
  z-index: 3;
  max-width: 900px;
  margin: 0 auto clamp(2rem, 5vw, 3.2rem);
  text-align: center;
}

.resume-hero p {
  margin: 0 0 .65rem;
  color: rgba(104,31,45,.72);
  font: 12px var(--mono);
  letter-spacing: .18em;
  text-transform: uppercase;
}

.resume-hero h1 {
  margin: 0;
  color: rgba(42,23,18,.92);
  font: clamp(3.4rem, 10vw, 8rem) / .82 var(--display);
}

.resume-hero h1 span {
  display: block;
  margin-top: .35rem;
  color: rgba(104,31,45,.78);
  font: 700 clamp(1.4rem, 4vw, 2.3rem) / .9 var(--hand);
}

.resume-contact {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .6rem;
  margin-top: 1.3rem;
}

.resume-contact span,
.resume-contact a {
  padding: .62rem .82rem;
  border: 1px dashed rgba(104,31,45,.18);
  border-radius: 999px;
  background: rgba(255,250,237,.54);
  color: rgba(42,23,18,.62);
  font: 11px var(--mono);
}

.resume-card {
  position: relative;
  z-index: 2;
  padding: clamp(1.35rem, 3vw, 2rem);
  border: 1px solid rgba(92,50,32,.1);
  border-radius: 12px 12px 18px 10px;
  background:
    radial-gradient(circle, rgba(42,23,18,.04) .6px, transparent .95px),
    linear-gradient(145deg, rgba(255,250,237,.92), rgba(239,222,197,.78));
  background-size: 13px 13px, auto;
  box-shadow: 0 28px 72px rgba(42,23,18,.13), inset 0 1px 0 rgba(255,255,255,.58);
  transform: rotate(var(--resume-r, 0deg));
  transition: transform .45s cubic-bezier(.18,.9,.18,1), box-shadow .45s ease;
}

.resume-card:hover {
  z-index: 6;
  box-shadow: 0 38px 90px rgba(42,23,18,.17), 0 0 48px rgba(255,226,167,.18);
  transform: translateY(-5px) rotate(0deg);
}

.resume-profile {
  width: min(820px, 100%);
  margin: 0 auto 1.4rem;
  --resume-r: -1.1deg;
}

.resume-profile > p:last-child {
  max-width: 65ch;
  margin: 0;
  color: rgba(42,23,18,.68);
  font: 1.05rem / 1.75 var(--body);
}

.resume-experience {
  --resume-r: .8deg;
  margin-bottom: 1.4rem;
}

.resume-section-number {
  margin: 0 0 1rem;
  color: rgba(104,31,45,.7);
  font: 12px var(--mono);
  letter-spacing: .16em;
  text-transform: uppercase;
}

.resume-timeline {
  display: grid;
  gap: .85rem;
}

.resume-role {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(160px, auto);
  gap: 1rem;
  align-items: start;
  padding: .95rem 0;
  border-top: 1px dashed rgba(42,23,18,.14);
}

.resume-role:first-child {
  border-top: 0;
}

.resume-role h2,
.resume-list h2 {
  margin: 0;
  color: rgba(42,23,18,.82);
  font: 700 clamp(1.15rem, 2.8vw, 1.55rem) / .92 var(--hand);
}

.resume-role p,
.resume-list p {
  margin: .28rem 0 0;
  color: rgba(42,23,18,.62);
  font: .98rem / 1.55 var(--body);
}

.resume-role > span {
  justify-self: end;
  color: rgba(104,31,45,.68);
  font: 11px / 1.45 var(--mono);
  text-align: right;
}

.resume-role-featured {
  align-items: stretch;
  padding: 1.15rem;
  border: 1px solid rgba(104,31,45,.13);
  border-radius: 12px;
  background: rgba(255,247,189,.34);
}

.resume-achievements {
  grid-column: 1 / -1;
  margin-top: .35rem;
}

.resume-achievements h3 {
  margin: 0 0 .55rem;
  color: rgba(104,31,45,.72);
  font: 700 1.18rem / .95 var(--hand);
}

.resume-achievements ul,
.resume-tags {
  margin: 0;
  padding: 0;
  list-style: none;
}

.resume-achievements li {
  position: relative;
  margin-top: .42rem;
  padding-left: 1.1rem;
  color: rgba(42,23,18,.65);
  font: .95rem / 1.55 var(--body);
}

.resume-achievements li::before {
  content: "♡";
  position: absolute;
  left: 0;
  color: rgba(104,31,45,.62);
  font-family: var(--hand);
}

.resume-lower-grid {
  display: grid;
  grid-template-columns: 1.25fr .85fr;
  gap: 1.4rem;
}

.resume-lower-grid .resume-card:nth-child(1) {
  grid-row: span 2;
  --resume-r: -1deg;
}

.resume-lower-grid .resume-card:nth-child(2) {
  --resume-r: 1.2deg;
}

.resume-lower-grid .resume-card:nth-child(3) {
  --resume-r: -.7deg;
}

.resume-list {
  display: grid;
  gap: 1rem;
}

.resume-list article {
  padding-top: .85rem;
  border-top: 1px dashed rgba(42,23,18,.14);
}

.resume-list article:first-child {
  padding-top: 0;
  border-top: 0;
}

.resume-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.resume-tags li {
  padding: .55rem .72rem;
  border: 1px dashed rgba(42,23,18,.18);
  border-radius: 999px;
  background: rgba(251,242,223,.72);
  color: rgba(42,23,18,.64);
  font: 11px var(--mono);
}

.resume-languages {
  margin: 0;
  color: rgba(42,23,18,.72);
  font: 700 1.3rem / 1.15 var(--hand);
}

.resume-paper-one {
  left: -5%;
  top: 13%;
  width: min(380px, 44vw);
  height: 420px;
  transform: rotate(-7deg);
}

.resume-paper-two {
  right: -5%;
  bottom: 6%;
  width: min(460px, 50vw);
  height: 460px;
  transform: rotate(5deg);
}

.resume-heart { left: 1%; top: 9%; font-size: 3rem; transform: rotate(-13deg); }
.resume-star { right: 6%; top: 17%; font-size: 2rem; color: rgba(139,143,95,.72); animation-delay: -2s; }
.resume-arrow { left: 51%; bottom: 1%; font-size: 1.8rem; transform: rotate(10deg); animation-delay: -4s; }

.reveal { opacity: 0; transform: translateY(20px); transition: opacity .55s ease, transform .55s ease; }
.reveal.in-view { opacity: 1; transform: translateY(0); }
.float-card.reveal { transform: rotate(var(--r)) translateY(20px); }
.float-card.reveal.in-view { transform: rotate(var(--r)) translateY(0); }
.hanging-badge.reveal { transform: rotate(var(--r)) translateY(20px); }
.hanging-badge.reveal.in-view { transform: rotate(var(--r)) translateY(0); }
.project-card.reveal {
  transform: translate3d(var(--px, 0), calc(var(--py, 0) + 20px + var(--lift, 0px)), 0) rotate(var(--r, 0)) scale(calc(var(--s, 1) * var(--mag, 1)));
}
.project-card.reveal.in-view {
  transform: translate3d(var(--px, 0), calc(var(--py, 0) + var(--lift, 0px)), 0) rotate(var(--r, 0)) scale(calc(var(--s, 1) * var(--mag, 1)));
}
.project-card.reveal.in-view:hover {
  transform: translate3d(var(--px, 0), calc(var(--py, 0) + var(--lift, 0px)), 0) rotate(var(--r, 0)) scale(calc(var(--s, 1) * var(--mag, 1)));
}
.work .reveal,
.work .reveal.in-view {
  opacity: 1;
}
.work .project-card,
.work .project-card.reveal,
.work .project-card.reveal.in-view {
  --lift: 0px;
  --mag: 1;
  transform: translate3d(var(--px, 0), calc(var(--py, 0) + var(--lift, 0px)), 0) rotate(var(--r, 0)) scale(calc(var(--s, 1) * var(--mag, 1)));
}
.work .project-card:hover,
.work .project-card.reveal.in-view:hover {
  --lift: -6px;
  --mag: 1;
  transform: translate3d(var(--px, 0), calc(var(--py, 0) + var(--lift, 0px)), 0) rotate(var(--r, 0)) scale(calc(var(--s, 1) * var(--mag, 1)));
}
.work .project-card.is-near,
.work .project-card.is-dimmed {
  opacity: 1;
  filter: none;
}
.ticket-card.reveal {
  opacity: 1;
  transform: translate3d(0, -50%, 0) rotate(-4deg);
  transition:
    opacity .24s ease,
    right .58s cubic-bezier(.18, .92, .18, 1),
    transform .58s cubic-bezier(.18, .92, .18, 1),
    filter .42s ease;
}
.ticket-card.reveal.in-view {
  opacity: 1;
  transform: translate3d(0, -50%, 0) rotate(-4deg);
}
.ticket-card.reveal.in-view:hover {
  transform: translate3d(-10px, -52%, 0) rotate(-2deg) perspective(900px) rotateY(-5deg) rotateX(2deg);
}
.ticket-card.reveal.in-view.is-pulling {
  transform: translate3d(50%, -50%, 0) rotate(.7deg) perspective(1100px) rotateY(-9deg) scale(1.08);
}

@media (max-width: 900px) {
  .mobile-magic-popup {
    display: block;
  }

  .nav-links { display: none; }
  .about,
  .project-grid,
  .play-grid { grid-template-columns: 1fr; }
  .about-canvas {
    min-height: auto;
    padding: 3.4rem 1rem 2.4rem;
    display: grid;
    gap: 1rem;
  }
  .about-book {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: min(100%, 420px);
    justify-self: center;
    transform: none;
  }
  .about-thisisme {
    position: relative;
    left: auto;
    top: auto;
    width: min(190px, 52vw);
    justify-self: center;
    transform: none;
  }
  .about-love-note {
    position: relative;
    right: auto;
    top: auto;
    width: 100%;
    max-width: 360px;
    justify-self: center;
    transform: none;
  }
  .about-browser,
  .about-wireframe {
    transform: scale(.82) rotate(var(--mobile-r, 0deg));
  }
  .about-browser,
  .about-wireframe,
  .about-coffee,
  .about-coffee-two,
  .about-clip,
  .about-clip-one,
  .about-doodle,
  .paw-trail,
  .about-cat-gif,
  .doodle-calm {
    display: none;
  }
  .doodle-arrow {
    left: 42%;
    bottom: 10%;
  }
  .hero {
    min-height: auto;
    padding: 5rem 0 2.5rem;
  }
  .hero-center {
    width: min(92vw, 420px);
    padding: 1.2rem 1rem .4rem;
  }
  .hero-logo {
    width: min(260px, 70vw);
  }
  .hero-right {
    position: relative;
    inset: auto;
    width: min(92vw, 520px);
    padding: 1rem;
    border-left: 0;
    display: grid;
    gap: 1rem;
  }
  .hero-illus,
  .fun-bit,
  .coffee-stain,
  .paperclip,
  .loading-note,
  .desk-arrow,
  .sticker-card,
  .diary-card {
    display: none;
  }
  .hero-bottom {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    width: min(92vw, 520px);
    margin: 0 auto 1rem;
    border-radius: 22px;
  }
  .float-card {
    position: relative;
    inset: auto !important;
    left: auto !important;
    top: auto !important;
    width: 100%;
    transform: none !important;
  }
  .ticket-card {
    position: relative;
    right: auto;
    top: auto;
    justify-self: end;
    width: min(230px, 66vw);
    margin: -.4rem -4.2rem 0 0;
    transform: rotate(-4deg) !important;
    animation: none;
  }
  .ticket-card:hover {
    right: auto;
    transform: translate3d(-8px, 0, 0) rotate(-2deg) !important;
  }
  .ticket-card.is-pulling,
  .ticket-card.reveal.in-view.is-pulling {
    right: auto;
    transform: rotate(-1deg) scale(1.03) !important;
  }
  .ticket-panel {
    width: min(92vw, 520px);
  }
  .ticket-panel-image {
    transform: rotate(-2deg);
  }
  .hanging-badge {
    width: 100%;
    animation: none;
  }
  .playlist-card {
    grid-template-columns: auto 1fr auto;
    width: 100%;
    padding: .8rem;
  }
  .record-player {
    width: 72px;
  }
  .record {
    width: 66px;
    animation: none;
  }
  .sound-bars {
    display: none;
  }
  .playlist-toggle {
    grid-column: 3;
    grid-row: 1;
    justify-self: end;
  }
  .badge-background-quote {
    display: none;
  }
  .journey-button {
    position: relative;
    left: auto;
    top: auto;
    justify-self: start;
    width: fit-content;
    margin: .1rem 0 .4rem;
    transform: rotate(2deg);
  }
  .badge-nail,
  .badge-string { display: none; }
  .doodle { display: none; }
  .section-heading { display: grid; justify-content: start; }
}

@media (max-width: 760px) {
  .privacy-nav,
  .privacy-actions,
  .privacy-footer .footer-inner {
    align-items: stretch;
    flex-direction: column;
  }

  .privacy-nav {
    gap: .8rem;
  }

  .privacy-actions {
    gap: .55rem;
  }

  .privacy-back {
    justify-content: center;
    width: 100%;
  }

  .privacy-main {
    width: min(100% - 2rem, 620px);
    padding-top: 2.5rem;
  }

  .privacy-policy-stack {
    grid-template-columns: 1fr;
  }

  .privacy-section,
  .privacy-section:nth-child(2),
  .privacy-section:nth-child(4),
  .privacy-contact-card {
    margin-top: 0;
    min-height: auto;
    transform: none;
  }

  .privacy-paper,
  .privacy-doodle {
    display: none;
  }

  .resume-main {
    width: min(100% - 2rem, 680px);
    padding-top: 2.5rem;
  }

  .resume-contact,
  .resume-role,
  .resume-lower-grid {
    grid-template-columns: 1fr;
  }

  .resume-role > span {
    justify-self: start;
    text-align: left;
  }

  .resume-card,
  .resume-profile,
  .resume-experience,
  .resume-lower-grid .resume-card:nth-child(1),
  .resume-lower-grid .resume-card:nth-child(2),
  .resume-lower-grid .resume-card:nth-child(3) {
    transform: none;
  }

  .resume-paper-one,
  .resume-paper-two,
  .resume-heart,
  .resume-star,
  .resume-arrow {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    transition-duration: .01ms !important;
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
  }
  .paw-print,
  .board-canvas::before,
  .archive-glow,
  .archive-dust,
  .desktop-cursor,
  .desktop-popup,
  .desktop-music-widget i,
  .desktop-paw,
  .about-canvas:has(.paw-trail) .about-book,
  .about-canvas:has(.paw-trail) .about-wireframe,
  .about-canvas:has(.paw-trail) .about-browser {
    animation: none;
  }
  .desktop-paw {
    opacity: 0;
  }
  .paw-print {
    opacity: .18;
  }
  .hanging-badge {
    animation: none;
  }
  .ticket-card {
    animation: none;
    transition: opacity .2s ease;
  }
  .ticket-card.is-pulling {
    animation: none;
  }
  .ticket-backdrop,
  .ticket-panel {
    transition: opacity .2s ease;
  }
  .portfolio-loader,
  .loader-scene,
  .loader-film-grain,
  .loader-light,
  .loader-tab,
  .loader-note,
  .loader-photo,
  .loader-type,
  .loader-glow,
  .loader-fragment,
  .loader-transition-ripple,
  .cat-loader-scene,
  .cat-loader-glow,
  .loader-cat,
  .loader-cat-gif,
  .cat-tail,
  .cat-head,
  .cat-ear,
  .cat-eye,
  .cat-paw-front,
  .coffee-pour,
  .coffee-mug,
  .coffee-surface,
  .coffee-stream,
  .coffee-surface i,
  .steam,
  .loader-dust span {
    animation: none;
  }
  .case-window,
  .project-card,
  .folder-icon,
  .desktop-folder strong {
    transition: none;
  }
}
