:root {
  box-sizing: border-box;
  color-scheme: dark;
  --bg: #05070d;
  --ink: #fff8e8;
  --muted: rgba(255, 248, 232, 0.62);
  --line: rgba(255, 255, 255, 0.14);
  --cyan: #62d9ff;
  --amber: #ffb45f;
  --rose: #ff6f91;
  --violet: #a78bfa;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

html,
body {
  width: 100%;
  min-width: 320px;
  min-height: 100%;
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

body {
  overflow-x: hidden;
}

::selection {
  background: var(--amber);
  color: #07080f;
}

.launcher {
  position: relative;
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 4vw, 3rem);
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(circle at 10% 10%, color-mix(in srgb, var(--cyan) 24%, transparent), transparent 26rem),
    radial-gradient(circle at 92% 16%, color-mix(in srgb, var(--amber) 20%, transparent), transparent 24rem),
    radial-gradient(circle at 48% 92%, color-mix(in srgb, var(--violet) 22%, transparent), transparent 30rem),
    linear-gradient(135deg, #05070d 0%, #0a1020 42%, #080912 100%);
}

.launcher::before,
.launcher::after {
  content: "";
  position: absolute;
  inset: -20%;
  z-index: -2;
  pointer-events: none;
}

.launcher::before {
  background:
    conic-gradient(from 60deg at 28% 38%, transparent 0 16%, color-mix(in srgb, var(--cyan) 19%, transparent) 20%, transparent 28% 48%, color-mix(in srgb, var(--rose) 16%, transparent) 55%, transparent 64% 100%),
    conic-gradient(from 220deg at 72% 54%, transparent 0 18%, color-mix(in srgb, var(--violet) 16%, transparent) 24%, transparent 34% 58%, color-mix(in srgb, var(--amber) 14%, transparent) 66%, transparent 76% 100%);
  filter: blur(24px);
  animation: orbit 24s linear infinite;
}

.launcher::after {
  z-index: -1;
  background:
    linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px),
    radial-gradient(circle at center, transparent 0 34%, rgba(5, 7, 13, 0.72) 82%);
  background-size: 58px 58px, 58px 58px, auto;
  mask-image: linear-gradient(to bottom, transparent, black 18%, black 84%, transparent);
}

.ambient {
  position: absolute;
  width: min(58vw, 38rem);
  aspect-ratio: 1;
  border-radius: 999px;
  pointer-events: none;
  opacity: 0.55;
  filter: blur(18px);
  mix-blend-mode: screen;
}

.ambient-one {
  top: -14rem;
  left: -10rem;
  background: radial-gradient(circle, color-mix(in srgb, var(--cyan) 68%, transparent), transparent 64%);
  animation: driftOne 16s ease-in-out infinite alternate;
}

.ambient-two {
  right: -13rem;
  bottom: -10rem;
  background: radial-gradient(circle, color-mix(in srgb, var(--amber) 58%, transparent), transparent 66%);
  animation: driftTwo 18s ease-in-out infinite alternate;
}

.ambient-three {
  left: 35%;
  bottom: -17rem;
  background: radial-gradient(circle, color-mix(in srgb, var(--violet) 54%, transparent), transparent 68%);
  animation: driftThree 20s ease-in-out infinite alternate;
}

.surface {
  width: min(100%, 68rem);
  min-width: 0;
  position: relative;
  padding: clamp(1rem, 2.4vw, 1.6rem);
  border: 1px solid var(--line);
  border-radius: 0.5rem;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.025)),
    rgba(5, 8, 15, 0.72);
  box-shadow:
    0 1.5rem 4rem rgba(0, 0, 0, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(18px) saturate(130%);
}

.surface::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background:
    linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.16), transparent),
    linear-gradient(to bottom, rgba(255, 255, 255, 0.07), transparent 22%);
  opacity: 0.55;
  animation: sheen 7s ease-in-out infinite;
}

.brand {
  position: relative;
  display: flex;
  justify-content: center;
  width: fit-content;
  margin: 0 auto clamp(1rem, 2vw, 1.35rem);
  padding-bottom: 0.34rem;
  color: rgba(255, 248, 232, 0.72);
  font-size: clamp(0.95rem, 1.5vw, 1.1rem);
  font-weight: 700;
  letter-spacing: 0;
  text-shadow: 0 0 1rem rgba(98, 217, 255, 0.08);
}

.brand-space {
  width: 0.35em;
}

.brand::before,
.brand::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  pointer-events: none;
}

.brand::before {
  background: linear-gradient(90deg, transparent, rgba(255, 248, 232, 0.28), transparent);
}

.brand::after {
  width: 42%;
  right: auto;
  background: linear-gradient(90deg, transparent, var(--cyan), var(--violet), transparent);
  filter: drop-shadow(0 0 0.4rem color-mix(in srgb, var(--cyan) 50%, transparent));
  opacity: 0.72;
  animation: brandGlide 5.8s ease-in-out infinite;
}

.project-links {
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(0.75rem, 1.6vw, 1.15rem);
}

.project-link {
  --accent: var(--cyan);
  --accent-two: color-mix(in srgb, var(--accent) 72%, white 16%);
  --plasma-base:
    radial-gradient(circle at 22% 18%, color-mix(in srgb, var(--accent) 48%, transparent), transparent 30%),
    radial-gradient(circle at 78% 82%, color-mix(in srgb, var(--accent-two) 36%, transparent), transparent 34%);
  --plasma-layer:
    conic-gradient(from 20deg, transparent 0 18%, color-mix(in srgb, var(--accent) 58%, transparent) 26%, transparent 36% 58%, color-mix(in srgb, var(--accent-two) 48%, transparent) 66%, transparent 78% 100%);
  --plasma-animation: plasmaOrbit 12s linear infinite;
  --plasma-opacity: 0.44;
  position: relative;
  min-width: 0;
  min-height: clamp(7rem, 15vw, 10.5rem);
  display: grid;
  grid-template-rows: auto 1fr auto;
  align-items: stretch;
  padding: clamp(1rem, 2vw, 1.35rem);
  overflow: hidden;
  isolation: isolate;
  color: var(--ink);
  text-decoration: none;
  border: 1px solid color-mix(in srgb, var(--accent) 52%, white 10%);
  border-radius: 0.45rem;
  background:
    var(--plasma-base),
    linear-gradient(150deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.02));
  box-shadow:
    0 1rem 2.2rem rgba(0, 0, 0, 0.28),
    inset 0 0 0 1px rgba(255, 255, 255, 0.05);
  transform: translateZ(0);
  transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

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

.project-link::before {
  inset: -45%;
  background: var(--plasma-layer);
  opacity: var(--plasma-opacity);
  animation: var(--plasma-animation);
  filter: blur(0.25rem) saturate(135%);
  z-index: 0;
}

.project-link::after {
  inset: auto 0 0;
  height: 0.35rem;
  background: linear-gradient(90deg, var(--accent), var(--accent-two));
  box-shadow: 0 0 1.5rem var(--accent);
  z-index: 2;
}

.project-icon,
.project-name {
  position: relative;
  z-index: 1;
}

.project-icon {
  width: clamp(2.45rem, 4.2vw, 3.55rem);
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  justify-self: start;
  align-self: start;
  color: var(--accent-two);
  border: 1px solid color-mix(in srgb, var(--accent) 38%, white 12%);
  border-radius: 0.42rem;
  background:
    radial-gradient(circle at 35% 28%, rgba(255, 255, 255, 0.13), transparent 38%),
    color-mix(in srgb, var(--bg) 72%, var(--accent) 18%);
  box-shadow:
    0.28rem 0.48rem 0.75rem rgba(0, 0, 0, 0.48),
    0 1rem 1.9rem rgba(0, 0, 0, 0.3),
    0 0 1.3rem color-mix(in srgb, var(--accent) 24%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.13);
}

.project-icon svg {
  width: 68%;
  height: 68%;
  fill: none;
  stroke: currentColor;
  stroke-width: 3.6;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter:
    drop-shadow(0.16rem 0.22rem 0.18rem rgba(0, 0, 0, 0.58))
    drop-shadow(0 0 0.42rem color-mix(in srgb, var(--accent) 44%, transparent));
}

.project-name {
  justify-self: end;
  align-self: end;
  min-width: 0;
  text-align: right;
  font-size: clamp(1.55rem, 3.45vw, 2.95rem);
  font-weight: 850;
  line-height: 0.94;
  letter-spacing: 0;
  text-shadow: 0 0.22rem 1.1rem rgba(0, 0, 0, 0.48);
}

.project-link:hover,
.project-link:focus-visible {
  transform: translateY(-0.22rem);
  border-color: color-mix(in srgb, var(--accent) 88%, white 12%);
  box-shadow:
    0 1.4rem 3.2rem rgba(0, 0, 0, 0.36),
    0 0 2rem color-mix(in srgb, var(--accent) 36%, transparent),
    inset 0 0 0 1px rgba(255, 255, 255, 0.1);
  outline: none;
}

.project-link:hover::before,
.project-link:focus-visible::before {
  opacity: 0.7;
}

.minerals {
  --accent: var(--cyan);
  --accent-two: color-mix(in srgb, var(--cyan) 72%, white 16%);
  --plasma-base:
    radial-gradient(ellipse at 12% 22%, color-mix(in srgb, var(--accent) 48%, transparent), transparent 30%),
    radial-gradient(ellipse at 82% 74%, color-mix(in srgb, var(--accent-two) 30%, transparent), transparent 36%),
    linear-gradient(115deg, color-mix(in srgb, var(--accent) 16%, transparent), transparent 58%);
  --plasma-layer:
    conic-gradient(from 10deg at 32% 44%, transparent 0 14%, color-mix(in srgb, var(--accent) 62%, transparent) 22%, transparent 34% 58%, color-mix(in srgb, var(--accent-two) 38%, transparent) 68%, transparent 82% 100%);
  --plasma-animation: plasmaOrbit 13s linear infinite;
}

.braintris {
  --accent: var(--amber);
  --accent-two: color-mix(in srgb, var(--amber) 74%, white 14%);
  --plasma-base:
    radial-gradient(ellipse at 18% 30%, color-mix(in srgb, var(--accent) 48%, transparent), transparent 28%),
    radial-gradient(ellipse at 70% 18%, color-mix(in srgb, var(--accent-two) 36%, transparent), transparent 30%),
    radial-gradient(ellipse at 82% 82%, color-mix(in srgb, var(--accent) 28%, transparent), transparent 38%),
    conic-gradient(from 120deg at 42% 54%, transparent 0 24%, color-mix(in srgb, var(--accent-two) 18%, transparent) 38%, transparent 54% 100%);
  --plasma-layer:
    radial-gradient(ellipse at 35% 42%, color-mix(in srgb, var(--accent) 52%, transparent), transparent 28%),
    conic-gradient(from 45deg at 58% 50%, transparent 0 16%, color-mix(in srgb, var(--accent-two) 42%, transparent) 30%, transparent 46% 70%, color-mix(in srgb, var(--accent) 36%, transparent) 84%, transparent 100%);
  --plasma-animation: plasmaSlide 9s ease-in-out infinite alternate;
}

.wordtag {
  --accent: var(--violet);
  --accent-two: var(--cyan);
  --plasma-base:
    radial-gradient(circle at 18% 16%, color-mix(in srgb, var(--accent-two) 32%, transparent), transparent 26%),
    radial-gradient(circle at 84% 26%, color-mix(in srgb, var(--accent) 34%, transparent), transparent 24%),
    radial-gradient(ellipse at 48% 92%, color-mix(in srgb, var(--accent) 26%, transparent), transparent 42%);
  --plasma-layer:
    repeating-radial-gradient(ellipse at 42% 46%, color-mix(in srgb, var(--accent) 34%, transparent) 0 0.7rem, transparent 0.7rem 1.8rem),
    conic-gradient(from 170deg, transparent 0 30%, color-mix(in srgb, var(--accent-two) 34%, transparent) 42%, transparent 54% 100%);
  --plasma-animation: plasmaPulse 10s ease-in-out infinite;
}

.bricks {
  --accent: var(--rose);
  --accent-two: var(--amber);
  --plasma-base:
    linear-gradient(32deg, color-mix(in srgb, var(--accent) 32%, transparent), transparent 36%),
    radial-gradient(circle at 18% 18%, color-mix(in srgb, var(--accent-two) 30%, transparent), transparent 28%),
    radial-gradient(circle at 74% 78%, color-mix(in srgb, var(--accent) 30%, transparent), transparent 38%);
  --plasma-layer:
    repeating-linear-gradient(135deg, transparent 0 1.1rem, color-mix(in srgb, var(--accent) 30%, transparent) 1.1rem 1.55rem, transparent 1.55rem 2.6rem),
    conic-gradient(from 260deg at 60% 54%, transparent 0 22%, color-mix(in srgb, var(--accent-two) 38%, transparent) 34%, transparent 48% 100%);
  --plasma-animation: plasmaShear 11s ease-in-out infinite alternate;
}

.booker {
  --accent: var(--cyan);
  --accent-two: var(--violet);
  --plasma-base:
    radial-gradient(ellipse at 20% 26%, color-mix(in srgb, var(--accent) 34%, transparent), transparent 34%),
    radial-gradient(ellipse at 76% 72%, color-mix(in srgb, var(--accent-two) 24%, transparent), transparent 42%),
    linear-gradient(160deg, transparent, color-mix(in srgb, var(--accent) 14%, transparent));
  --plasma-layer:
    conic-gradient(from 95deg at 28% 66%, transparent 0 20%, color-mix(in srgb, var(--accent) 38%, transparent) 32%, transparent 46% 70%, color-mix(in srgb, var(--accent-two) 30%, transparent) 82%, transparent 100%);
  --plasma-animation: plasmaBloom 12s ease-in-out infinite;
}

.szondi {
  --accent: var(--violet);
  --accent-two: var(--rose);
  --plasma-base:
    radial-gradient(circle at 22% 18%, color-mix(in srgb, var(--accent-two) 30%, transparent), transparent 30%),
    radial-gradient(circle at 78% 72%, color-mix(in srgb, var(--accent) 36%, transparent), transparent 38%),
    linear-gradient(45deg, color-mix(in srgb, var(--accent) 16%, transparent), transparent 54%);
  --plasma-layer:
    conic-gradient(from 300deg at 50% 50%, color-mix(in srgb, var(--accent) 36%, transparent), transparent 18% 34%, color-mix(in srgb, var(--accent-two) 34%, transparent) 48%, transparent 64% 82%, color-mix(in srgb, var(--accent) 28%, transparent));
  --plasma-animation: plasmaTwist 14s ease-in-out infinite;
}

@keyframes orbit {
  from {
    transform: rotate(0deg) scale(1);
  }

  to {
    transform: rotate(360deg) scale(1.08);
  }
}

@keyframes driftOne {
  from {
    transform: translate3d(0, 0, 0) scale(1);
  }

  to {
    transform: translate3d(18vw, 18vh, 0) scale(1.25);
  }
}

@keyframes driftTwo {
  from {
    transform: translate3d(0, 0, 0) scale(1);
  }

  to {
    transform: translate3d(-16vw, -14vh, 0) scale(1.16);
  }
}

@keyframes driftThree {
  from {
    transform: translate3d(-8vw, 0, 0) scale(1);
  }

  to {
    transform: translate3d(10vw, -18vh, 0) scale(1.22);
  }
}

@keyframes sheen {
  0%,
  100% {
    transform: translateX(-28%);
    opacity: 0.34;
  }

  45% {
    transform: translateX(28%);
    opacity: 0.68;
  }
}

@keyframes brandGlide {
  0%,
  100% {
    transform: translateX(0);
    opacity: 0.42;
  }

  45% {
    transform: translateX(138%);
    opacity: 0.78;
  }
}

@keyframes plasmaOrbit {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes plasmaSlide {
  from {
    transform: translate3d(-12%, -5%, 0) scale(1.05);
  }

  to {
    transform: translate3d(12%, 7%, 0) scale(1.18);
  }
}

@keyframes plasmaPulse {
  0%,
  100% {
    transform: scale(0.92) rotate(-8deg);
    opacity: 0.34;
  }

  50% {
    transform: scale(1.22) rotate(10deg);
    opacity: 0.64;
  }
}

@keyframes plasmaShear {
  from {
    transform: translate3d(-9%, 8%, 0) skewX(-8deg) scale(1.05);
  }

  to {
    transform: translate3d(11%, -6%, 0) skewX(8deg) scale(1.16);
  }
}

@keyframes plasmaBloom {
  0%,
  100% {
    transform: scale(0.95) rotate(14deg);
    filter: blur(0.35rem) saturate(120%);
  }

  50% {
    transform: scale(1.24) rotate(-10deg);
    filter: blur(0.15rem) saturate(170%);
  }
}

@keyframes plasmaTwist {
  0%,
  100% {
    transform: rotate(-18deg) scale(1);
  }

  45% {
    transform: rotate(20deg) scale(1.18);
  }
}

@media (max-width: 900px) {
  .project-links {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 580px) {
  .launcher {
    align-items: stretch;
    padding: 0.85rem;
  }

  .surface {
    align-self: center;
    width: 100%;
    max-width: 100%;
    padding: 0.85rem;
  }

  .project-links {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.7rem;
  }

  .project-link {
    width: 100%;
    min-height: 5.6rem;
    grid-template-columns: clamp(2.6rem, 13vw, 3.5rem) minmax(0, 1fr);
    grid-template-rows: 1fr;
    align-items: center;
    gap: 0.65rem;
    padding: 0.82rem 0.9rem;
  }

  .project-icon {
    width: clamp(2.6rem, 13vw, 3.5rem);
    align-self: center;
    transform: translateY(-0.18rem);
  }

  .project-name {
    justify-self: end;
    align-self: center;
    text-align: right;
    font-size: clamp(1.16rem, 6.35vw, 2rem);
    transform: translateY(-0.18rem);
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }
}
