:root {
  --bg-1: #0a0015;
  --bg-2: #1a0030;
  --panel: #0d0d2b;
  --panel-edge: #ff00ff;
  --text-main: #e0e0ff;
  --text-muted: #8888cc;
  --accent: #ffdb2e;
  --accent-2: #ff7a18;
  --link: #00ffff;
  --link-hover: #ff00ff;
  --neon-pink: #ff00ff;
  --neon-cyan: #00ffff;
  --neon-green: #39ff14;
  --neon-yellow: #ffff00;
  --neon-orange: #ff6600;
}

* {
  box-sizing: border-box;
}

/* ======================================
   STATIC GRADIENT BACKGROUND — sunset beach
   ====================================== */
body {
  margin: 0;
  min-height: 100vh;
  color: var(--text-main);
  font-family: "Courier New", Courier, monospace;
  line-height: 1.55;
  background: linear-gradient(
    180deg,
    #0b0a1a 0%,
    #141233 15%,
    #1a1445 30%,
    #2d1b4e 45%,
    #4a2050 55%,
    #6b2a4a 65%,
    #8a3a3f 75%,
    #b85a30 85%,
    #d4883a 93%,
    #e8b84a 100%
  );
  background-attachment: fixed;
  overflow-x: hidden;
}

/* ======================================
   SCANLINES OVERLAY
   ====================================== */
.scanlines {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 0;
  background: repeating-linear-gradient(
    0deg,
    rgba(0, 0, 0, 0.15) 0px,
    rgba(0, 0, 0, 0.15) 1px,
    transparent 1px,
    transparent 3px
  );
  animation: scanFlicker 0.1s infinite;
}

@keyframes scanFlicker {
  0%   { opacity: 0.8; }
  50%  { opacity: 0.85; }
  100% { opacity: 0.8; }
}

/* ======================================
   STARS / SPARKLE BACKGROUND
   ====================================== */
.stars {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 0;
  background-image:
    radial-gradient(1px 1px at 10% 20%, #fff 100%, transparent),
    radial-gradient(1px 1px at 30% 65%, #ff00ff 100%, transparent),
    radial-gradient(1.5px 1.5px at 50% 10%, #00ffff 100%, transparent),
    radial-gradient(1px 1px at 70% 80%, #fff 100%, transparent),
    radial-gradient(1px 1px at 85% 35%, #39ff14 100%, transparent),
    radial-gradient(1.5px 1.5px at 15% 90%, #ffff00 100%, transparent),
    radial-gradient(1px 1px at 60% 45%, #fff 100%, transparent),
    radial-gradient(1px 1px at 95% 60%, #ff00ff 100%, transparent),
    radial-gradient(1px 1px at 40% 30%, #00ffff 100%, transparent),
    radial-gradient(1.5px 1.5px at 25% 50%, #fff 100%, transparent);
  animation: starsTwinkle 3s ease-in-out infinite alternate;
}

@keyframes starsTwinkle {
  0%   { opacity: 0.4; }
  100% { opacity: 0.9; }
}

/* ======================================
   MAIN SHELL / PANEL
   ====================================== */
.site-shell {
  position: relative;
  z-index: 1;
  width: min(860px, calc(100% - 2rem));
  margin: 2rem auto 1rem;
  padding: 1.25rem;
  background: rgba(10, 10, 40, 0.92);
  border: 2px solid rgba(0, 255, 255, 0.25);
  box-shadow:
    0 0 15px rgba(0, 150, 180, 0.15),
    inset 0 0 20px rgba(0, 100, 140, 0.05);
  border-radius: 2px;
}

/* ======================================
   TERMINAL BAR
   ====================================== */
.terminal-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  margin: -1.25rem -1.25rem 1rem;
  background: #1a1a3a;
  border-bottom: 2px solid var(--neon-pink);
}

.dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
}

.dot.red {
  background: #ff3b30;
  box-shadow: 0 0 6px #ff3b30;
}

.dot.yellow {
  background: #ffcc00;
  box-shadow: 0 0 6px #ffcc00;
}

.dot.green {
  background: #39ff14;
  box-shadow: 0 0 6px #39ff14;
}

.terminal-title {
  margin-left: auto;
  font-size: 0.75rem;
  color: var(--text-muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* ======================================
   HEADINGS
   ====================================== */
h1,
h2 {
  margin: 0;
  line-height: 1.15;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

h1 {
  margin-top: 0.25rem;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  color: var(--neon-cyan);
  text-shadow:
    0 0 7px var(--neon-cyan),
    0 0 20px var(--neon-cyan),
    0 0 40px rgba(0, 255, 255, 0.4);
}

h2 {
  margin-top: 1.5rem;
  font-size: 1.1rem;
  color: var(--neon-green);
  border-bottom: 2px dashed var(--neon-green);
  padding-bottom: 0.3rem;
  text-shadow: 0 0 8px var(--neon-green);
}

.h2-icon {
  color: var(--neon-pink);
  margin-right: 0.3em;
}

p {
  margin: 0.5rem 0;
}

/* ======================================
   GLITCH EFFECT ON H1
   ====================================== */
.glitch {
  position: relative;
  animation: glitchShake 2.5s infinite;
}

.glitch::before,
.glitch::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.glitch::before {
  color: #ff00ff;
  text-shadow: 0 0 10px #ff00ff;
  animation: glitchLeft 1.5s infinite linear alternate-reverse;
  clip-path: inset(0 0 60% 0);
}

.glitch::after {
  color: #00ff00;
  text-shadow: 0 0 10px #00ff00;
  animation: glitchRight 2s infinite linear alternate-reverse;
  clip-path: inset(60% 0 0 0);
}

@keyframes glitchShake {
  0%, 95%, 100% { transform: translate(0); }
  96% { transform: translate(-3px, 1px); }
  97% { transform: translate(3px, -1px); }
  98% { transform: translate(-2px, -1px); }
  99% { transform: translate(2px, 1px); }
}

@keyframes glitchLeft {
  0%   { transform: translate(0); }
  20%  { transform: translate(-3px, 1px); }
  40%  { transform: translate(2px, -1px); }
  60%  { transform: translate(-1px, 2px); }
  80%  { transform: translate(3px, 0); }
  100% { transform: translate(0); }
}

@keyframes glitchRight {
  0%   { transform: translate(0); }
  25%  { transform: translate(2px, -2px); }
  50%  { transform: translate(-3px, 1px); }
  75%  { transform: translate(1px, 2px); }
  100% { transform: translate(0); }
}

/* ======================================
   TAGLINE & INTRO
   ====================================== */
.tagline {
  color: var(--neon-pink);
  font-size: 0.9rem;
  text-shadow: 0 0 8px rgba(255, 0, 255, 0.6);
  animation: tagPulse 2s ease-in-out infinite;
}

@keyframes tagPulse {
  0%, 100% { opacity: 0.7; }
  50%      { opacity: 1; }
}

.intro {
  max-width: 62ch;
  color: #c0c0e0;
}

.prompt {
  color: var(--neon-green);
  font-weight: bold;
  text-shadow: 0 0 6px var(--neon-green);
  margin-right: 0.3em;
}

/* ======================================
   BLINKING CURSOR
   ====================================== */
.blink-cursor {
  animation: blink 1s step-end infinite;
  color: var(--neon-green);
  text-shadow: 0 0 5px var(--neon-green);
}

@keyframes blink {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0; }
}

/* ======================================
   MARQUEE
   ====================================== */
.marquee-wrap {
  margin: 1.25rem -1.25rem;
  padding: 8px 0;
  overflow: hidden;
  background: linear-gradient(
    90deg,
    var(--neon-pink),
    var(--neon-cyan),
    var(--neon-green),
    var(--neon-yellow),
    var(--neon-orange),
    var(--neon-pink)
  );
  background-size: 200% 100%;
  animation: marqueeGradient 4s linear infinite;
}

@keyframes marqueeGradient {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

.marquee-track {
  display: flex;
  white-space: nowrap;
  animation: marqueeScroll 20s linear infinite;
}

.marquee-track span {
  font-size: 0.8rem;
  font-weight: 900;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #0a0015;
  padding: 0 1rem;
}

@keyframes marqueeScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ======================================
   INTEREST GRID
   ====================================== */
.section-note {
  color: var(--text-muted);
  font-size: 0.9rem;
}

.interest-grid {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 0.75rem;
}

.interest-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 0.5rem;
  text-align: center;
  text-decoration: none;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--neon-cyan);
  border: 1px solid rgba(0, 255, 255, 0.3);
  background: rgba(0, 255, 255, 0.04);
  transition: all 0.2s ease;
}

.interest-card img {
  width: 48px;
  height: 48px;
  object-fit: contain;
  image-rendering: pixelated;
}

.interest-card:hover {
  color: var(--neon-pink);
  border-color: var(--neon-pink);
  background: rgba(255, 0, 255, 0.08);
  box-shadow:
    0 0 10px rgba(255, 0, 255, 0.3),
    inset 0 0 10px rgba(255, 0, 255, 0.05);
  transform: translateY(-2px);
}

/* ======================================
   PIXEL SPRITES
   ====================================== */
.sprite {
  width: 8px;
  height: 8px;
  margin: 0 auto;
  image-rendering: pixelated;
}

.skateboard {
  background: #ccc;
  box-shadow:
    8px 0 #ccc,
    16px 0 #ccc,
    24px 0 #ccc,
    32px 0 #ccc,
    40px 0 #ccc,
    48px 8px #555,
    -8px 8px #555,
    8px 8px #ff5a1f,
    16px 8px #ff5a1f,
    24px 8px #ff5a1f,
    32px 8px #ff5a1f,
    40px 8px #ff5a1f,
    0 16px #ccc,
    40px 16px #ccc;
}

.wave {
  background: #4fb6ff;
  box-shadow:
    8px 0 #00ffff,
    16px 0 #4fb6ff,
    24px 0 #00ffff,
    -8px 8px #00ffff,
    0 8px #4fb6ff,
    8px 8px #00ffff,
    16px 8px #4fb6ff,
    24px 8px #00ffff,
    32px 8px #4fb6ff,
    -16px 16px #4fb6ff,
    -8px 16px #00ffff,
    0 16px #4fb6ff,
    8px 16px #00ffff,
    16px 16px #4fb6ff,
    24px 16px #00ffff,
    32px 16px #4fb6ff;
}

.hammer {
  background: #aaa;
  box-shadow:
    8px 0 #aaa,
    16px 0 #aaa,
    24px 0 #aaa,
    8px 8px #8b6914,
    8px 16px #8b6914,
    8px 24px #8b6914;
}

.tree {
  background: #39ff14;
  box-shadow:
    8px 0 #1d7a55,
    16px 0 #39ff14,
    -8px 8px #1d7a55,
    0 8px #39ff14,
    8px 8px #1d7a55,
    16px 8px #39ff14,
    24px 8px #1d7a55,
    -8px 16px #1d7a55,
    0 16px #39ff14,
    8px 16px #1d7a55,
    16px 16px #39ff14,
    24px 16px #1d7a55,
    8px 24px #8b6914,
    8px 32px #8b6914;
}

.camera {
  background: #888;
  box-shadow:
    8px 0 #888,
    16px 0 #888,
    24px 0 #888,
    32px 0 #888,
    0 8px #666,
    8px 8px #00ffff,
    16px 8px #00ffff,
    24px 8px #00ffff,
    32px 8px #666,
    0 16px #888,
    8px 16px #888,
    16px 16px #888,
    24px 16px #888,
    32px 16px #888;
}

.kayak {
  background: #ff6600;
  box-shadow:
    8px 0 #ff6600,
    16px 0 #ff6600,
    24px 0 #ff6600,
    32px 0 #ff6600,
    40px 0 #ff6600,
    -8px 0 transparent,
    48px 0 transparent,
    16px -8px #aaa,
    24px -8px #aaa,
    20px -16px #aaa;
}

.mountain {
  background: #6666cc;
  box-shadow:
    8px 8px #6666cc,
    16px 16px #6666cc,
    24px 24px #6666cc,
    32px 16px #5555aa,
    40px 8px #5555aa,
    16px 8px #fff,
    24px 16px #fff,
    32px 24px #5555aa,
    40px 24px #5555aa,
    48px 24px #5555aa;
}

.gamepad {
  background: #888;
  box-shadow:
    8px 0 #888,
    16px 0 #888,
    24px 0 #888,
    32px 0 #888,
    -8px 8px #888,
    0 8px #888,
    8px 8px #ff00ff,
    16px 8px #888,
    24px 8px #39ff14,
    32px 8px #888,
    40px 8px #888,
    0 16px #888,
    8px 16px #888,
    16px 16px #888,
    24px 16px #888,
    32px 16px #888;
}

.lambda {
  background: var(--neon-yellow);
  box-shadow:
    8px 8px var(--neon-yellow),
    -8px 8px var(--neon-yellow),
    16px 16px var(--neon-yellow),
    -16px 16px var(--neon-yellow),
    0 16px var(--neon-yellow),
    8px 16px var(--neon-yellow),
    -8px 16px var(--neon-yellow),
    0 24px var(--neon-yellow);
}

/* ======================================
   STATUS BAR
   ====================================== */
.status-bar {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-top: 1.5rem;
  padding: 0.6rem 0.8rem;
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--neon-green);
  border: 1px solid rgba(57, 255, 20, 0.3);
  background: rgba(57, 255, 20, 0.04);
  text-shadow: 0 0 6px var(--neon-green);
}

.status-led {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--neon-green);
  box-shadow: 0 0 6px var(--neon-green), 0 0 12px var(--neon-green);
  animation: ledPulse 1.5s ease-in-out infinite;
}

@keyframes ledPulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 6px var(--neon-green), 0 0 12px var(--neon-green); }
  50%      { opacity: 0.5; box-shadow: 0 0 3px var(--neon-green); }
}

.spacer {
  flex: 1;
}

/* ======================================
   LINKS
   ====================================== */
a {
  color: var(--link);
  font-weight: 700;
  text-shadow: 0 0 5px rgba(0, 255, 255, 0.3);
  transition: all 0.2s ease;
}

a:hover {
  color: var(--link-hover);
  text-shadow: 0 0 10px rgba(255, 0, 255, 0.5);
}

/* ======================================
   FOOTER
   ====================================== */
.site-footer {
  position: relative;
  z-index: 1;
  width: min(860px, calc(100% - 2rem));
  margin: 0 auto 2rem;
  padding: 0.75rem 1rem;
  border: 2px solid rgba(0, 255, 255, 0.25);
  background: rgba(10, 10, 40, 0.92);
  box-shadow:
    0 0 15px rgba(0, 150, 180, 0.15),
    inset 0 0 20px rgba(0, 100, 140, 0.05);
  overflow: hidden;
}

.site-footer::before {
  content: "";
  position: absolute;
  inset: -2px;
  z-index: -1;
  background: linear-gradient(
    180deg,
    rgba(0, 180, 220, 0.3),
    rgba(100, 60, 120, 0.15),
    rgba(180, 100, 60, 0.2)
  );
  border-radius: 3px;
}

.footer-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.8rem;
}

.site-footer img {
  width: 88px;
  height: auto;
  image-rendering: pixelated;
}

.footer-links p {
  margin: 0;
}

.site-footer a {
  color: var(--neon-cyan);
}

.site-footer a:hover {
  color: var(--neon-pink);
}

/* ======================================
   SUBTLE GLOW BORDER (on shell)
   ====================================== */
.site-shell::before {
  content: "";
  position: absolute;
  inset: -2px;
  z-index: -1;
  background: linear-gradient(
    180deg,
    rgba(0, 180, 220, 0.3),
    rgba(100, 60, 120, 0.15),
    rgba(180, 100, 60, 0.2)
  );
  border-radius: 3px;
}

/* ======================================
   GALLERY
   ====================================== */
.gallery {
  margin-top: 1rem;
  columns: 3;
  column-gap: 0.75rem;
}

.gallery-item {
  display: block;
  margin-bottom: 0.75rem;
  break-inside: avoid;
  border: 1px solid rgba(0, 255, 255, 0.2);
  background: rgba(0, 0, 0, 0.3);
  cursor: pointer;
  overflow: hidden;
  transition: all 0.2s ease;
}

.gallery-item:hover {
  border-color: var(--neon-pink);
  box-shadow: 0 0 12px rgba(255, 0, 255, 0.25);
  transform: scale(1.02);
}

.gallery-item img {
  display: block;
  width: 100%;
  height: auto;
}

.back-link {
  margin: 0 0 0.5rem;
  font-size: 0.85rem;
}

/* ======================================
   404 PAGE
   ====================================== */
.not-found {
  text-align: center;
  padding: 2rem 0;
}

.not-found-code {
  font-size: clamp(4rem, 12vw, 8rem);
  font-weight: 900;
  line-height: 1;
  margin: 0;
  color: var(--neon-cyan);
  text-shadow:
    0 0 10px var(--neon-cyan),
    0 0 40px rgba(0, 255, 255, 0.3);
}

.not-found-msg {
  font-size: 1.2rem;
  color: var(--text-main);
  margin: 1rem 0 0.5rem;
}

.not-found-sub {
  color: var(--text-muted);
  font-size: 0.9rem;
  max-width: 40ch;
  margin: 0 auto;
}

.not-found-art {
  display: block;
  width: 360px;
  height: auto;
  margin: 2rem auto;
  opacity: 0.6;
  image-rendering: pixelated;
}

/* ======================================
   PHOTO GROUPS (skateboarding, etc.)
   ====================================== */
.photo-group {
  margin-top: 1.5rem;
}

.group-date {
  display: inline-block;
  font-size: 0.75rem;
  color: var(--neon-pink);
  letter-spacing: 0.08em;
  margin-bottom: 0.25rem;
  opacity: 0.7;
}

.group-description {
  color: var(--text-muted);
  font-size: 0.9rem;
  max-width: 60ch;
  margin-bottom: 0.75rem;
}

.photo-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 0.75rem;
}

.photo-item {
  border: 1px solid rgba(0, 255, 255, 0.2);
  background: rgba(0, 0, 0, 0.3);
  overflow: hidden;
  cursor: pointer;
  transition: all 0.2s ease;
}

.photo-item:hover {
  border-color: var(--neon-pink);
  box-shadow: 0 0 12px rgba(255, 0, 255, 0.25);
  transform: scale(1.02);
}

.photo-item img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ======================================
   LIGHTBOX
   ====================================== */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(0, 0, 0, 0.9);
  cursor: pointer;
  justify-content: center;
  align-items: center;
  padding: 2rem;
}

.lightbox.active {
  display: flex;
}

.lightbox img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  border: 2px solid rgba(0, 255, 255, 0.25);
  box-shadow: 0 0 30px rgba(0, 150, 180, 0.3);
}

/* ======================================
   RESPONSIVE
   ====================================== */
@media (max-width: 640px) {
  .site-shell {
    margin-top: 1rem;
    padding: 1rem;
  }

  .terminal-bar {
    margin: -1rem -1rem 1rem;
    padding: 6px 8px;
  }

  .marquee-wrap {
    margin: 1rem -1rem;
  }

  .interest-grid {
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  }

  .gallery {
    columns: 2;
  }
}

@media (max-width: 400px) {
  .gallery {
    columns: 1;
  }
}
