:root {
  --r: #ff1a1a;
  --y: #ffe600;
  --b: #1a75ff;
  --fg: #fff;
  --bg: #000;
}

html, body {
  margin: 0; padding: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: "Trebuchet MS", Arial Black, sans-serif;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* BIG BLOCKS */
.frame {
  margin: 20px auto;
  max-width: 1100px;
  padding: 20px;
  border: 8px solid var(--y);
  background: linear-gradient(90deg, var(--r) 33%, var(--y) 33% 66%, var(--b) 66%);
  animation: bgshift 12s infinite linear;
}
@keyframes bgshift {
  0% { background-position: 0 0; }
  100% { background-position: 300px 0; }
}

/* TITLE */
.titlebar h1 {
  font-size: 42px;
  color: var(--y);
  text-shadow: 3px 3px var(--r), -3px -3px var(--b);
  margin: 0 0 10px;
}
.subtitle {
  font-size: 14px;
  color: var(--fg);
}

/* NAV GRID */
.grid {
  display: grid;
  gap: 14px;
  margin: 20px 0;
  grid-template-columns: repeat(2, 1fr);
}
.btn {
  display: block;
  padding: 20px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  background: var(--b);
  color: var(--y);
  border: 4px solid var(--r);
  box-shadow: 4px 4px 0 var(--y), -4px -4px 0 var(--r);
  transition: all .2s ease;
}
.btn:hover {
  background: var(--r);
  color: var(--b);
  border-color: var(--y);
  box-shadow: -4px -4px 0 var(--b), 4px 4px 0 var(--y);
  transform: rotate(-1deg) scale(1.05);
}

/* PANELS */
.panel {
  padding: 16px;
  margin: 16px 0;
  border: 6px dashed var(--r);
  background: repeating-linear-gradient(
    45deg,
    var(--y),
    var(--y) 20px,
    var(--b) 20px,
    var(--b) 40px
  );
  color: #000;
  font-weight: bold;
  text-shadow: 1px 1px 0 var(--fg);
}

/* GALLERY THUMBS */
.thumbs {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}
.thumb {
  border: 6px solid var(--b);
  background: var(--y);
  transform: rotate(-1deg);
  transition: transform .1s;
}
.thumb img {
  width: 100%;
  display: block;
}
.thumb:hover {
  transform: rotate(2deg) scale(1.1);
  border-color: var(--r);
}

/* LIVE */
.live-indicator {
  display: inline-block;
  background: var(--r);
  color: var(--y);
  font-weight: bold;
  padding: 6px 14px;
  border: 3px solid var(--b);
  animation: blink 1s infinite;
}
@keyframes blink { 50% { opacity: 0; } }

/* TICKER */
.ticker {
  background: var(--b);
  color: var(--y);
  padding: 6px;
  border: 3px solid var(--r);
  font-family: "Courier New", monospace;
  overflow: hidden;
  white-space: nowrap;
}

/* FOOTER */
.footer {
  margin-top: 20px;
  font-size: 12px;
  color: var(--y);
  text-align: center;
}

/* STATIC BUTTON */
.static {
  position: fixed;
  right: 20px;
  bottom: 20px;
  width: 100px;
  height: 80px;
  background: url('../assets/blacklightning.gif') center/cover, var(--r);
  border: 6px solid var(--y);
  box-shadow: 0 0 30px var(--b);
  cursor: pointer;
}
.secret-link,
.secret-link:visited,
.secret-link:hover,
.secret-link:active {
  color: inherit;
  text-decoration: none;
}
.panel {
  padding: 16px;
  margin: 16px 0;
  border: 8px solid var(--r);
  background: #fff;
  color: #000;
  font-family: "Trebuchet MS", Arial Black, sans-serif;
  text-transform: uppercase;
}
.panel {
  padding: 16px;
  margin: 16px 0;
  border: 6px dashed var(--r);
  background: rgba(26, 117, 255, 0.75);  /* translucent blue */
  color: var(--y);                       /* yellow text pops on blue */
  font-weight: bold;
  text-shadow: 2px 2px 0 #000;           /* black outline for readability */
}
.twitch-player {
  position: relative;
  width: 100%;
  padding-top: 56.25%; /* 16:9 ratio */
  border: 6px solid var(--y);
  box-shadow: 0 0 25px var(--b);
}
.twitch-player iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
}
/* Twitch wrapper + player */
.twitch-wrapper { position: relative; }
.twitch-player {
  position: relative;
  width: 100%;
  padding-top: 56.25%; /* 16:9 */
  border: 6px solid var(--y);
  box-shadow: 0 0 25px var(--b);
}
.twitch-player iframe,
#twitch-player > iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  display: block;
}

/* On-brand offline overlay */
.offline-overlay {
  position: absolute;
  inset: 0;
  display: flex; /* shown until Twitch says live */
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 16px;

  background:
    repeating-linear-gradient(
      45deg,
      var(--y), var(--y) 24px,
      var(--b) 24px, var(--b) 48px
    );
  outline: 8px solid var(--r);
  color: var(--r);
  text-shadow: 2px 2px 0 #000;
  font-weight: bold;
  z-index: 2;
  pointer-events: none;
}

.offline-overlay h2 {
  margin: 0 0 8px 0;
  font-size: 28px;
}
.offline-overlay p { margin: 4px 0; }

.offline-overlay .btn {
  pointer-events: auto;
  text-transform: uppercase;
  background: var(--r);
  color: var(--y);
  border: 4px solid var(--b);
  box-shadow: 4px 4px 0 var(--y), -4px -4px 0 var(--b);
}
.offline-overlay .btn:hover {
  background: var(--b);
  color: var(--y);
  border-color: var(--r);
  box-shadow: -4px -4px 0 var(--r), 4px 4px 0 var(--y);
  transform: rotate(-1deg) scale(1.05);
}
/* Make the stripe background move so it feels alive */
.offline-overlay {
  animation: stripesShift 8s linear infinite;
  position: relative; /* for scanlines layer */
}
@keyframes stripesShift {
  0% { background-position: 0 0; }
  100% { background-position: 200px 0; }
}

/* CRT scanlines + mild flicker */
.offline-overlay::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(rgba(0,0,0,0.18) 1px, transparent 1px);
  background-size: 100% 3px;
  mix-blend-mode: multiply;
  pointer-events: none;
  animation: flicker 6s ease-in-out infinite;
}
@keyframes flicker {
  0%, 100% { opacity: .18; }
  45%      { opacity: .28; }
  50%      { opacity: .38; }
  55%      { opacity: .28; }
}

/* Big circus "OFFLINE" title with red/yellow glitch echoes */
.offline-title {
  position: relative;
  margin: 0 0 6px 0;
  font-size: clamp(40px, 8vw, 72px);
  letter-spacing: 4px;
  color: var(--y); /* main fill is yellow (matches your site title) */
  text-shadow: 3px 3px 0 var(--r), -2px -2px 0 #000; /* red pop + black bite */
  transform: translateZ(0);
  animation: titleJitter 1.6s steps(2, end) infinite;
}

/* Duplicate layers for glitch splits */
.offline-title::before,
.offline-title::after {
  content: attr(data-text);
  position: absolute;
  top: 0; left: 0;
  pointer-events: none;
}
.offline-title::before {
  color: var(--r);                    /* red ghost */
  transform: translate(2px, -2px);
  mix-blend-mode: screen;
  animation: glitchA 2.1s infinite;
}
.offline-title::after {
  color: var(--y);                    /* extra yellow echo */
  opacity: .85;
  transform: translate(-2px, 2px);
  animation: glitchB 3s infinite;
}

/* Subtitle wiggle so it doesn’t look static */
.offline-sub {
  margin: 4px 0 0 0;
  text-shadow: 2px 2px 0 #000;
  animation: subWiggle 2.8s ease-in-out infinite;
}

/* Keyframes for the title jitter + layered glitches */
@keyframes titleJitter {
  0%   { transform: translate(0,0) rotate(0deg); }
  50%  { transform: translate(0.5px,-0.5px) rotate(-0.2deg); }
  100% { transform: translate(0,0) rotate(0deg); }
}
@keyframes glitchA {
  0%   { clip-path: inset(0 0 0 0); transform: translate(2px,-2px); }
  20%  { clip-path: inset(0 0 70% 0); transform: translate(3px,-1px); }
  40%  { clip-path: inset(60% 0 0 0); transform: translate(1px,-3px); }
  60%  { clip-path: inset(20% 0 20% 0); transform: translate(4px,-2px); }
  80%  { clip-path: inset(0 0 0 0); transform: translate(2px,-2px) skewX(1deg); }
  100% { clip-path: inset(0 0 0 0); transform: translate(2px,-2px); }
}
@keyframes glitchB {
  0%   { clip-path: inset(0 0 0 0); transform: translate(-2px,2px); }
  25%  { clip-path: inset(10% 0 40% 0); transform: translate(-3px,1px); }
  50%  { clip-path: inset(30% 0 10% 0); transform: translate(-1px,3px); }
  75%  { clip-path: inset(0 0 0 0); transform: translate(-4px,2px) skewX(-1deg); }
  100% { clip-path: inset(0 0 0 0); transform: translate(-2px,2px); }
}
@keyframes subWiggle {
  0%   { transform: translateX(0); }
  50%  { transform: translateX(1px); }
  100% { transform: translateX(0); }
}
/* Make wrapper clip anything weird */
.twitch-wrapper { position: relative; overflow: hidden; }

/* FULL bleed stripes: no padding, use border-box, use BORDER (not outline) */
.offline-overlay {
  position: absolute;
  inset: 0;
  display: block;               /* inner flex handles centering */
  padding: 0;                   /* <-- important */
  box-sizing: border-box;       /* include border in the box */
  border: 8px solid var(--r);   /* replaces outline so edges align */
  z-index: 2;
  pointer-events: none;

  background:
    repeating-linear-gradient(
      45deg,
      var(--y), var(--y) 24px,
      var(--b) 24px, var(--b) 48px
    );
  animation: stripesShift 8s linear infinite;
  transform: translateZ(0);     /* avoids subpixel gaps in Safari */
}

/* Inner centers content and adds spacing */
.offline-inner{
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 16px;
  color: var(--r);
  text-shadow: 2px 2px 0 #000;
  font-weight: bold;
}

/* Scanlines & flicker */
.offline-overlay::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(rgba(0,0,0,0.18) 1px, transparent 1px);
  background-size: 100% 3px;
  mix-blend-mode: multiply;
  pointer-events: none;
  animation: flicker 6s ease-in-out infinite;
}

@keyframes stripesShift { 0%{background-position:0 0} 100%{background-position:200px 0} }
@keyframes flicker { 0%,100%{opacity:.18} 45%{opacity:.28} 50%{opacity:.38} 55%{opacity:.28} }

/* Title/subtitle glitch from earlier (unchanged) */
.offline-title{
  position:relative;margin:0 0 6px;font-size:clamp(40px,8vw,72px);
  letter-spacing:4px;color:var(--y);
  text-shadow:3px 3px 0 var(--r), -2px -2px 0 #000;
  animation:titleJitter 1.6s steps(2,end) infinite;
}
.offline-title::before,
.offline-title::after{content:attr(data-text);position:absolute;top:0;left:0;pointer-events:none}
.offline-title::before{color:var(--r);transform:translate(2px,-2px);mix-blend-mode:screen;animation:glitchA 2.1s infinite}
.offline-title::after{color:var(--y);opacity:.85;transform:translate(-2px,2px);animation:glitchB 3s infinite}
.offline-sub{margin:4px 0 0;text-shadow:2px 2px 0 #000;animation:subWiggle 2.8s ease-in-out infinite}

@keyframes titleJitter{0%{transform:translate(0,0)}50%{transform:translate(.5px,-.5px) rotate(-.2deg)}100%{transform:translate(0,0)}}
@keyframes glitchA{0%{clip-path:inset(0 0 0 0);transform:translate(2px,-2px)}20%{clip-path:inset(0 0 70% 0);transform:translate(3px,-1px)}40%{clip-path:inset(60% 0 0 0);transform:translate(1px,-3px)}60%{clip-path:inset(20% 0 20% 0);transform:translate(4px,-2px)}80%{clip-path:inset(0 0 0 0);transform:translate(2px,-2px) skewX(1deg)}100%{clip-path:inset(0 0 0 0);transform:translate(2px,-2px)}}
@keyframes glitchB{0%{clip-path:inset(0 0 0 0);transform:translate(-2px,2px)}25%{clip-path:inset(10% 0 40% 0);transform:translate(-3px,1px)}50%{clip-path:inset(30% 0 10% 0);transform:translate(-1px,3px)}75%{clip-path:inset(0 0 0 0);transform:translate(-4px,2px) skewX(-1deg)}100%{clip-path:inset(0 0 0 0);transform:translate(-2px,2px)}}
@keyframes subWiggle{0%{transform:translateX(0)}50%{transform:translateX(1px)}100%{transform:translateX(0)}}
/* ------- Lightbox ------- */
.lightbox {
  position: fixed; inset: 0; z-index: 9999;
  display: none; /* toggled to flex when open */
  align-items: center; justify-content: center;
  background:
    radial-gradient(circle at 10% 10%, rgba(255,230,0,.12), transparent 40%),
    radial-gradient(circle at 90% 90%, rgba(26,117,255,.12), transparent 40%),
    rgba(0,0,0,.85);
  backdrop-filter: blur(2px);
}
.lightbox.open { display: flex; }

.lb-figure {
  position: relative; margin: 0; max-width: 92vw; max-height: 86vh;
  border: 8px solid var(--y);
  box-shadow: 0 0 0 6px var(--r), 0 0 40px var(--b);
  background: #000;
  display: grid; grid-template-rows: 1fr auto;
}
#lbImg {
  max-width: 92vw; max-height: 74vh; object-fit: contain; background:#000;
}
#lbCap {
  padding: 8px 12px; text-align: center; color: var(--y);
  background: repeating-linear-gradient(45deg, var(--b), var(--b) 10px, #000 10px, #000 20px);
  text-shadow: 2px 2px #000; font-weight: bold;
}

/* Controls */
.lb-close, .lb-prev, .lb-next {
  position: absolute; border: 4px solid var(--r); background: var(--b);
  color: var(--y); font-weight: 800; cursor: pointer; user-select: none;
  box-shadow: 4px 4px 0 var(--y), -4px -4px 0 var(--r);
  transition: transform .07s ease;
}
.lb-close:hover, .lb-prev:hover, .lb-next:hover {
  background: var(--r); color: var(--b);
  transform: translateY(-1px) rotate(-1deg);
}
.lb-close { top: 16px; right: 16px; padding: 6px 10px; font-size: 18px; z-index: 2; }
.lb-prev  { left: 8px;  top: 50%; transform: translateY(-50%); padding: 8px 12px; font-size: 20px; }
.lb-next  { right: 8px; top: 50%; transform: translateY(-50%); padding: 8px 12px; font-size: 20px; }

body.no-scroll { overflow: hidden; }

/* Optional: thumb focus style for accessibility */
.thumb:focus { outline: 4px solid var(--y); outline-offset: 2px; }

/* WebGL background */
#webgl-bg {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  display: block;
  z-index: -1;
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  :root { --reduced-motion: 1; }
}

/* Optional shimmer for glitch buttons */
a.btn[data-glitch] {
  position: relative;
  will-change: filter, transform;
  transition: transform 120ms ease, filter 200ms ease;
}
a.btn[data-glitch]:hover {
  transform: translateZ(0) scale(1.01);
}
a.btn[data-glitch]::after {
  content: attr(data-glitch);
  position: absolute; inset: 0;
  opacity: 0;
  mix-blend-mode: color-dodge;
  pointer-events: none;
  transition: opacity 180ms ease;
}
a.btn[data-glitch]:hover::after { opacity: 0.06; }
