/* === RUN LOLA RUN theme — neon punk magenta + cyan === */
body { font-family: 'Bebas Neue', 'Oswald', 'Noto Serif SC', sans-serif; background: #0a0a0a; }
.title-poster { background: linear-gradient(135deg, rgba(255,32,128,0.10), transparent 50%, rgba(0,212,255,0.10)); }
.title-line1 { color: #ffe040 !important; font-family: 'Bebas Neue', sans-serif !important; font-size: 1.1em !important; letter-spacing: 12px !important; text-shadow: 0 0 1px #ff2080, 4px 4px 0 #00d4ff, 8px 8px 30px rgba(255,32,128,0.6) !important; transform: rotate(-2deg) !important; }
.title-line2 { color: #00d4ff !important; font-family: 'Bebas Neue', sans-serif !important; font-size: 1.1em !important; letter-spacing: 12px !important; text-shadow: 0 0 1px #ff2080, 4px 4px 0 #ff2080, 8px 8px 30px rgba(0,212,255,0.6) !important; transform: rotate(2deg) translateX(30px) !important; }
.kanji-bg { color: #ff2080 !important; opacity: 0.16 !important; font-size: 360px !important; transform: translate(-50%, -50%) rotate(-12deg) !important; }
.title-tag, .route-tag, .chapter-card-tag, .title-starring-label,
#dialogue-controls button, .menu-btn { font-family: 'Bebas Neue', 'Oswald', sans-serif !important; }
.title-tag { color: #ff2080 !important; letter-spacing: 8px !important; font-size: 1.1em !important; }
.title-quote { color: #00d4ff !important; font-family: 'Bebas Neue', sans-serif !important; letter-spacing: 4px !important; }
.menu-btn { border-color: #ff2080 !important; color: #ffe040 !important; font-size: 1.1em !important; letter-spacing: 4px !important; }
.menu-btn:hover { background: #ff2080 !important; color: #ffe040 !important; box-shadow: 0 0 30px rgba(255,32,128,0.8), 0 0 60px rgba(0,212,255,0.4) !important; }
.route-card { border-color: #ff2080 !important; }
.route-card:hover { box-shadow: 0 0 50px rgba(0,212,255,0.5) !important; border-color: #00d4ff !important; transform: translateY(-6px) rotate(-1deg) !important; }
#speaker-name { color: #ff2080 !important; font-family: 'Bebas Neue', sans-serif !important; letter-spacing: 4px !important; }
.choice-btn { border-color: #00d4ff !important; color: #ffe040 !important; font-family: 'Bebas Neue', sans-serif !important; letter-spacing: 2px !important; font-size: 1.1em !important; }
.choice-btn:hover { background: #00d4ff !important; color: #0a0a0a !important; }


/* === AUTO-INJECTED bg/cg CSS RULES (do not edit by hand) === */
#bg-layer.bg-bank { --bg-img: url('assets/bg/bg-bank.png'); --bg-tint: linear-gradient(180deg,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0.5) 100%); }
#bg-layer.bg-bridge { --bg-img: url('assets/bg/bg-bridge.png'); --bg-tint: linear-gradient(180deg,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0.5) 100%); }
#bg-layer.bg-casino { --bg-img: url('assets/bg/bg-casino.png'); --bg-tint: radial-gradient(ellipse at 50% 50%,rgba(180,140,80,0.15) 0%,transparent 55%),linear-gradient(180deg,rgba(15,10,5,0.2) 0%,rgba(0,0,0,0.55) 100%); }
#bg-layer.bg-flat { --bg-img: url('assets/bg/bg-flat.png'); --bg-tint: linear-gradient(180deg,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0.5) 100%); }
#bg-layer.bg-street { --bg-img: url('assets/bg/bg-street.png'); --bg-tint: radial-gradient(circle at 50% 60%,rgba(255,140,60,0.15) 0%,transparent 50%),linear-gradient(180deg,rgba(15,10,20,0.2) 0%,rgba(0,0,0,0.55) 100%); }
#bg-layer.bg-supermarket { --bg-img: url('assets/bg/bg-supermarket.png'); --bg-tint: linear-gradient(180deg,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0.5) 100%); }
#bg-layer { background: var(--bg-tint, none), var(--bg-img, none) center/cover no-repeat; }
/* === END AUTO-INJECTED === */

/* === TITLE SCREEN BG IMAGE (auto) === */
#title-screen {
  background-image: url('assets/title.png');
  background-size: cover;
  background-position: center;
  position: relative;
}
/* Darkening + vignette overlay so the title/buttons read clearly */
#title-screen::after {
  content: '';
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(ellipse at 50% 55%, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.65) 60%, rgba(0,0,0,0.85) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0.20) 30%, rgba(0,0,0,0.45) 75%, rgba(0,0,0,0.85) 100%);
}
/* Make sure all the actual content sits above the overlay */
#title-screen > * { position: relative; z-index: 1; }
/* === END TITLE BG === */
