:root {
  --paper: #f9f6e7;
  --ink: #0f1131;
  --royal: #2241d8;
  --hot: #ff3a7a;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: "VT323", monospace;
  color: var(--ink);
  background:
    radial-gradient(circle at 15% 20%, #ffffffa0 0 3%, transparent 4%),
    radial-gradient(circle at 80% 10%, #8dd9ff 0 16%, transparent 17%),
    radial-gradient(circle at 20% 75%, #bbaaff 0 20%, transparent 21%),
    linear-gradient(160deg, #9ad5ff 0%, #9e80ff 45%, #ffe5f2 100%);
  min-height: 100vh;
  padding-bottom: 2rem;
  overflow-x: hidden;
}

.waterfall-bg {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 0;
  background-image: url("assets/waterfall-shiny.svg");
  background-size: cover;
  background-position: center;
  opacity: 0.38;
  filter: saturate(1.2) contrast(1.05);
}

.scanlines {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 1;
  background: repeating-linear-gradient(
    to bottom,
    transparent,
    transparent 2px,
    rgba(5, 16, 44, 0.06) 3px,
    rgba(5, 16, 44, 0.06) 4px
  );
  mix-blend-mode: multiply;
}

.pixel-overlay {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 2;
  background-image:
    repeating-linear-gradient(to right, rgba(255, 255, 255, 0.06) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(to bottom, rgba(36, 74, 171, 0.07) 0 1px, transparent 1px 4px);
  mix-blend-mode: soft-light;
}

.sparkles {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 3;
  background-image:
    radial-gradient(circle at 10% 20%, rgba(255, 255, 255, 0.95) 0 1.2px, transparent 2.5px),
    radial-gradient(circle at 78% 28%, rgba(255, 210, 255, 0.92) 0 1.8px, transparent 2.7px),
    radial-gradient(circle at 56% 68%, rgba(198, 253, 255, 0.94) 0 1.5px, transparent 2.4px),
    radial-gradient(circle at 26% 54%, rgba(255, 255, 255, 0.9) 0 1.4px, transparent 2.2px),
    radial-gradient(circle at 90% 82%, rgba(255, 223, 247, 0.95) 0 1.6px, transparent 2.5px);
  animation: twinkle 1.9s ease-in-out infinite alternate;
}

.bubbles {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 3;
}

.bubble {
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(255, 220, 255, 0.72);
  background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.84), rgba(255, 151, 238, 0.14));
  box-shadow: inset -3px -3px 8px rgba(103, 149, 255, 0.2), 0 0 12px rgba(255, 86, 214, 0.22);
  animation: drift 11s linear infinite;
}

.b1 { width: 22px; height: 22px; left: 8%; top: 70%; animation-duration: 10s; }
.b2 { width: 36px; height: 36px; left: 82%; top: 74%; animation-duration: 14s; }
.b3 { width: 18px; height: 18px; left: 46%; top: 82%; animation-duration: 12s; }
.b4 { width: 28px; height: 28px; left: 66%; top: 88%; animation-duration: 15s; }
.b5 { width: 32px; height: 32px; left: 24%; top: 78%; animation-duration: 13s; }

.stickers {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 4;
}

.heart {
  --rot: -45deg;
  --s: 1;
  position: absolute;
  width: 24px;
  height: 24px;
  transform: rotate(var(--rot)) scale(var(--s));
  background: linear-gradient(145deg, #ff89df, #ff3cb8);
  box-shadow: 0 0 12px rgba(255, 81, 194, 0.5);
  animation: heartFloat 6s ease-in-out infinite;
}

.heart::before,
.heart::after {
  content: "";
  position: absolute;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: inherit;
}

.heart::before { top: -12px; left: 0; }
.heart::after { top: 0; left: 12px; }

.heart-a { left: 9%; top: 26%; animation-delay: 0s; }
.heart-b { left: 87%; top: 31%; animation-delay: 1.1s; --s: 0.8; }
.heart-c { left: 76%; top: 71%; animation-delay: 2.2s; --s: 1.15; }

.shell {
  --s: 1;
  position: absolute;
  width: 38px;
  height: 28px;
  border-radius: 50% 50% 40% 40%;
  background: repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.35) 0 2px, rgba(255, 178, 225, 0.8) 2px 6px);
  border: 1px solid rgba(255, 238, 247, 0.95);
  box-shadow: 0 0 10px rgba(255, 176, 230, 0.45);
  transform: scale(var(--s));
  animation: shellFloat 7.4s ease-in-out infinite;
}

.shell::before {
  content: "";
  position: absolute;
  inset: 4px 5px 8px;
  border-radius: 50%;
  border-top: 1px solid rgba(255, 255, 255, 0.85);
}

.shell-a { left: 14%; top: 76%; }
.shell-b { left: 82%; top: 18%; --s: 0.92; animation-delay: 2.6s; }

.topbar {
  position: relative;
  z-index: 10;
  font-family: "Press Start 2P", cursive;
  font-size: 0.65rem;
  color: #001f66;
  background: linear-gradient(90deg, #edffe9, #d9ecff, #ffe0f4);
  border-bottom: 3px ridge #fff;
  padding: 0.4rem 0;
}

.desktop-wrap {
  position: relative;
  z-index: 6;
  max-width: 1120px;
  margin: 1rem auto;
  padding: 0 1rem;
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 1rem;
}

.window {
  background: var(--paper);
  border: 3px solid #fefefe;
  box-shadow: 0 0 0 2px #5877ff, 6px 6px 0 #222f8a;
  padding: 0.8rem;
}

.window h1,
.window h2 {
  margin: 0 0 0.5rem;
  font-family: "Press Start 2P", cursive;
  letter-spacing: 0.02em;
}

.window h1 {
  font-size: 1rem;
  line-height: 1.4;
}

.window h2 {
  font-size: 0.75rem;
}

.profile-window {
  grid-row: span 2;
}

.tag {
  color: var(--royal);
  font-size: 1.6rem;
  margin: 0.2rem 0 0.4rem;
}

.bio {
  font-size: 1.4rem;
  line-height: 1.18;
}

.tiny {
  font-size: 1.2rem;
  color: #373a77;
}

.blinkies {
  margin-top: 1rem;
  display: grid;
  gap: 0.35rem;
  font-size: 1.2rem;
}

.blink {
  animation: blink 0.8s steps(2, jump-none) infinite;
  color: var(--hot);
  font-weight: bold;
}

.counter {
  display: inline-block;
  background: #111;
  color: #7dff8f;
  letter-spacing: 0.08em;
  width: fit-content;
  padding: 0 0.4rem;
}

.folder-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 0.9rem;
}

.folder {
  background: transparent;
  border: 0;
  color: var(--ink);
  font: inherit;
  text-align: center;
  cursor: pointer;
  padding: 0.2rem;
}

.folder:focus-visible {
  outline: 2px dashed #1520cc;
  outline-offset: 3px;
}

.folder-icon {
  width: 100px;
  height: 100px;
  margin: 0 auto 0.45rem;
  display: grid;
  place-items: center;
}

.folder-shell {
  width: 100%;
  height: 100%;
  object-fit: contain;
  image-rendering: pixelated;
  filter: saturate(1.25) contrast(1.08) drop-shadow(0 0 9px rgba(255, 96, 214, 0.42));
}

.folder-name {
  font-size: 1.2rem;
  line-height: 1.04;
  max-width: 150px;
  margin: 0 auto;
}

.folder:hover .folder-shell {
  transform: translateY(-5px) rotate(-2deg);
}

.details-window {
  min-height: 560px;
  grid-row: span 2;
}

#projectMeta {
  margin-top: 0;
  font-size: 1.35rem;
  color: #1b2784;
}

#projectDesc {
  font-size: 1.38rem;
  line-height: 1.14;
}

.project-bullets {
  margin: 0;
  padding-left: 1.2rem;
  font-size: 1.28rem;
  line-height: 1.08;
}

.project-links {
  font-size: 1.24rem;
  margin-top: 0.8rem;
}

.project-links a {
  color: #001f9a;
  font-weight: bold;
}

.project-media {
  margin-top: 0.8rem;
}

.spells-intro {
  margin: 0 0 0.5rem;
  font-size: 1.2rem;
}

.spells-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 0.7rem;
}

.spell-card {
  border: 3px solid #fff;
  box-shadow: 0 0 0 2px #5877ff;
  background: #f4ecff;
  min-height: 130px;
  overflow: hidden;
}

.spell-card img,
.spell-card video {
  width: 100%;
  height: 100%;
  min-height: 130px;
  object-fit: cover;
  display: block;
}

.empty-spells {
  border: 2px dashed #5d6ec0;
  background: #eff4ff;
  padding: 0.7rem;
  font-size: 1.1rem;
}

.footer {
  position: relative;
  z-index: 6;
  max-width: 1120px;
  margin: 1rem auto 0;
  padding: 0 1rem;
  font-size: 1.1rem;
  color: #0b1247;
  text-shadow: 0 0 6px rgba(255, 129, 220, 0.35);
}

@keyframes blink {
  50% { opacity: 0; }
}

@keyframes twinkle {
  from { opacity: 0.5; }
  to { opacity: 1; }
}

@keyframes drift {
  0% { transform: translateY(0); opacity: 0.85; }
  100% { transform: translateY(-115vh); opacity: 0.1; }
}

@keyframes heartFloat {
  0% { transform: translateY(0) rotate(var(--rot)) scale(var(--s)); }
  50% { transform: translateY(-8px) rotate(calc(var(--rot) + 4deg)) scale(var(--s)); }
  100% { transform: translateY(0) rotate(var(--rot)) scale(var(--s)); }
}

@keyframes shellFloat {
  0% { transform: translateY(0) scale(var(--s)); }
  50% { transform: translateY(-7px) scale(var(--s)); }
  100% { transform: translateY(0) scale(var(--s)); }
}

@media (max-width: 860px) {
  .desktop-wrap {
    grid-template-columns: 1fr;
  }

  .profile-window,
  .details-window {
    grid-row: auto;
  }

  .details-window {
    min-height: 420px;
  }

  .folder-grid {
    grid-template-columns: repeat(auto-fill, minmax(128px, 1fr));
  }

  .folder-icon {
    width: 84px;
    height: 84px;
  }

  .spells-grid {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  }
}
