/* ============================================
   MAD HOUSE CREW — Global Effects
   ============================================ */

/* ── GRAIN OVERLAY ─────────────────────────── */
.grain-overlay {
  position: fixed;
  top: -50%; left: -50%;
  width: 200%; height: 200%;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
  opacity: 0.07;
  pointer-events: none;
  z-index: 9990;
  animation: grain 0.4s steps(1) infinite;
}
@keyframes grain {
  0%, 100% { transform: translate(0,    0); }
  10%       { transform: translate(-2%, -3%); }
  20%       { transform: translate( 3%,  1%); }
  30%       { transform: translate(-1%,  2%); }
  40%       { transform: translate( 2%, -1%); }
  50%       { transform: translate(-3%,  3%); }
  60%       { transform: translate( 1%, -2%); }
  70%       { transform: translate(-2%,  1%); }
  80%       { transform: translate( 3%, -3%); }
  90%       { transform: translate(-1%,  2%); }
}

/* ── SCANLINES ─────────────────────────────── */
.scanlines {
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0, 0, 0, 0.12) 2px,
    rgba(0, 0, 0, 0.12) 4px
  );
  pointer-events: none;
  z-index: 2;
}

/* ── CUSTOM CURSOR ─────────────────────────── */
.cursor {
  position: fixed;
  width: 12px; height: 12px;
  background: var(--red);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  transition: transform 0.15s var(--transition-bounce),
              background 0.2s ease,
              width 0.2s ease,
              height 0.2s ease;
  mix-blend-mode: screen;
}
.cursor.hover {
  transform: translate(-50%, -50%) scale(2.5);
  background: var(--red-hot);
}

.cursor-ring {
  position: fixed;
  width: 36px; height: 36px;
  border: 1px solid var(--red);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9998;
  transform: translate(-50%, -50%);
  opacity: 0.5;
  transition: border-color 0.2s ease, opacity 0.2s ease;
}
.cursor-ring.hover {
  border-color: var(--red-hot);
  opacity: 0.8;
}

/* ── MARQUEE ───────────────────────────────── */
.marquee-section {
  background: var(--red);
  padding: 14px 0;
  overflow: hidden;
  white-space: nowrap;
}
.marquee-track {
  display: inline-flex;
  animation: marquee-scroll 22s linear infinite;
}
.marquee-section:hover .marquee-track {
  animation-play-state: paused;
}
.marquee-item {
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: 4px;
  color: var(--black);
  padding: 0 28px;
}
.marquee-sep {
  color: rgba(0, 0, 0, 0.35);
  padding: 0 4px;
}
@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── GLITCH TEXT ───────────────────────────── */
.glitch {
  position: relative;
}
.glitch::before,
.glitch::after {
  content: attr(data-text);
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
}
.glitch::before {
  color: var(--red);
  animation: glitch-1 3s infinite linear;
  clip-path: polygon(0 0, 100% 0, 100% 35%, 0 35%);
}
.glitch::after {
  color: #00ffff;
  animation: glitch-2 3s infinite linear;
  clip-path: polygon(0 65%, 100% 65%, 100% 100%, 0 100%);
}
@keyframes glitch-1 {
  0%, 90%, 100% { transform: translate(0); opacity: 0; }
  92%           { transform: translate(-3px, 1px); opacity: 0.6; }
  94%           { transform: translate(3px, -1px); opacity: 0.6; }
  96%           { transform: translate(-2px, 0); opacity: 0.6; }
}
@keyframes glitch-2 {
  0%, 90%, 100% { transform: translate(0); opacity: 0; }
  93%           { transform: translate(3px, 1px); opacity: 0.4; }
  95%           { transform: translate(-3px, -1px); opacity: 0.4; }
  97%           { transform: translate(2px, 0); opacity: 0.4; }
}

/* ── RED GLOW BOX ──────────────────────────── */
.glow-box {
  box-shadow: 0 0 30px rgba(200, 0, 0, 0.15),
              inset 0 0 30px rgba(200, 0, 0, 0.05);
}

/* ── CTA BUTTON ────────────────────────────── */
.btn-primary {
  display: inline-block;
  background: var(--red);
  color: var(--white);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 4px;
  text-transform: uppercase;
  padding: 18px 52px;
  clip-path: polygon(14px 0%, 100% 0%, calc(100% - 14px) 100%, 0% 100%);
  transition: background var(--transition-fast),
              transform var(--transition-fast),
              box-shadow var(--transition-fast);
  cursor: none;
}
.btn-primary:hover {
  background: var(--red-hot);
  transform: scale(1.03);
  box-shadow: 0 0 40px rgba(200, 0, 0, 0.5);
}

.btn-outline {
  display: inline-block;
  background: transparent;
  color: var(--white);
  border: 1px solid var(--red-dim);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  padding: 14px 36px;
  transition: border-color var(--transition-fast),
              color var(--transition-fast),
              background var(--transition-fast);
  cursor: none;
}
.btn-outline:hover {
  border-color: var(--red);
  color: var(--red);
  background: rgba(200, 0, 0, 0.05);
}
