Compare commits

...

4 Commits

Author SHA1 Message Date
Alexander Whitestone
07bf8913bb fix: sync rock scene dataset to valid schema (#607)
Some checks failed
Architecture Lint / Linter Tests (pull_request) Successful in 32s
Smoke Test / smoke (pull_request) Failing after 26s
Validate Config / YAML Lint (pull_request) Failing after 17s
Validate Config / JSON Validate (pull_request) Successful in 23s
Validate Config / Python Syntax & Import Check (pull_request) Failing after 1m7s
Validate Config / Python Test Suite (pull_request) Has been skipped
Validate Config / Cron Syntax Check (pull_request) Successful in 15s
Validate Config / Deploy Script Dry Run (pull_request) Successful in 12s
Validate Config / Shell Script Lint (pull_request) Failing after 55s
Validate Config / Playbook Schema Validation (pull_request) Successful in 16s
Validate Training Data / validate (pull_request) Successful in 13s
Architecture Lint / Lint Repository (pull_request) Failing after 14s
PR Checklist / pr-checklist (pull_request) Successful in 6m3s
2026-04-22 11:23:51 -04:00
Alexander Whitestone
0eb70c7b4f test: add rock scene dataset schema regression (#607) 2026-04-22 11:22:42 -04:00
ae8c1d46ae Merge pull request 'feat(#407): Phase progression tracker with auto-eval, Telegram daily post, and blockers' (#857) from fix/407 into main
Some checks failed
Architecture Lint / Linter Tests (push) Successful in 28s
Smoke Test / smoke (push) Failing after 21s
Validate Config / YAML Lint (push) Failing after 9s
Validate Config / JSON Validate (push) Successful in 12s
Validate Config / Python Syntax & Import Check (push) Failing after 35s
Validate Config / Python Test Suite (push) Has been skipped
Validate Config / Shell Script Lint (push) Failing after 38s
Validate Config / Cron Syntax Check (push) Successful in 7s
Validate Config / Deploy Script Dry Run (push) Successful in 7s
Validate Config / Playbook Schema Validation (push) Successful in 16s
Architecture Lint / Lint Repository (push) Failing after 20s
2026-04-22 07:36:26 +00:00
Alexander Whitestone
508441acb4 feat(#407): Phase progression tracker with auto-eval, Telegram daily post, and blockers
Some checks failed
Architecture Lint / Linter Tests (pull_request) Successful in 25s
Smoke Test / smoke (pull_request) Failing after 23s
Validate Config / YAML Lint (pull_request) Failing after 16s
Validate Config / JSON Validate (pull_request) Successful in 19s
Validate Config / Python Syntax & Import Check (pull_request) Failing after 1m2s
Validate Config / Python Test Suite (pull_request) Has been skipped
Validate Config / Shell Script Lint (pull_request) Failing after 1m6s
Validate Config / Cron Syntax Check (pull_request) Successful in 14s
Validate Config / Deploy Script Dry Run (pull_request) Successful in 14s
Validate Config / Playbook Schema Validation (pull_request) Successful in 28s
Architecture Lint / Lint Repository (pull_request) Failing after 27s
PR Checklist / pr-checklist (pull_request) Failing after 11m41s
2026-04-22 03:34:36 -04:00
3 changed files with 446 additions and 170 deletions

View File

@@ -4,111 +4,365 @@
Part of the Gemini Sovereign Infrastructure Suite.
Tracks the fleet's progress through the Paperclips-inspired evolution arc.
Usage:
python3 scripts/phase_tracker.py status # Show current state
python3 scripts/phase_tracker.py evaluate # Auto-evaluate checkable milestones
python3 scripts/phase_tracker.py complete M4 # Mark milestone complete
python3 scripts/phase_tracker.py telegram # Post daily update to Telegram
python3 scripts/phase_tracker.py daily # evaluate + telegram
"""
import os
import sys
import json
import re
import argparse
import urllib.request
import subprocess
from pathlib import Path
from datetime import datetime, timezone, timedelta
MILESTONES_FILE = "fleet/milestones.md"
COMPLETED_FILE = "fleet/completed_milestones.json"
LOG_DIR = Path(os.path.expanduser("~/.local/timmy/fleet-health"))
UPTIME_FILE = LOG_DIR / "uptime.json"
TELEGRAM_TOKEN_PATHS = [
Path.home() / ".config" / "timmy" / "telegram_bot_token",
Path.home() / ".hermes" / "telegram_bot_token",
Path.home() / ".hermes" / "telegram_token",
]
TELEGRAM_CHAT = os.environ.get("TELEGRAM_HOME_CHANNEL", "-1003664764329")
HOSTS = {
"ezra": {"ip": "143.198.27.163"},
"allegro": {"ip": "167.99.126.228"},
"bezalel": {"ip": "159.203.146.185"},
}
def _find_repo_root() -> Path:
script_dir = Path(__file__).resolve().parent
return script_dir.parent
def _read_token() -> str | None:
for p in TELEGRAM_TOKEN_PATHS:
if p.exists():
return p.read_text().strip()
return os.environ.get("TELEGRAM_BOT_TOKEN") or None
def telegram_send(text: str) -> bool:
token = _read_token()
if not token:
print("[WARN] No Telegram token found.", file=sys.stderr)
return False
url = f"https://api.telegram.org/bot{token}/sendMessage"
body = json.dumps({"chat_id": TELEGRAM_CHAT, "text": text, "parse_mode": "HTML"}).encode()
req = urllib.request.Request(url, data=body, headers={"Content-Type": "application/json"})
try:
with urllib.request.urlopen(req, timeout=30) as resp:
return resp.status == 200
except Exception as e:
print(f"[WARN] Telegram send failed: {e}", file=sys.stderr)
return False
class Milestone:
def __init__(self, m_id: str, title: str, trigger: str, message: str):
self.id = m_id
self.title = title
self.trigger = trigger
self.message = message
class Phase:
def __init__(self, name: str, number: int, unlock_condition: str | None):
self.name = name
self.number = number
self.unlock_condition = unlock_condition
self.milestones: list[Milestone] = []
class PhaseTracker:
def __init__(self):
# Find files relative to repo root
script_dir = os.path.dirname(os.path.abspath(__file__))
repo_root = os.path.dirname(script_dir)
self.milestones_path = os.path.join(repo_root, MILESTONES_FILE)
self.completed_path = os.path.join(repo_root, COMPLETED_FILE)
self.milestones = self.parse_milestones()
self.completed = self.load_completed()
self.repo_root = _find_repo_root()
self.milestones_path = self.repo_root / MILESTONES_FILE
self.completed_path = self.repo_root / COMPLETED_FILE
self.phases: list[Phase] = self._parse_milestones()
self.completed: set[str] = self._load_completed()
def _parse_milestones(self) -> list[Phase]:
if not self.milestones_path.exists():
return []
content = self.milestones_path.read_text()
phases: list[Phase] = []
current_phase: Phase | None = None
for line in content.splitlines():
phase_match = re.match(r"##\s*Phase\s*(\d+):\s*(.+?)\s*(?:\(([^)]+)\))?\s*$", line)
if phase_match:
num = int(phase_match.group(1))
name = phase_match.group(2).strip()
unlock = phase_match.group(3)
current_phase = Phase(name, num, unlock)
phases.append(current_phase)
continue
m_match = re.match(r"###\s*(M\d+):\s*(.+)$", line)
if m_match and current_phase is not None:
m_id = m_match.group(1)
title = m_match.group(2).strip()
current_phase.milestones.append(Milestone(m_id, title, "", ""))
continue
if line.startswith("**Trigger:**") and current_phase and current_phase.milestones:
current_phase.milestones[-1].trigger = line.replace("**Trigger:**", "").strip()
continue
if line.startswith("**Message:**") and current_phase and current_phase.milestones:
current_phase.milestones[-1].message = line.replace("**Message:**", "").strip().strip('"')
continue
def parse_milestones(self):
if not os.path.exists(self.milestones_path):
return {}
with open(self.milestones_path, "r") as f:
content = f.read()
phases = {}
current_phase = None
for line in content.split("\n"):
if line.startswith("## Phase"):
current_phase = line.replace("## ", "").strip()
phases[current_phase] = []
elif line.startswith("### M"):
m_id = line.split(":")[0].replace("### ", "").strip()
title = line.split(":")[1].strip()
phases[current_phase].append({"id": m_id, "title": title})
return phases
def load_completed(self):
if os.path.exists(self.completed_path):
with open(self.completed_path, "r") as f:
try:
return json.load(f)
except:
return []
return []
def _load_completed(self) -> set[str]:
if self.completed_path.exists():
try:
data = json.loads(self.completed_path.read_text())
if isinstance(data, list):
return set(data)
except Exception:
pass
return set()
def save_completed(self):
with open(self.completed_path, "w") as f:
json.dump(self.completed, f, indent=2)
self.completed_path.write_text(json.dumps(sorted(self.completed), indent=2))
def show_progress(self):
print("--- Fleet Phase Progression Tracker ---")
total_milestones = 0
total_completed = 0
if not self.milestones:
print("[ERROR] No milestones found in fleet/milestones.md")
return
for phase, ms in self.milestones.items():
print(f"\n{phase}")
for m in ms:
total_milestones += 1
done = m["id"] in self.completed
if done:
total_completed += 1
status = "" if done else ""
print(f" {status} {m['id']}: {m['title']}")
percent = (total_completed / total_milestones) * 100 if total_milestones > 0 else 0
print(f"\nOverall Progress: {total_completed}/{total_milestones} ({percent:.1f}%)")
def mark_complete(self, m_id: str):
def mark_complete(self, m_id: str) -> bool:
m_id = m_id.upper()
exists = any(m.id == m_id for p in self.phases for m in p.milestones)
if not exists:
print(f"[ERROR] Unknown milestone: {m_id}")
return False
if m_id not in self.completed:
self.completed.append(m_id)
self.completed.add(m_id)
self.save_completed()
print(f"[SUCCESS] Marked {m_id} as complete.")
return True
print(f"[INFO] {m_id} is already complete.")
return True
def _get_phase_state(self) -> tuple[int, float, list[str], list[str]]:
"""Returns (current_phase_number, decimal_progress, blockers, next_milestones)."""
blockers = []
next_milestones = []
for phase in self.phases:
phase_completed = sum(1 for m in phase.milestones if m.id in self.completed)
phase_total = len(phase.milestones)
if phase_total == 0:
continue
if phase_completed < phase_total:
progress = phase_completed / phase_total
decimal = phase.number + progress
# Find next incomplete milestone
for m in phase.milestones:
if m.id not in self.completed:
next_milestones.append(f"{m.id}: {m.title}")
if m.trigger:
blockers.append(f"{m.id}: {m.trigger}")
break
# Phase unlock condition as blocker if near end
if phase_completed == phase_total - 1 and phase.unlock_condition:
blockers.append(f"Unlock Phase {phase.number + 1}: {phase.unlock_condition}")
return phase.number, decimal, blockers, next_milestones
# All done
last = self.phases[-1] if self.phases else None
if last:
return last.number, float(last.number) + 1.0, ["All phases complete."], []
return 0, 0.0, ["No milestones defined."], []
def show_progress(self):
phase_num, decimal, blockers, next_ms = self._get_phase_state()
total_ms = sum(len(p.milestones) for p in self.phases)
total_completed = len(self.completed)
overall_pct = (total_completed / total_ms * 100) if total_ms else 0
print("=" * 50)
print(" Fleet Phase Progression Tracker")
print("=" * 50)
print(f"\nCurrent Phase: Phase {phase_num}{self.phases[phase_num - 1].name if phase_num <= len(self.phases) else 'Complete'}")
print(f"Decimal Progress: Phase {decimal:.1f}")
print(f"Overall: {total_completed}/{total_ms} milestones ({overall_pct:.1f}%)")
print("\n--- Milestones ---")
for phase in self.phases:
done = sum(1 for m in phase.milestones if m.id in self.completed)
total = len(phase.milestones)
status = "" if done == total else ""
print(f"\n{status} Phase {phase.number}: {phase.name} ({done}/{total})")
for m in phase.milestones:
mark = "" if m.id in self.completed else ""
print(f" {mark} {m.id}: {m.title}")
print("\n--- Next Up ---")
for nm in next_ms[:3]:
print(f"{nm}")
print("\n--- Blockers ---")
for b in blockers[:5]:
print(f" ⚠️ {b}")
if not blockers:
print(" 🚀 Nothing blocking.")
print()
def summary_text(self) -> str:
phase_num, decimal, blockers, next_ms = self._get_phase_state()
total_ms = sum(len(p.milestones) for p in self.phases)
total_completed = len(self.completed)
overall_pct = (total_completed / total_ms * 100) if total_ms else 0
phase_name = self.phases[phase_num - 1].name if phase_num <= len(self.phases) else "Complete"
next_phase = phase_num + 1 if phase_num < len(self.phases) else phase_num
progress_to_next = (decimal - phase_num) * 100
lines = [
f"Fleet: Phase {decimal:.1f} ({progress_to_next:.0f}% to Phase {next_phase})",
f"Phase: {phase_num}{phase_name}",
f"Overall: {total_completed}/{total_ms} milestones ({overall_pct:.1f}%)",
]
if next_ms:
lines.append(f"Next: {next_ms[0]}")
if blockers and blockers[0] != "All phases complete.":
lines.append(f"Blocker: {blockers[0]}")
return "\n".join(lines)
# === Auto-evaluation heuristics ===
def _eval_file_exists(self, path: str) -> bool:
return (self.repo_root / path).exists()
def _eval_command(self, cmd: str) -> bool:
try:
result = subprocess.run(cmd, shell=True, capture_output=True, timeout=10)
return result.returncode == 0
except Exception:
return False
def _eval_uptime(self, target: float) -> bool:
if not UPTIME_FILE.exists():
return False
try:
data = json.loads(UPTIME_FILE.read_text())
uptime = data.get("uptime_30d_percent", 0.0)
return uptime >= target
except Exception:
return False
def _eval_local_model_multi(self) -> bool:
count = 0
for host in HOSTS:
if self._eval_command(f"ssh -o ConnectTimeout=5 {host} 'pgrep -f ollama >/dev/null 2>&1'"):
count += 1
return count >= 2
def _eval_zero_manual_restarts(self, days: int = 7) -> bool:
log = LOG_DIR / "auto_restart.log"
if not log.exists():
return False
cutoff = datetime.now(timezone.utc) - timedelta(days=days)
try:
with open(log) as f:
for line in f:
if "manual restart" in line.lower():
# crude timestamp parse
try:
ts = datetime.fromisoformat(line[:19])
if ts > cutoff:
return False
except Exception:
continue
return True
except Exception:
return False
def evaluate(self):
"""Auto-check milestones where we have heuristics."""
print("[EVAL] Running automatic milestone checks...\n")
checks = [
("M1", self._eval_command, "python3 fleet/health_check.py --dry-run 2>/dev/null || python3 fleet/health_check.py 2>&1 | head -1 >/dev/null"),
("M2", self._eval_command, "test -f ~/.local/timmy/fleet-health/auto_restart.log && grep -q 'restarted' ~/.local/timmy/fleet-health/auto_restart.log"),
("M3", self._eval_command, "test -d ~/.local/timmy/backups && ls ~/.local/timmy/backups | grep -q ."),
("M4", self._eval_uptime, 95.0),
("M5", self._eval_uptime, 97.0),
("M6", self._eval_zero_manual_restarts, 7),
("M9", self._eval_uptime, 98.0),
("M11", self._eval_local_model_multi, None),
]
newly_found = []
for m_id, check_fn, arg in checks:
if m_id in self.completed:
continue
result = check_fn(arg) if arg is not None else check_fn()
if result:
print(f"{m_id} appears satisfied — marking complete.")
self.completed.add(m_id)
newly_found.append(m_id)
else:
print(f"{m_id} not yet satisfied.")
if newly_found:
self.save_completed()
print(f"\n[SUCCESS] Auto-completed {len(newly_found)} milestone(s): {', '.join(newly_found)}")
else:
print(f"[INFO] {m_id} is already complete.")
print("\n[INFO] No new milestones auto-detected.")
def daily(self):
self.evaluate()
text = self.summary_text()
print(text)
ok = telegram_send(text)
if ok:
print("\n[TELEGRAM] Daily update sent.")
else:
print("\n[TELEGRAM] Failed to send update.")
def main():
parser = argparse.ArgumentParser(description="Gemini Phase Tracker")
parser = argparse.ArgumentParser(description="Fleet Phase Progression Tracker")
subparsers = parser.add_subparsers(dest="command")
subparsers.add_parser("status", help="Show current progress")
subparsers.add_parser("evaluate", help="Auto-evaluate checkable milestones")
subparsers.add_parser("telegram", help="Post summary to Telegram")
subparsers.add_parser("daily", help="Evaluate then post to Telegram")
complete_parser = subparsers.add_parser("complete", help="Mark a milestone as complete")
complete_parser.add_argument("id", help="Milestone ID (e.g. M1)")
args = parser.parse_args()
tracker = PhaseTracker()
if args.command == "status":
tracker.show_progress()
elif args.command == "evaluate":
tracker.evaluate()
elif args.command == "telegram":
ok = telegram_send(tracker.summary_text())
sys.exit(0 if ok else 1)
elif args.command == "daily":
tracker.daily()
elif args.command == "complete":
tracker.mark_complete(args.id)
ok = tracker.mark_complete(args.id)
sys.exit(0 if ok else 1)
else:
parser.print_help()
if __name__ == "__main__":
main()

View File

@@ -0,0 +1,22 @@
import importlib.util
from pathlib import Path
REPO_ROOT = Path(__file__).resolve().parent.parent
ROCK_DATASET = REPO_ROOT / "training-data" / "scene-descriptions-rock.jsonl"
VALIDATOR_PATH = REPO_ROOT / "training" / "data" / "scene-descriptions" / "validate.py"
def _load_validator_module():
spec = importlib.util.spec_from_file_location("scene_validator", VALIDATOR_PATH)
module = importlib.util.module_from_spec(spec)
assert spec.loader is not None
spec.loader.exec_module(module)
return module
def test_training_data_rock_dataset_is_schema_valid():
validator = _load_validator_module()
errors, line_count, valid_count = validator.validate_file(str(ROCK_DATASET))
assert errors == []
assert line_count == 100
assert valid_count == 100

View File

@@ -1,100 +1,100 @@
{"song": "Thunder Road", "artist": "Heartland", "beat": 1, "timestamp": "0:00", "duration": "30s", "lyric_line": "The screen door slams, Mary's dress waves", "scene": {"mood": "hope", "colors": ["gold", "sky blue", "white"], "composition": "wide shot", "camera": "static", "description": "Open horizon. Golden light breaking through clouds. The figure silhouetted against dawn. The screen door slams, Mary's dress waves"}}
{"song": "Thunder Road", "artist": "Heartland", "beat": 2, "timestamp": "0:30", "duration": "30s", "lyric_line": "Like a vision she dances across the porch as the radio plays", "scene": {"mood": "anticipation", "colors": ["silver", "pale green", "cream"], "composition": "close-up", "camera": "slow pan", "description": "Close on hands gripping a steering wheel. Dashboard lights reflecting in eyes. Road stretching ahead. Like a vision she dances across the porch as the radio plays"}}
{"song": "Thunder Road", "artist": "Heartland", "beat": 3, "timestamp": "1:00", "duration": "30s", "lyric_line": "Roy Orbison singing for the lonely, hey that's me and I want you only", "scene": {"mood": "energy", "colors": ["red", "orange", "electric blue"], "composition": "over the shoulder", "camera": "dolly in", "description": "Rapid cuts. Bodies in motion. Light streaks across the frame. Roy Orbison singing for the lonely, hey that's me and I want you only"}}
{"song": "Thunder Road", "artist": "Heartland", "beat": 4, "timestamp": "1:30", "duration": "30s", "lyric_line": "Don't turn me home out now I'm so young and worthless still", "scene": {"mood": "triumph", "colors": ["gold", "crimson", "white"], "composition": "low angle", "camera": "dolly out", "description": "Wide shot. Figure standing on a hilltop. Arms raised. City lights below. Don't turn me home out now I'm so young and worthless still"}}
{"song": "Thunder Road", "artist": "Heartland", "beat": 5, "timestamp": "2:00", "duration": "30s", "lyric_line": "The night's busting open these two lanes will take us anywhere", "scene": {"mood": "nostalgia", "colors": ["amber", "sepia", "dusty rose"], "composition": "high angle", "camera": "handheld", "description": "Sepia tones. A photograph come to life. Dust motes in afternoon light. The night's busting open these two lanes will take us anywhere"}}
{"song": "Thunder Road", "artist": "Heartland", "beat": 6, "timestamp": "2:30", "duration": "30s", "lyric_line": "We got one last chance to make it real", "scene": {"mood": "urgency", "colors": ["red", "black", "strobe white"], "composition": "dutch angle", "camera": "steadicam", "description": "Handheld camera running. Blurred faces. Traffic. Heartbeat sound design. We got one last chance to make it real"}}
{"song": "Thunder Road", "artist": "Heartland", "beat": 7, "timestamp": "3:00", "duration": "30s", "lyric_line": "To trade in these wings on some wheels", "scene": {"mood": "passion", "colors": ["deep red", "burgundy", "gold"], "composition": "symmetrical", "camera": "slow zoom", "description": "Extreme close-up. Skin. Breath visible in cold air. Eyes locked. To trade in these wings on some wheels"}}
{"song": "Thunder Road", "artist": "Heartland", "beat": 8, "timestamp": "3:30", "duration": "30s", "lyric_line": "Climb in back, heaven's waiting down the tracks", "scene": {"mood": "defiance", "colors": ["black", "neon green", "chrome"], "composition": "rule of thirds", "camera": "crane up", "description": "Low angle. Figure standing against the wind. Debris flying past. Unmoved. Climb in back, heaven's waiting down the tracks"}}
{"song": "Thunder Road", "artist": "Heartland", "beat": 9, "timestamp": "4:00", "duration": "30s", "lyric_line": "Oh oh oh oh oh oh oh", "scene": {"mood": "release", "colors": ["sky blue", "white", "pale gold"], "composition": "extreme wide", "camera": "tracking shot", "description": "Slow motion. Something falling \u2014 a mask, a chain, a weight. Lightness follows. Oh oh oh oh oh oh oh"}}
{"song": "Thunder Road", "artist": "Heartland", "beat": 10, "timestamp": "4:30", "duration": "30s", "lyric_line": "It's a town full of losers and I'm pulling out of here to win", "scene": {"mood": "catharsis", "colors": ["all white", "silver", "clear"], "composition": "medium shot", "camera": "slow tilt down", "description": "White space expanding. Figure dissolving into light. Peace in the dissolution. It's a town full of losers and I'm pulling out of here to win"}}
{"song": "Black Dog Howl", "artist": "Rust & Wire", "beat": 1, "timestamp": "0:00", "duration": "30s", "lyric_line": "Woke up on the floor again, whiskey still on my tongue", "scene": {"mood": "despair", "colors": ["navy", "black", "grey"], "composition": "wide shot", "camera": "static", "description": "Empty room. Single light source. Figure curled in corner. Rain on windows. Woke up on the floor again, whiskey still on my tongue"}}
{"song": "Black Dog Howl", "artist": "Rust & Wire", "beat": 2, "timestamp": "0:30", "duration": "30s", "lyric_line": "The mirror shows a stranger and the damage that I've done", "scene": {"mood": "anger", "colors": ["red", "black", "orange"], "composition": "close-up", "camera": "slow pan", "description": "Shattered glass. Red light. Hands clenched. Jaw tight. The frame vibrates. The mirror shows a stranger and the damage that I've done"}}
{"song": "Black Dog Howl", "artist": "Rust & Wire", "beat": 3, "timestamp": "1:00", "duration": "30s", "lyric_line": "I scream until my throat bleeds but nobody comes", "scene": {"mood": "frenzy", "colors": ["strobe", "red", "white flash"], "composition": "over the shoulder", "camera": "dolly in", "description": "Strobe lighting. Multiple exposures. Bodies colliding. Chaos as composition. I scream until my throat bleeds but nobody comes"}}
{"song": "Black Dog Howl", "artist": "Rust & Wire", "beat": 4, "timestamp": "1:30", "duration": "30s", "lyric_line": "The walls are closing in again, the ceiling pressing down", "scene": {"mood": "exhaustion", "colors": ["grey", "brown", "faded"], "composition": "low angle", "camera": "dolly out", "description": "Static shot. Figure slumped. Eyes half-closed. Time passing in shadows. The walls are closing in again, the ceiling pressing down"}}
{"song": "Black Dog Howl", "artist": "Rust & Wire", "beat": 5, "timestamp": "2:00", "duration": "30s", "lyric_line": "I tried to call your number but you changed it years ago", "scene": {"mood": "resignation", "colors": ["grey", "muted blue", "beige"], "composition": "high angle", "camera": "handheld", "description": "Medium shot. Hands dropping keys on a table. Turning away. Not looking back. I tried to call your number but you changed it years ago"}}
{"song": "Black Dog Howl", "artist": "Rust & Wire", "beat": 6, "timestamp": "2:30", "duration": "30s", "lyric_line": "Now I'm howling at the moon like some rabid dog I know", "scene": {"mood": "grief", "colors": ["deep purple", "black", "silver"], "composition": "dutch angle", "camera": "steadicam", "description": "Wide shot. Figure alone in vast space. Dark purple sky. No horizon line. Now I'm howling at the moon like some rabid dog I know"}}
{"song": "Black Dog Howl", "artist": "Rust & Wire", "beat": 7, "timestamp": "3:00", "duration": "30s", "lyric_line": "Every bone remembers what my mind wants to forget", "scene": {"mood": "numbness", "colors": ["white", "grey", "no color"], "composition": "symmetrical", "camera": "slow zoom", "description": "Desaturated. Figure staring at nothing. World moving around them in blur. Every bone remembers what my mind wants to forget"}}
{"song": "Black Dog Howl", "artist": "Rust & Wire", "beat": 8, "timestamp": "3:30", "duration": "30s", "lyric_line": "I'll tear this whole house down before the sun comes up", "scene": {"mood": "rage", "colors": ["fire red", "black", "ember orange"], "composition": "rule of thirds", "camera": "crane up", "description": "Red wash. Extreme close-up on eyes. Fire reflected in pupils. I'll tear this whole house down before the sun comes up"}}
{"song": "Black Dog Howl", "artist": "Rust & Wire", "beat": 9, "timestamp": "4:00", "duration": "30s", "lyric_line": "Ash and ruin everywhere, this is all that's left", "scene": {"mood": "acceptance", "colors": ["soft blue", "warm grey", "sage"], "composition": "extreme wide", "camera": "tracking shot", "description": "Soft focus. Gentle light. Figure breathing. The camera doesn't judge. Ash and ruin everywhere, this is all that's left"}}
{"song": "Black Dog Howl", "artist": "Rust & Wire", "beat": 10, "timestamp": "4:30", "duration": "30s", "lyric_line": "Silence. Just the wind through broken glass.", "scene": {"mood": "silence", "colors": ["black", "void", "faint starlight"], "composition": "medium shot", "camera": "slow tilt down", "description": "Black screen. Faint starlight. The sound drops out completely. Silence. Just the wind through broken glass."}}
{"song": "Satellite Hearts", "artist": "Neon Circuit", "beat": 1, "timestamp": "0:00", "duration": "30s", "lyric_line": "Ten thousand miles of static between your voice and mine", "scene": {"mood": "wonder", "colors": ["aurora green", "violet", "silver"], "composition": "wide shot", "camera": "static", "description": "Northern lights overhead. Figure looking up. Mouth open. Child's expression. Ten thousand miles of static between your voice and mine"}}
{"song": "Satellite Hearts", "artist": "Neon Circuit", "beat": 2, "timestamp": "0:30", "duration": "30s", "lyric_line": "I trace your constellation on the dashboard every night", "scene": {"mood": "isolation", "colors": ["cold blue", "black", "distant starlight"], "composition": "close-up", "camera": "slow pan", "description": "Extreme wide. Single figure. Vast empty landscape. Scale crushing. I trace your constellation on the dashboard every night"}}
{"song": "Satellite Hearts", "artist": "Neon Circuit", "beat": 3, "timestamp": "1:00", "duration": "30s", "lyric_line": "The signal fades to nothing but I keep the frequency", "scene": {"mood": "longing", "colors": ["teal", "silver", "moonlight"], "composition": "over the shoulder", "camera": "dolly in", "description": "Through a window. Figure on the other side. Glass between. Breath on the pane. The signal fades to nothing but I keep the frequency"}}
{"song": "Satellite Hearts", "artist": "Neon Circuit", "beat": 4, "timestamp": "1:30", "duration": "30s", "lyric_line": "Then suddenly your laughter breaks through like a summer storm", "scene": {"mood": "connection", "colors": ["warm gold", "rose", "blush"], "composition": "low angle", "camera": "dolly out", "description": "Two hands reaching. Fingers almost touching. Warm light between them. Then suddenly your laughter breaks through like a summer storm"}}
{"song": "Satellite Hearts", "artist": "Neon Circuit", "beat": 5, "timestamp": "2:00", "duration": "30s", "lyric_line": "We're dancing in the data stream, our pixels intertwined", "scene": {"mood": "euphoria", "colors": ["neon", "rainbow", "white flash"], "composition": "high angle", "camera": "handheld", "description": "Overexposed. Everything bright. Dancing. The frame can't contain the joy. We're dancing in the data stream, our pixels intertwined"}}
{"song": "Satellite Hearts", "artist": "Neon Circuit", "beat": 6, "timestamp": "2:30", "duration": "30s", "lyric_line": "But I can't tell if you're real or just a ghost in the machine", "scene": {"mood": "confusion", "colors": ["swirling", "unsettled", "green-grey"], "composition": "dutch angle", "camera": "steadicam", "description": "Multiple focal points. Nothing sharp. The viewer doesn't know where to look. But I can't tell if you're real or just a ghost in the machine"}}
{"song": "Satellite Hearts", "artist": "Neon Circuit", "beat": 7, "timestamp": "3:00", "duration": "30s", "lyric_line": "The picture clears and there you are \u2014 imperfect, warm, alive", "scene": {"mood": "clarity", "colors": ["clear blue", "white", "crisp"], "composition": "symmetrical", "camera": "slow zoom", "description": "Rack focus. Background blurs, foreground sharpens. Suddenly everything makes sense. The picture clears and there you are \u2014 imperfect, warm, alive"}}
{"song": "Satellite Hearts", "artist": "Neon Circuit", "beat": 8, "timestamp": "3:30", "duration": "30s", "lyric_line": "Your hand reaches through the screen, I swear I feel the heat", "scene": {"mood": "tenderness", "colors": ["blush pink", "warm cream", "soft gold"], "composition": "rule of thirds", "camera": "crane up", "description": "Close on a hand touching a face. Soft light. Shallow depth of field. Your hand reaches through the screen, I swear I feel the heat"}}
{"song": "Satellite Hearts", "artist": "Neon Circuit", "beat": 9, "timestamp": "4:00", "duration": "30s", "lyric_line": "The bandwidth's dying, say it now before the link goes dark", "scene": {"mood": "urgency", "colors": ["red", "black", "strobe white"], "composition": "extreme wide", "camera": "tracking shot", "description": "Handheld camera running. Blurred faces. Traffic. Heartbeat sound design. The bandwidth's dying, say it now before the link goes dark"}}
{"song": "Satellite Hearts", "artist": "Neon Circuit", "beat": 10, "timestamp": "4:30", "duration": "30s", "lyric_line": "Goodnight, satellite heart. I'll find you in the static.", "scene": {"mood": "bittersweet", "colors": ["amber", "lavender", "fading light"], "composition": "medium shot", "camera": "slow tilt down", "description": "Amber light fading. A smile that's also a goodbye. Beautiful and sad at once. Goodnight, satellite heart. I'll find you in the static."}}
{"song": "Concrete Garden", "artist": "Streetlight Prophet", "beat": 1, "timestamp": "0:00", "duration": "30s", "lyric_line": "They paved over every green thing when the developers came", "scene": {"mood": "oppression", "colors": ["concrete grey", "brown", "exhaust fume yellow"], "composition": "wide shot", "camera": "static", "description": "Concrete. Overpasses. No sky visible. Figures small against infrastructure. They paved over every green thing when the developers came"}}
{"song": "Concrete Garden", "artist": "Streetlight Prophet", "beat": 2, "timestamp": "0:30", "duration": "30s", "lyric_line": "But we planted seeds between the cracks and gave them all a name", "scene": {"mood": "resilience", "colors": ["green", "cracked concrete", "gold"], "composition": "close-up", "camera": "slow pan", "description": "Crack in pavement. Green shoot pushing through. Macro lens. But we planted seeds between the cracks and gave them all a name"}}
{"song": "Concrete Garden", "artist": "Streetlight Prophet", "beat": 3, "timestamp": "1:00", "duration": "30s", "lyric_line": "The mayor says progress looks like demolition and dust", "scene": {"mood": "anger", "colors": ["red", "black", "orange"], "composition": "over the shoulder", "camera": "dolly in", "description": "Shattered glass. Red light. Hands clenched. Jaw tight. The frame vibrates. The mayor says progress looks like demolition and dust"}}
{"song": "Concrete Garden", "artist": "Streetlight Prophet", "beat": 4, "timestamp": "1:30", "duration": "30s", "lyric_line": "But a dandelion broke through the asphalt this morning \u2014 that's us", "scene": {"mood": "beauty", "colors": ["wildflower colors", "green", "sunlight"], "composition": "low angle", "camera": "dolly out", "description": "Wildflowers in unexpected places. Color against grey. Nature reclaiming. But a dandelion broke through the asphalt this morning \u2014 that's us"}}
{"song": "Concrete Garden", "artist": "Streetlight Prophet", "beat": 5, "timestamp": "2:00", "duration": "30s", "lyric_line": "You can't kill what wants to live, can't silence what must sing", "scene": {"mood": "defiance", "colors": ["black", "neon green", "chrome"], "composition": "high angle", "camera": "handheld", "description": "Low angle. Figure standing against the wind. Debris flying past. Unmoved. You can't kill what wants to live, can't silence what must sing"}}
{"song": "Concrete Garden", "artist": "Streetlight Prophet", "beat": 6, "timestamp": "2:30", "duration": "30s", "lyric_line": "We're the roots beneath the road, we're the birds that built on string", "scene": {"mood": "community", "colors": ["warm tones", "string lights", "firelight"], "composition": "dutch angle", "camera": "steadicam", "description": "String lights. People gathered. Laughter out of focus. Warmth as visual language. We're the roots beneath the road, we're the birds that built on string"}}
{"song": "Concrete Garden", "artist": "Streetlight Prophet", "beat": 7, "timestamp": "3:00", "duration": "30s", "lyric_line": "When they tear the next block down we'll be dancing in the rubble", "scene": {"mood": "joy", "colors": ["bright", "multi", "saturated"], "composition": "symmetrical", "camera": "slow zoom", "description": "Saturated color. Wide smiles. Arms open. The world in full bloom. When they tear the next block down we'll be dancing in the rubble"}}
{"song": "Concrete Garden", "artist": "Streetlight Prophet", "beat": 8, "timestamp": "3:30", "duration": "30s", "lyric_line": "Every protest is a garden, every march plants something new", "scene": {"mood": "struggle", "colors": ["dust", "grey", "hard light"], "composition": "rule of thirds", "camera": "crane up", "description": "Close on hands working. Calluses. Dust. Effort visible in every frame. Every protest is a garden, every march plants something new"}}
{"song": "Concrete Garden", "artist": "Streetlight Prophet", "beat": 9, "timestamp": "4:00", "duration": "30s", "lyric_line": "The concrete is a drum and our footsteps keep the beat", "scene": {"mood": "growth", "colors": ["green", "brown", "morning light"], "composition": "extreme wide", "camera": "tracking shot", "description": "Time-lapse. Seed to flower. Sunrise to sunset. Transformation as rhythm. The concrete is a drum and our footsteps keep the beat"}}
{"song": "Concrete Garden", "artist": "Streetlight Prophet", "beat": 10, "timestamp": "4:30", "duration": "30s", "lyric_line": "Tomorrow there'll be flowers where they swore there'd only be defeat", "scene": {"mood": "hope", "colors": ["gold", "sky blue", "white"], "composition": "medium shot", "camera": "slow tilt down", "description": "Open horizon. Golden light breaking through clouds. The figure silhouetted against dawn. Tomorrow there'll be flowers where they swore there'd only be defeat"}}
{"song": "Gravity Well", "artist": "Void Walker", "beat": 1, "timestamp": "0:00", "duration": "30s", "lyric_line": "I felt the pull before I saw the edge", "scene": {"mood": "dread", "colors": ["void black", "deep red", "cold white"], "composition": "wide shot", "camera": "static", "description": "Corner of frame. Something in the periphery. Dark. The camera doesn't look directly. I felt the pull before I saw the edge"}}
{"song": "Gravity Well", "artist": "Void Walker", "beat": 2, "timestamp": "0:30", "duration": "30s", "lyric_line": "The stars bent sideways, light itself was dead", "scene": {"mood": "fascination", "colors": ["event horizon purple", "gravitational lens blue"], "composition": "close-up", "camera": "slow pan", "description": "Close on eyes. Reflection of something impossible. The pupil expands. The stars bent sideways, light itself was dead"}}
{"song": "Gravity Well", "artist": "Void Walker", "beat": 3, "timestamp": "1:00", "duration": "30s", "lyric_line": "I could have turned the ship around but something in me said stay", "scene": {"mood": "surrender", "colors": ["white", "dissolution", "prismatic"], "composition": "over the shoulder", "camera": "dolly in", "description": "Arms opening. Head back. Falling backward into something vast. I could have turned the ship around but something in me said stay"}}
{"song": "Gravity Well", "artist": "Void Walker", "beat": 4, "timestamp": "1:30", "duration": "30s", "lyric_line": "The event horizon glows like a halo made of nothing", "scene": {"mood": "awe", "colors": ["starfield", "nebula colors", "infinite dark"], "composition": "low angle", "camera": "dolly out", "description": "Wide shot of cosmos. Nebula. Stars being born. Human figure tiny at bottom. The event horizon glows like a halo made of nothing"}}
{"song": "Gravity Well", "artist": "Void Walker", "beat": 5, "timestamp": "2:00", "duration": "30s", "lyric_line": "Time stretches thin as wire, each second takes a year", "scene": {"mood": "terror", "colors": ["black", "red shift", "distortion"], "composition": "high angle", "camera": "handheld", "description": "Shaking camera. Red shift. Something approaching fast. The frame distorts. Time stretches thin as wire, each second takes a year"}}
{"song": "Gravity Well", "artist": "Void Walker", "beat": 6, "timestamp": "2:30", "duration": "30s", "lyric_line": "I am both the observer and the thing that disappears", "scene": {"mood": "peace", "colors": ["deep space black", "starlight", "calm"], "composition": "dutch angle", "camera": "steadicam", "description": "Still water. Stars reflected. Perfect mirror. No movement. No sound. I am both the observer and the thing that disappears"}}
{"song": "Gravity Well", "artist": "Void Walker", "beat": 7, "timestamp": "3:00", "duration": "30s", "lyric_line": "My body reads the tidal forces like sheet music played on bone", "scene": {"mood": "disorientation", "colors": ["warped", "chromatic aberration", "bent light"], "composition": "symmetrical", "camera": "slow zoom", "description": "Warped lens. Vertigo. Walls becoming floor. Gravity is a suggestion. My body reads the tidal forces like sheet music played on bone"}}
{"song": "Gravity Well", "artist": "Void Walker", "beat": 8, "timestamp": "3:30", "duration": "30s", "lyric_line": "I stop fighting, stop reaching, stop calling home", "scene": {"mood": "acceptance", "colors": ["soft blue", "warm grey", "sage"], "composition": "rule of thirds", "camera": "crane up", "description": "Soft focus. Gentle light. Figure breathing. The camera doesn't judge. I stop fighting, stop reaching, stop calling home"}}
{"song": "Gravity Well", "artist": "Void Walker", "beat": 9, "timestamp": "4:00", "duration": "30s", "lyric_line": "There is a peace in dissolution I was never meant to know", "scene": {"mood": "transcendence", "colors": ["pure white", "beyond visible", "golden"], "composition": "extreme wide", "camera": "tracking shot", "description": "Pure white expanding. Figure becoming light. Boundaries dissolving. There is a peace in dissolution I was never meant to know"}}
{"song": "Gravity Well", "artist": "Void Walker", "beat": 10, "timestamp": "4:30", "duration": "30s", "lyric_line": "Singularity. Silence. Everything and nothing both at once.", "scene": {"mood": "emptiness", "colors": ["void", "absolute black", "nothing"], "composition": "medium shot", "camera": "slow tilt down", "description": "Absolute black. No stars. No reference point. The void looking back. Singularity. Silence. Everything and nothing both at once."}}
{"song": "Rust Belt Lullaby", "artist": "Iron & Ember", "beat": 1, "timestamp": "0:00", "duration": "30s", "lyric_line": "My father's hands smelled like machine oil and prayer", "scene": {"mood": "nostalgia", "colors": ["amber", "sepia", "dusty rose"], "composition": "wide shot", "camera": "static", "description": "Sepia tones. A photograph come to life. Dust motes in afternoon light. My father's hands smelled like machine oil and prayer"}}
{"song": "Rust Belt Lullaby", "artist": "Iron & Ember", "beat": 2, "timestamp": "0:30", "duration": "30s", "lyric_line": "The factory whistle was our clock, the shift was our calendar", "scene": {"mood": "sadness", "colors": ["grey", "rain", "muted blue"], "composition": "close-up", "camera": "slow pan", "description": "Rain on glass. Grey light. A cup of tea going cold. Still life of loss. The factory whistle was our clock, the shift was our calendar"}}
{"song": "Rust Belt Lullaby", "artist": "Iron & Ember", "beat": 3, "timestamp": "1:00", "duration": "30s", "lyric_line": "He'd come home at midnight, wake me up to say goodnight", "scene": {"mood": "tenderness", "colors": ["blush pink", "warm cream", "soft gold"], "composition": "over the shoulder", "camera": "dolly in", "description": "Close on a hand touching a face. Soft light. Shallow depth of field. He'd come home at midnight, wake me up to say goodnight"}}
{"song": "Rust Belt Lullaby", "artist": "Iron & Ember", "beat": 4, "timestamp": "1:30", "duration": "30s", "lyric_line": "Now the mill is just a skeleton and he's been gone ten years", "scene": {"mood": "loss", "colors": ["faded", "dusty", "empty space"], "composition": "low angle", "camera": "dolly out", "description": "Empty chair. Dust settling. A coat still on a hook. Presence of absence. Now the mill is just a skeleton and he's been gone ten years"}}
{"song": "Rust Belt Lullaby", "artist": "Iron & Ember", "beat": 5, "timestamp": "2:00", "duration": "30s", "lyric_line": "But the river still runs brown with memory and rust", "scene": {"mood": "beauty", "colors": ["wildflower colors", "green", "sunlight"], "composition": "high angle", "camera": "handheld", "description": "Wildflowers in unexpected places. Color against grey. Nature reclaiming. But the river still runs brown with memory and rust"}}
{"song": "Rust Belt Lullaby", "artist": "Iron & Ember", "beat": 6, "timestamp": "2:30", "duration": "30s", "lyric_line": "I found his lunchbox in the attic, coffee stains still fresh", "scene": {"mood": "resignation", "colors": ["grey", "muted blue", "beige"], "composition": "dutch angle", "camera": "steadicam", "description": "Medium shot. Hands dropping keys on a table. Turning away. Not looking back. I found his lunchbox in the attic, coffee stains still fresh"}}
{"song": "Rust Belt Lullaby", "artist": "Iron & Ember", "beat": 7, "timestamp": "3:00", "duration": "30s", "lyric_line": "Some things don't decay \u2014 they just learn to hold still", "scene": {"mood": "love", "colors": ["neutral"], "composition": "symmetrical", "camera": "slow zoom", "description": "Visual interpretation of: Some things don't decay \u2014 they just learn to hold still"}}
{"song": "Rust Belt Lullaby", "artist": "Iron & Ember", "beat": 8, "timestamp": "3:30", "duration": "30s", "lyric_line": "I hum the songs he hummed to me though I've forgotten half the words", "scene": {"mood": "weariness", "colors": ["grey-brown", "faded", "dim"], "composition": "rule of thirds", "camera": "crane up", "description": "Slow movement. Heavy eyelids. The world in faded tones. Everything too much. I hum the songs he hummed to me though I've forgotten half the words"}}
{"song": "Rust Belt Lullaby", "artist": "Iron & Ember", "beat": 9, "timestamp": "4:00", "duration": "30s", "lyric_line": "The town's half-empty but the porch lights still come on at dusk", "scene": {"mood": "quiet hope", "colors": ["faint warm light", "candle glow", "dawn grey"], "composition": "extreme wide", "camera": "tracking shot", "description": "Faint warm light. Candle in dark room. Just enough to see by. The town's half-empty but the porch lights still come on at dusk"}}
{"song": "Rust Belt Lullaby", "artist": "Iron & Ember", "beat": 10, "timestamp": "4:30", "duration": "30s", "lyric_line": "Sleep now, rust belt baby. The furnace keeps us warm.", "scene": {"mood": "peace", "colors": ["deep space black", "starlight", "calm"], "composition": "medium shot", "camera": "slow tilt down", "description": "Still water. Stars reflected. Perfect mirror. No movement. No sound. Sleep now, rust belt baby. The furnace keeps us warm."}}
{"song": "Wildfire Sermon", "artist": "Prophet Ash", "beat": 1, "timestamp": "0:00", "duration": "30s", "lyric_line": "I didn't start the fire but I brought the gasoline", "scene": {"mood": "fury", "colors": ["dark red", "black", "flash"], "composition": "wide shot", "camera": "static", "description": "Dark red wash. Hands destroying. Frame shaking with rage. I didn't start the fire but I brought the gasoline"}}
{"song": "Wildfire Sermon", "artist": "Prophet Ash", "beat": 2, "timestamp": "0:30", "duration": "30s", "lyric_line": "Every sermon needs a spark and every spark needs a dream", "scene": {"mood": "ecstasy", "colors": ["fire", "gold", "blinding white"], "composition": "close-up", "camera": "slow pan", "description": "Fire and gold. Bodies arching. Light bursting from every surface. Every sermon needs a spark and every spark needs a dream"}}
{"song": "Wildfire Sermon", "artist": "Prophet Ash", "beat": 3, "timestamp": "1:00", "duration": "30s", "lyric_line": "The forest is a cathedral and the flames are choir boys singing", "scene": {"mood": "chaos", "colors": ["strobe", "fragmented", "clashing"], "composition": "over the shoulder", "camera": "dolly in", "description": "Fragmented frame. Collage. Everything at once. Order is a memory. The forest is a cathedral and the flames are choir boys singing"}}
{"song": "Wildfire Sermon", "artist": "Prophet Ash", "beat": 4, "timestamp": "1:30", "duration": "30s", "lyric_line": "Watch the old world burn \u2014 isn't the light beautiful?", "scene": {"mood": "joy", "colors": ["bright", "multi", "saturated"], "composition": "low angle", "camera": "dolly out", "description": "Saturated color. Wide smiles. Arms open. The world in full bloom. Watch the old world burn \u2014 isn't the light beautiful?"}}
{"song": "Wildfire Sermon", "artist": "Prophet Ash", "beat": 5, "timestamp": "2:00", "duration": "30s", "lyric_line": "We'll dance in the embers, we'll make love in the ash", "scene": {"mood": "destruction", "colors": ["fire", "ash", "smoke orange"], "composition": "high angle", "camera": "handheld", "description": "Fire. Ash falling like snow. Structures collapsing. Beautiful in its terrible way. We'll dance in the embers, we'll make love in the ash"}}
{"song": "Wildfire Sermon", "artist": "Prophet Ash", "beat": 6, "timestamp": "2:30", "duration": "30s", "lyric_line": "From destruction comes the soil where new things grow at last", "scene": {"mood": "creation", "colors": ["green", "light", "warm gold"], "composition": "dutch angle", "camera": "steadicam", "description": "Hands shaping clay. Light emerging from dark. Something new being born. From destruction comes the soil where new things grow at last"}}
{"song": "Wildfire Sermon", "artist": "Prophet Ash", "beat": 7, "timestamp": "3:00", "duration": "30s", "lyric_line": "But don't mistake the warmth for safety, don't mistake the glow for home", "scene": {"mood": "warning", "colors": ["red flash", "amber", "siren"], "composition": "symmetrical", "camera": "slow zoom", "description": "Red flash. Siren light. The calm before. Then: impact. But don't mistake the warmth for safety, don't mistake the glow for home"}}
{"song": "Wildfire Sermon", "artist": "Prophet Ash", "beat": 8, "timestamp": "3:30", "duration": "30s", "lyric_line": "Come closer, come closer \u2014 I promise the burning feels like flying", "scene": {"mood": "invitation", "colors": ["warm", "open", "golden"], "composition": "rule of thirds", "camera": "crane up", "description": "Open door. Warm light spilling out. A hand extended. Come in. Come closer, come closer \u2014 I promise the burning feels like flying"}}
{"song": "Wildfire Sermon", "artist": "Prophet Ash", "beat": 9, "timestamp": "4:00", "duration": "30s", "lyric_line": "We threw everything we owned into the blaze and laughed", "scene": {"mood": "abandon", "colors": ["wild", "free", "untethered"], "composition": "extreme wide", "camera": "tracking shot", "description": "Running through a field. Hair wild. No destination. Just movement. We threw everything we owned into the blaze and laughed"}}
{"song": "Wildfire Sermon", "artist": "Prophet Ash", "beat": 10, "timestamp": "4:30", "duration": "30s", "lyric_line": "Morning. Smoke. Green shoots. Begin again.", "scene": {"mood": "rebirth", "colors": ["green shoots", "dawn", "clear"], "composition": "medium shot", "camera": "slow tilt down", "description": "Dawn. Green shoots in ash. First breath after drowning. Morning. Smoke. Green shoots. Begin again."}}
{"song": "Midnight Transmission", "artist": "Frequency Ghost", "beat": 1, "timestamp": "0:00", "duration": "30s", "lyric_line": "There's a voice on the radio that shouldn't be there", "scene": {"mood": "mystery", "colors": ["deep blue", "shadow", "candle"], "composition": "wide shot", "camera": "static", "description": "Shadow figure in doorway. Candle. Face half-lit. Eyes knowing. There's a voice on the radio that shouldn't be there"}}
{"song": "Midnight Transmission", "artist": "Frequency Ghost", "beat": 2, "timestamp": "0:30", "duration": "30s", "lyric_line": "Speaking my name in a language I almost understand", "scene": {"mood": "loneliness", "colors": ["single light", "dark", "cold blue"], "composition": "close-up", "camera": "slow pan", "description": "Single light in vast dark. Figure beneath it. Nothing else. Speaking my name in a language I almost understand"}}
{"song": "Midnight Transmission", "artist": "Frequency Ghost", "beat": 3, "timestamp": "1:00", "duration": "30s", "lyric_line": "I turn the dial but it follows like a shadow made of sound", "scene": {"mood": "curiosity", "colors": ["warm yellow", "spotlight", "discovery"], "composition": "over the shoulder", "camera": "dolly in", "description": "Light moving across a surface. Discovery. Eyes widening. I turn the dial but it follows like a shadow made of sound"}}
{"song": "Midnight Transmission", "artist": "Frequency Ghost", "beat": 4, "timestamp": "1:30", "duration": "30s", "lyric_line": "Then it says something only I would know, something buried deep", "scene": {"mood": "connection", "colors": ["warm gold", "rose", "blush"], "composition": "low angle", "camera": "dolly out", "description": "Two hands reaching. Fingers almost touching. Warm light between them. Then it says something only I would know, something buried deep"}}
{"song": "Midnight Transmission", "artist": "Frequency Ghost", "beat": 5, "timestamp": "2:00", "duration": "30s", "lyric_line": "I'm not afraid anymore \u2014 I'm listening", "scene": {"mood": "paranoia", "colors": ["surveillance green", "strobe", "red"], "composition": "high angle", "camera": "handheld", "description": "Surveillance angles. Green tint. Multiple screens. Watching. Being watched. I'm not afraid anymore \u2014 I'm listening"}}
{"song": "Midnight Transmission", "artist": "Frequency Ghost", "beat": 6, "timestamp": "2:30", "duration": "30s", "lyric_line": "The voice knows my dreams, it describes them back to me", "scene": {"mood": "intimacy", "colors": ["candlelight", "warm", "close"], "composition": "dutch angle", "camera": "steadicam", "description": "Candlelight only. Two faces close. Shared breath. The world outside forgotten. The voice knows my dreams, it describes them back to me"}}
{"song": "Midnight Transmission", "artist": "Frequency Ghost", "beat": 7, "timestamp": "3:00", "duration": "30s", "lyric_line": "We're having a conversation across some membrane I can't see", "scene": {"mood": "urgency", "colors": ["red", "black", "strobe white"], "composition": "symmetrical", "camera": "slow zoom", "description": "Handheld camera running. Blurred faces. Traffic. Heartbeat sound design. We're having a conversation across some membrane I can't see"}}
{"song": "Midnight Transmission", "artist": "Frequency Ghost", "beat": 8, "timestamp": "3:30", "duration": "30s", "lyric_line": "Then static. Then nothing. Then a whisper: find me", "scene": {"mood": "disconnection", "colors": ["static", "grey", "broken signal"], "composition": "rule of thirds", "camera": "crane up", "description": "Static. Snow on screen. A voice breaking up. Distance measured in noise. Then static. Then nothing. Then a whisper: find me"}}
{"song": "Midnight Transmission", "artist": "Frequency Ghost", "beat": 9, "timestamp": "4:00", "duration": "30s", "lyric_line": "I search every frequency but the voice is gone", "scene": {"mood": "searching", "colors": ["flashlight beam", "dark", "moving light"], "composition": "extreme wide", "camera": "tracking shot", "description": "Flashlight beam cutting dark. Moving. Looking. Not finding yet. I search every frequency but the voice is gone"}}
{"song": "Midnight Transmission", "artist": "Frequency Ghost", "beat": 10, "timestamp": "4:30", "duration": "30s", "lyric_line": "Some nights I still hear it, faint, like a song in another room", "scene": {"mood": "haunting", "colors": ["faint blue", "echo", "silver"], "composition": "medium shot", "camera": "slow tilt down", "description": "Faint blue light. Echo of a figure. Present and absent simultaneously. Some nights I still hear it, faint, like a song in another room"}}
{"song": "Crown of Thorns and Roses", "artist": "Velvet Guillotine", "beat": 1, "timestamp": "0:00", "duration": "30s", "lyric_line": "I wore your love like a weapon and you never felt the blade", "scene": {"mood": "seduction", "colors": ["deep red", "velvet", "candlelight"], "composition": "wide shot", "camera": "static", "description": "Deep red. Velvet textures. Slow movement. Eyes that promise. I wore your love like a weapon and you never felt the blade"}}
{"song": "Crown of Thorns and Roses", "artist": "Velvet Guillotine", "beat": 2, "timestamp": "0:30", "duration": "30s", "lyric_line": "Every kiss was a negotiation, every touch a trade", "scene": {"mood": "power", "colors": ["gold", "black", "crimson"], "composition": "close-up", "camera": "slow pan", "description": "Throne. Gold. Black. The figure doesn't move. Doesn't need to. Every kiss was a negotiation, every touch a trade"}}
{"song": "Crown of Thorns and Roses", "artist": "Velvet Guillotine", "beat": 3, "timestamp": "1:00", "duration": "30s", "lyric_line": "The throne room smells like jasmine and someone else's fear", "scene": {"mood": "cruelty", "colors": ["cold silver", "black", "sharp white"], "composition": "over the shoulder", "camera": "dolly in", "description": "Silver blade. Cold light. A smile that doesn't reach the eyes. The throne room smells like jasmine and someone else's fear"}}
{"song": "Crown of Thorns and Roses", "artist": "Velvet Guillotine", "beat": 4, "timestamp": "1:30", "duration": "30s", "lyric_line": "I am beautiful when I'm angry \u2014 haven't you heard?", "scene": {"mood": "beauty", "colors": ["wildflower colors", "green", "sunlight"], "composition": "low angle", "camera": "dolly out", "description": "Wildflowers in unexpected places. Color against grey. Nature reclaiming. I am beautiful when I'm angry \u2014 haven't you heard?"}}
{"song": "Crown of Thorns and Roses", "artist": "Velvet Guillotine", "beat": 5, "timestamp": "2:00", "duration": "30s", "lyric_line": "Don't mistake my gentleness for weakness, darling", "scene": {"mood": "danger", "colors": ["red", "black", "warning yellow"], "composition": "high angle", "camera": "handheld", "description": "Red and black. Warning signs. The frame contracts. Something approaches. Don't mistake my gentleness for weakness, darling"}}
{"song": "Crown of Thorns and Roses", "artist": "Velvet Guillotine", "beat": 6, "timestamp": "2:30", "duration": "30s", "lyric_line": "I chose to be kind. I could burn this kingdom down.", "scene": {"mood": "vulnerability", "colors": ["soft", "exposed", "raw"], "composition": "dutch angle", "camera": "steadicam", "description": "Exposed skin. Soft light. Eyes open. Trust visible in every pore. I chose to be kind. I could burn this kingdom down."}}
{"song": "Crown of Thorns and Roses", "artist": "Velvet Guillotine", "beat": 7, "timestamp": "3:00", "duration": "30s", "lyric_line": "The roses in my crown have thorns that curve inward", "scene": {"mood": "fury", "colors": ["dark red", "black", "flash"], "composition": "symmetrical", "camera": "slow zoom", "description": "Dark red wash. Hands destroying. Frame shaking with rage. The roses in my crown have thorns that curve inward"}}
{"song": "Crown of Thorns and Roses", "artist": "Velvet Guillotine", "beat": 8, "timestamp": "3:30", "duration": "30s", "lyric_line": "I bleed for my own sins, not for yours", "scene": {"mood": "grace", "colors": ["white", "silver", "flowing"], "composition": "rule of thirds", "camera": "crane up", "description": "White. Flowing. Movement without effort. The body as art. I bleed for my own sins, not for yours"}}
{"song": "Crown of Thorns and Roses", "artist": "Velvet Guillotine", "beat": 9, "timestamp": "4:00", "duration": "30s", "lyric_line": "Tonight I lay the crown aside and sleep without armor", "scene": {"mood": "revenge", "colors": ["dark", "steel", "cold blue"], "composition": "extreme wide", "camera": "tracking shot", "description": "Cold blue. Steel. The plan unfolding in shadows. Patience as weapon. Tonight I lay the crown aside and sleep without armor"}}
{"song": "Crown of Thorns and Roses", "artist": "Velvet Guillotine", "beat": 10, "timestamp": "4:30", "duration": "30s", "lyric_line": "Mercy. The hardest word. The only gift worth giving.", "scene": {"mood": "mercy", "colors": ["warm gold", "white", "gentle"], "composition": "medium shot", "camera": "slow tilt down", "description": "Warm gold. Hand lowering a weapon. Choosing not to. The harder path. Mercy. The hardest word. The only gift worth giving."}}
{"song": "Apartment 4B", "artist": "Wallpaper & Wire", "beat": 1, "timestamp": "0:00", "duration": "30s", "lyric_line": "Four walls, one window, a view of another wall", "scene": {"mood": "claustrophobia", "colors": ["close walls", "yellow bulb", "cramped"], "composition": "wide shot", "camera": "static", "description": "Walls close. Ceiling low. Yellow bulb. No escape visible. Four walls, one window, a view of another wall"}}
{"song": "Apartment 4B", "artist": "Wallpaper & Wire", "beat": 2, "timestamp": "0:30", "duration": "30s", "lyric_line": "The radiator clicks like a metronome for the damned", "scene": {"mood": "routine", "colors": ["grey", "institutional", "fluorescent"], "composition": "close-up", "camera": "slow pan", "description": "Fluorescent light. Same motion repeated. Clock on the wall. Time as loop. The radiator clicks like a metronome for the damned"}}
{"song": "Apartment 4B", "artist": "Wallpaper & Wire", "beat": 3, "timestamp": "1:00", "duration": "30s", "lyric_line": "I've memorized every crack in the ceiling \u2014 they form a map", "scene": {"mood": "desperation", "colors": ["scratching", "clawing", "raw"], "composition": "over the shoulder", "camera": "dolly in", "description": "Hands clawing. Fingernails against surface. Raw need. Nothing held back. I've memorized every crack in the ceiling \u2014 they form a map"}}
{"song": "Apartment 4B", "artist": "Wallpaper & Wire", "beat": 4, "timestamp": "1:30", "duration": "30s", "lyric_line": "In my mind I've left a hundred times, bought a farm, learned to fly", "scene": {"mood": "fantasy", "colors": ["dreamy", "pastel", "floating"], "composition": "low angle", "camera": "dolly out", "description": "Pastel. Floating. Impossible architecture. Gravity optional. In my mind I've left a hundred times, bought a farm, learned to fly"}}
{"song": "Apartment 4B", "artist": "Wallpaper & Wire", "beat": 5, "timestamp": "2:00", "duration": "30s", "lyric_line": "Then one morning I open the door and just walk out", "scene": {"mood": "breakthrough", "colors": ["white burst", "open sky", "blinding"], "composition": "high angle", "camera": "handheld", "description": "White burst. Wall shattering. Open sky beyond. Freedom as explosion. Then one morning I open the door and just walk out"}}
{"song": "Apartment 4B", "artist": "Wallpaper & Wire", "beat": 6, "timestamp": "2:30", "duration": "30s", "lyric_line": "The hallway is an ocean, the stairs are a mountain range", "scene": {"mood": "freedom", "colors": ["open sky", "blue", "green"], "composition": "dutch angle", "camera": "steadicam", "description": "Open road. Blue sky. Green fields. Wind in hair. No walls. The hallway is an ocean, the stairs are a mountain range"}}
{"song": "Apartment 4B", "artist": "Wallpaper & Wire", "beat": 7, "timestamp": "3:00", "duration": "30s", "lyric_line": "The street hits me like cold water and I almost go back", "scene": {"mood": "fear", "colors": ["cold", "dark", "sharp"], "composition": "symmetrical", "camera": "slow zoom", "description": "Cold. Dark. Sharp edges. The frame contracts. Something unseen. The street hits me like cold water and I almost go back"}}
{"song": "Apartment 4B", "artist": "Wallpaper & Wire", "beat": 8, "timestamp": "3:30", "duration": "30s", "lyric_line": "But the sky \u2014 have you seen the sky? It goes on forever", "scene": {"mood": "joy", "colors": ["bright", "multi", "saturated"], "composition": "rule of thirds", "camera": "crane up", "description": "Saturated color. Wide smiles. Arms open. The world in full bloom. But the sky \u2014 have you seen the sky? It goes on forever"}}
{"song": "Apartment 4B", "artist": "Wallpaper & Wire", "beat": 9, "timestamp": "4:00", "duration": "30s", "lyric_line": "I stand on the sidewalk and cry because the world is so big", "scene": {"mood": "grounding", "colors": ["neutral"], "composition": "extreme wide", "camera": "tracking shot", "description": "Visual interpretation of: I stand on the sidewalk and cry because the world is so big"}}
{"song": "Apartment 4B", "artist": "Wallpaper & Wire", "beat": 10, "timestamp": "4:30", "duration": "30s", "lyric_line": "Home is not a place. Home is the moment you stop hiding.", "scene": {"mood": "home", "colors": ["neutral"], "composition": "medium shot", "camera": "slow tilt down", "description": "Visual interpretation of: Home is not a place. Home is the moment you stop hiding."}}
{"song": "Asphalt Kingdom", "artist": "Chrome Highway", "beat": 1, "timestamp": "0:00", "duration_seconds": 20, "lyric_line": "The engine roars before the guitar does", "scene": {"mood": "rebellion", "colors": ["red", "black", "chrome"], "composition": "silhouette frame", "camera": "dolly forward", "description": "A rebellion scene in rock register. silhouette frame framing. rack focus movement."}}
{"song": "Asphalt Kingdom", "artist": "Chrome Highway", "beat": 2, "timestamp": "0:20", "duration_seconds": 22, "lyric_line": "Asphalt kingdom, we own the shoulder", "scene": {"mood": "energy", "colors": ["orange", "red", "yellow"], "composition": "POV", "camera": "handheld sway", "description": "A energy scene in rock register. rule of thirds framing. crane up movement."}}
{"song": "Asphalt Kingdom", "artist": "Chrome Highway", "beat": 3, "timestamp": "0:42", "duration_seconds": 24, "lyric_line": "Distortion like a fist through glass", "scene": {"mood": "freedom", "colors": ["sky blue", "green", "gold"], "composition": "wide shot", "camera": "floating drift", "description": "A freedom scene in rock register. high angle framing. dolly forward movement."}}
{"song": "Asphalt Kingdom", "artist": "Chrome Highway", "beat": 4, "timestamp": "1:06", "duration_seconds": 22, "lyric_line": "The chorus is a road sign screaming", "scene": {"mood": "anger", "colors": ["red", "black", "iron grey"], "composition": "POV", "camera": "handheld sway", "description": "A anger scene in rock register. low angle framing. steady hold movement."}}
{"song": "Asphalt Kingdom", "artist": "Chrome Highway", "beat": 5, "timestamp": "1:28", "duration_seconds": 26, "lyric_line": "Every riff a mile marker", "scene": {"mood": "power", "colors": ["gold", "black", "deep red"], "composition": "silhouette frame", "camera": "slow zoom out", "description": "A power scene in rock register. dutch angle framing. steady hold movement."}}
{"song": "Asphalt Kingdom", "artist": "Chrome Highway", "beat": 6, "timestamp": "1:54", "duration_seconds": 22, "lyric_line": "The bridge — the road narrows", "scene": {"mood": "defiance", "colors": ["black", "red", "silver"], "composition": "high angle", "camera": "static", "description": "A defiance scene in rock register. silhouette frame framing. dolly forward movement."}}
{"song": "Asphalt Kingdom", "artist": "Chrome Highway", "beat": 7, "timestamp": "2:16", "duration_seconds": 24, "lyric_line": "Asphalt kingdom — no speed limits here", "scene": {"mood": "joy", "colors": ["bright gold", "warm white", "orange"], "composition": "silhouette frame", "camera": "crane up", "description": "A joy scene in rock register. rule of thirds framing. slow zoom out movement."}}
{"song": "Asphalt Kingdom", "artist": "Chrome Highway", "beat": 8, "timestamp": "2:40", "duration_seconds": 22, "lyric_line": "The solo is the horizon bending", "scene": {"mood": "chaos", "colors": ["red", "orange", "white flash"], "composition": "wide shot", "camera": "floating drift", "description": "A chaos scene in rock register. symmetrical framing. circular orbit movement."}}
{"song": "Asphalt Kingdom", "artist": "Chrome Highway", "beat": 9, "timestamp": "3:02", "duration_seconds": 24, "lyric_line": "Headlights like applause", "scene": {"mood": "triumph", "colors": ["gold", "red", "white"], "composition": "low angle", "camera": "tracking shot", "description": "A triumph scene in rock register. silhouette frame framing. rack focus movement."}}
{"song": "Asphalt Kingdom", "artist": "Chrome Highway", "beat": 10, "timestamp": "3:26", "duration_seconds": 28, "lyric_line": "Asphalt kingdom — the road never ends", "scene": {"mood": "afterglow", "colors": ["soft gold", "pink", "warm white"], "composition": "high angle", "camera": "slow zoom in", "description": "A afterglow scene in rock register. extreme close-up framing. floating drift movement."}}
{"song": "Satellite Hearts", "artist": "Orbit Collapse", "beat": 1, "timestamp": "0:00", "duration_seconds": 24, "lyric_line": "We launched our hearts into orbit", "scene": {"mood": "longing", "colors": ["slate blue", "silver", "dusk grey"], "composition": "close-up", "camera": "static", "description": "A longing scene in rock register. center frame framing. rack focus movement."}}
{"song": "Satellite Hearts", "artist": "Orbit Collapse", "beat": 2, "timestamp": "0:24", "duration_seconds": 22, "lyric_line": "Satellite hearts — broadcasting and alone", "scene": {"mood": "melancholy", "colors": ["navy", "steel grey", "teal"], "composition": "close-up", "camera": "static", "description": "A melancholy scene in rock register. rule of thirds framing. slow zoom out movement."}}
{"song": "Satellite Hearts", "artist": "Orbit Collapse", "beat": 3, "timestamp": "0:46", "duration_seconds": 26, "lyric_line": "The guitar feeds back like static from space", "scene": {"mood": "hope", "colors": ["pale gold", "sky blue", "white"], "composition": "POV", "camera": "static", "description": "A hope scene in rock register. silhouette frame framing. dolly forward movement."}}
{"song": "Satellite Hearts", "artist": "Orbit Collapse", "beat": 4, "timestamp": "1:12", "duration_seconds": 24, "lyric_line": "Every chord a transmission lost", "scene": {"mood": "despair", "colors": ["charcoal", "navy", "faded grey"], "composition": "symmetrical", "camera": "slow zoom out", "description": "A despair scene in rock register. center frame framing. rack focus movement."}}
{"song": "Satellite Hearts", "artist": "Orbit Collapse", "beat": 5, "timestamp": "1:36", "duration_seconds": 26, "lyric_line": "The drums pound like re-entry heat", "scene": {"mood": "anger", "colors": ["red", "black", "iron grey"], "composition": "rule of thirds", "camera": "slow zoom in", "description": "A anger scene in rock register. center frame framing. handheld sway movement."}}
{"song": "Satellite Hearts", "artist": "Orbit Collapse", "beat": 6, "timestamp": "2:02", "duration_seconds": 24, "lyric_line": "Satellite hearts — burning on the way down", "scene": {"mood": "beauty", "colors": ["white", "gold", "soft pink"], "composition": "bird's eye", "camera": "steady hold", "description": "A beauty scene in rock register. dutch angle framing. steady hold movement."}}
{"song": "Satellite Hearts", "artist": "Orbit Collapse", "beat": 7, "timestamp": "2:26", "duration_seconds": 26, "lyric_line": "A power chord the size of an atmosphere", "scene": {"mood": "resilience", "colors": ["green", "brown", "iron"], "composition": "center frame", "camera": "slow zoom in", "description": "A resilience scene in rock register. low angle framing. handheld sway movement."}}
{"song": "Satellite Hearts", "artist": "Orbit Collapse", "beat": 8, "timestamp": "2:52", "duration_seconds": 24, "lyric_line": "We crash-landed in the chorus", "scene": {"mood": "defiance", "colors": ["black", "red", "silver"], "composition": "dutch angle", "camera": "slow zoom out", "description": "A defiance scene in rock register. extreme close-up framing. tracking shot movement."}}
{"song": "Satellite Hearts", "artist": "Orbit Collapse", "beat": 9, "timestamp": "3:16", "duration_seconds": 26, "lyric_line": "The wreckage sounds beautiful from far away", "scene": {"mood": "triumph", "colors": ["gold", "red", "white"], "composition": "dutch angle", "camera": "circular orbit", "description": "A triumph scene in rock register. POV framing. tracking shot movement."}}
{"song": "Satellite Hearts", "artist": "Orbit Collapse", "beat": 10, "timestamp": "3:42", "duration_seconds": 28, "lyric_line": "Satellite hearts — the signal never stopped", "scene": {"mood": "peace", "colors": ["soft blue", "white", "sage green"], "composition": "rule of thirds", "camera": "dolly forward", "description": "A peace scene in rock register. center frame framing. crane up movement."}}
{"song": "Concrete Psalms", "artist": "Brutalist", "beat": 1, "timestamp": "0:00", "duration_seconds": 20, "lyric_line": "The amp stack rises like a tenement", "scene": {"mood": "anger", "colors": ["red", "black", "iron grey"], "composition": "wide shot", "camera": "static", "description": "A anger scene in rock register. close-up framing. static movement."}}
{"song": "Concrete Psalms", "artist": "Brutalist", "beat": 2, "timestamp": "0:20", "duration_seconds": 22, "lyric_line": "Concrete psalms in drop-D tuning", "scene": {"mood": "power", "colors": ["gold", "black", "deep red"], "composition": "rule of thirds", "camera": "handheld sway", "description": "A power scene in rock register. center frame framing. slow zoom out movement."}}
{"song": "Concrete Psalms", "artist": "Brutalist", "beat": 3, "timestamp": "0:42", "duration_seconds": 24, "lyric_line": "Every palm mute a brick laid", "scene": {"mood": "menace", "colors": ["dark green", "black", "purple"], "composition": "close-up", "camera": "steady hold", "description": "A menace scene in rock register. rule of thirds framing. steady hold movement."}}
{"song": "Concrete Psalms", "artist": "Brutalist", "beat": 4, "timestamp": "1:06", "duration_seconds": 22, "lyric_line": "The vocalist screams the building's name", "scene": {"mood": "fury", "colors": ["crimson", "dark grey", "fire orange"], "composition": "close-up", "camera": "slow zoom in", "description": "A fury scene in rock register. silhouette frame framing. floating drift movement."}}
{"song": "Concrete Psalms", "artist": "Brutalist", "beat": 5, "timestamp": "1:28", "duration_seconds": 26, "lyric_line": "Feedback like a fire escape bending", "scene": {"mood": "despair", "colors": ["charcoal", "navy", "faded grey"], "composition": "rule of thirds", "camera": "slow zoom in", "description": "A despair scene in rock register. high angle framing. slow zoom out movement."}}
{"song": "Concrete Psalms", "artist": "Brutalist", "beat": 6, "timestamp": "1:54", "duration_seconds": 22, "lyric_line": "Concrete psalms — the architecture of rage", "scene": {"mood": "strength", "colors": ["iron grey", "dark brown", "gold"], "composition": "POV", "camera": "circular orbit", "description": "A strength scene in rock register. symmetrical framing. crane up movement."}}
{"song": "Concrete Psalms", "artist": "Brutalist", "beat": 7, "timestamp": "2:16", "duration_seconds": 24, "lyric_line": "The breakdown is a demolition", "scene": {"mood": "defiance", "colors": ["black", "red", "silver"], "composition": "symmetrical", "camera": "rack focus", "description": "A defiance scene in rock register. bird's eye framing. static movement."}}
{"song": "Concrete Psalms", "artist": "Brutalist", "beat": 8, "timestamp": "2:40", "duration_seconds": 22, "lyric_line": "Rising from the rubble in harmonics", "scene": {"mood": "catharsis", "colors": ["gold", "white", "red"], "composition": "dutch angle", "camera": "crane up", "description": "A catharsis scene in rock register. rule of thirds framing. tracking shot movement."}}
{"song": "Concrete Psalms", "artist": "Brutalist", "beat": 9, "timestamp": "3:02", "duration_seconds": 24, "lyric_line": "The final chorus rebuilds the wall", "scene": {"mood": "triumph", "colors": ["gold", "red", "white"], "composition": "center frame", "camera": "crane up", "description": "A triumph scene in rock register. POV framing. steady hold movement."}}
{"song": "Concrete Psalms", "artist": "Brutalist", "beat": 10, "timestamp": "3:26", "duration_seconds": 28, "lyric_line": "Concrete psalms — standing after the storm", "scene": {"mood": "glory", "colors": ["gold", "white", "purple"], "composition": "bird's eye", "camera": "static", "description": "A glory scene in rock register. dutch angle framing. rack focus movement."}}
{"song": "Wildfire Sermon", "artist": "Tongues of Flame", "beat": 1, "timestamp": "0:00", "duration_seconds": 22, "lyric_line": "The preacher plays a Gibson like a weapon", "scene": {"mood": "fury", "colors": ["crimson", "dark grey", "fire orange"], "composition": "high angle", "camera": "circular orbit", "description": "A fury scene in rock register. dutch angle framing. dolly forward movement."}}
{"song": "Wildfire Sermon", "artist": "Tongues of Flame", "beat": 2, "timestamp": "0:22", "duration_seconds": 24, "lyric_line": "Wildfire sermon — the church is the venue", "scene": {"mood": "power", "colors": ["gold", "black", "deep red"], "composition": "symmetrical", "camera": "rack focus", "description": "A power scene in rock register. wide shot framing. floating drift movement."}}
{"song": "Wildfire Sermon", "artist": "Tongues of Flame", "beat": 3, "timestamp": "0:46", "duration_seconds": 26, "lyric_line": "Every lick a tongue of flame", "scene": {"mood": "frenzy", "colors": ["red", "white flash", "orange"], "composition": "rule of thirds", "camera": "steady hold", "description": "A frenzy scene in rock register. close-up framing. static movement."}}
{"song": "Wildfire Sermon", "artist": "Tongues of Flame", "beat": 4, "timestamp": "1:12", "duration_seconds": 24, "lyric_line": "The congregation moshes at the altar", "scene": {"mood": "ecstasy", "colors": ["gold", "red", "white"], "composition": "low angle", "camera": "crane up", "description": "A ecstasy scene in rock register. POV framing. static movement."}}
{"song": "Wildfire Sermon", "artist": "Tongues of Flame", "beat": 5, "timestamp": "1:36", "duration_seconds": 26, "lyric_line": "The sermon is a guitar solo", "scene": {"mood": "danger", "colors": ["red", "black", "orange"], "composition": "dutch angle", "camera": "floating drift", "description": "A danger scene in rock register. extreme close-up framing. dolly forward movement."}}
{"song": "Wildfire Sermon", "artist": "Tongues of Flame", "beat": 6, "timestamp": "2:02", "duration_seconds": 24, "lyric_line": "Wildfire sermon — speaking in distortion", "scene": {"mood": "catharsis", "colors": ["gold", "white", "red"], "composition": "bird's eye", "camera": "dolly forward", "description": "A catharsis scene in rock register. rule of thirds framing. circular orbit movement."}}
{"song": "Wildfire Sermon", "artist": "Tongues of Flame", "beat": 7, "timestamp": "2:26", "duration_seconds": 26, "lyric_line": "The holy ghost is a wah pedal", "scene": {"mood": "pride", "colors": ["gold", "purple", "red"], "composition": "close-up", "camera": "slow zoom in", "description": "A pride scene in rock register. symmetrical framing. handheld sway movement."}}
{"song": "Wildfire Sermon", "artist": "Tongues of Flame", "beat": 8, "timestamp": "2:52", "duration_seconds": 24, "lyric_line": "Amen in power chords", "scene": {"mood": "triumph", "colors": ["gold", "red", "white"], "composition": "rule of thirds", "camera": "circular orbit", "description": "A triumph scene in rock register. dutch angle framing. crane up movement."}}
{"song": "Wildfire Sermon", "artist": "Tongues of Flame", "beat": 9, "timestamp": "3:16", "duration_seconds": 26, "lyric_line": "The flames die but the heat remains", "scene": {"mood": "aftermath", "colors": ["black", "grey", "red"], "composition": "extreme close-up", "camera": "handheld sway", "description": "A aftermath scene in rock register. center frame framing. rack focus movement."}}
{"song": "Wildfire Sermon", "artist": "Tongues of Flame", "beat": 10, "timestamp": "3:42", "duration_seconds": 28, "lyric_line": "Wildfire sermon — the ashes testify", "scene": {"mood": "peace", "colors": ["soft blue", "white", "sage green"], "composition": "POV", "camera": "crane up", "description": "A peace scene in rock register. extreme close-up framing. crane up movement."}}
{"song": "Rust Belt Lullaby", "artist": "Iron Lung", "beat": 1, "timestamp": "0:00", "duration_seconds": 24, "lyric_line": "The factory whistle is the intro", "scene": {"mood": "melancholy", "colors": ["navy", "steel grey", "teal"], "composition": "dutch angle", "camera": "tracking shot", "description": "A melancholy scene in rock register. bird's eye framing. circular orbit movement."}}
{"song": "Rust Belt Lullaby", "artist": "Iron Lung", "beat": 2, "timestamp": "0:24", "duration_seconds": 22, "lyric_line": "Rust belt lullaby — the machines remember", "scene": {"mood": "nostalgia", "colors": ["sepia", "warm brown", "faded gold"], "composition": "extreme close-up", "camera": "tracking shot", "description": "A nostalgia scene in rock register. low angle framing. circular orbit movement."}}
{"song": "Rust Belt Lullaby", "artist": "Iron Lung", "beat": 3, "timestamp": "0:46", "duration_seconds": 26, "lyric_line": "A guitar like a foreman's last words", "scene": {"mood": "anger", "colors": ["red", "black", "iron grey"], "composition": "bird's eye", "camera": "circular orbit", "description": "A anger scene in rock register. close-up framing. tracking shot movement."}}
{"song": "Rust Belt Lullaby", "artist": "Iron Lung", "beat": 4, "timestamp": "1:12", "duration_seconds": 24, "lyric_line": "The bass line walks the assembly line", "scene": {"mood": "sorrow", "colors": ["deep blue", "grey", "silver"], "composition": "close-up", "camera": "crane up", "description": "A sorrow scene in rock register. silhouette frame framing. static movement."}}
{"song": "Rust Belt Lullaby", "artist": "Iron Lung", "beat": 5, "timestamp": "1:36", "duration_seconds": 26, "lyric_line": "Every shift a verse of consequence", "scene": {"mood": "resilience", "colors": ["green", "brown", "iron"], "composition": "wide shot", "camera": "dolly forward", "description": "A resilience scene in rock register. silhouette frame framing. tracking shot movement."}}
{"song": "Rust Belt Lullaby", "artist": "Iron Lung", "beat": 6, "timestamp": "2:02", "duration_seconds": 24, "lyric_line": "Rust belt lullaby — the furnace never sleeps", "scene": {"mood": "pride", "colors": ["gold", "purple", "red"], "composition": "POV", "camera": "floating drift", "description": "A pride scene in rock register. silhouette frame framing. handheld sway movement."}}
{"song": "Rust Belt Lullaby", "artist": "Iron Lung", "beat": 7, "timestamp": "2:26", "duration_seconds": 26, "lyric_line": "The solo is overtime, unpaid", "scene": {"mood": "strength", "colors": ["iron grey", "dark brown", "gold"], "composition": "extreme close-up", "camera": "dolly forward", "description": "A strength scene in rock register. dutch angle framing. crane up movement."}}
{"song": "Rust Belt Lullaby", "artist": "Iron Lung", "beat": 8, "timestamp": "2:52", "duration_seconds": 24, "lyric_line": "But it sounds like freedom anyway", "scene": {"mood": "hope", "colors": ["pale gold", "sky blue", "white"], "composition": "low angle", "camera": "dolly forward", "description": "A hope scene in rock register. wide shot framing. static movement."}}
{"song": "Rust Belt Lullaby", "artist": "Iron Lung", "beat": 9, "timestamp": "3:16", "duration_seconds": 26, "lyric_line": "The last note — the factory closing bell", "scene": {"mood": "defiance", "colors": ["black", "red", "silver"], "composition": "wide shot", "camera": "static", "description": "A defiance scene in rock register. wide shot framing. slow zoom in movement."}}
{"song": "Rust Belt Lullaby", "artist": "Iron Lung", "beat": 10, "timestamp": "3:42", "duration_seconds": 28, "lyric_line": "Rust belt lullaby — the steel remembers", "scene": {"mood": "glory", "colors": ["gold", "white", "purple"], "composition": "rule of thirds", "camera": "steady hold", "description": "A glory scene in rock register. high angle framing. slow zoom out movement."}}
{"song": "Neon Crucifix", "artist": "Electric Saints", "beat": 1, "timestamp": "0:00", "duration_seconds": 22, "lyric_line": "The neon crucifix flickers like a doubt", "scene": {"mood": "darkness", "colors": ["black", "grey", "red"], "composition": "low angle", "camera": "tracking shot", "description": "A darkness scene in rock register. high angle framing. slow zoom out movement."}}
{"song": "Neon Crucifix", "artist": "Electric Saints", "beat": 2, "timestamp": "0:22", "duration_seconds": 24, "lyric_line": "Bourbon and bass in the baptismal font", "scene": {"mood": "seduction", "colors": ["deep red", "black", "champagne"], "composition": "bird's eye", "camera": "tracking shot", "description": "A seduction scene in rock register. low angle framing. tracking shot movement."}}
{"song": "Neon Crucifix", "artist": "Electric Saints", "beat": 3, "timestamp": "0:46", "duration_seconds": 26, "lyric_line": "The riff is a prayer the church wouldn't accept", "scene": {"mood": "power", "colors": ["gold", "black", "deep red"], "composition": "silhouette frame", "camera": "circular orbit", "description": "A power scene in rock register. symmetrical framing. static movement."}}
{"song": "Neon Crucifix", "artist": "Electric Saints", "beat": 4, "timestamp": "1:12", "duration_seconds": 24, "lyric_line": "Neon crucifix — salvation in distortion", "scene": {"mood": "blasphemy", "colors": ["dark purple", "red", "black"], "composition": "bird's eye", "camera": "rack focus", "description": "A blasphemy scene in rock register. center frame framing. crane up movement."}}
{"song": "Neon Crucifix", "artist": "Electric Saints", "beat": 5, "timestamp": "1:36", "duration_seconds": 26, "lyric_line": "The chorus raises hell and hopes", "scene": {"mood": "beauty", "colors": ["white", "gold", "soft pink"], "composition": "center frame", "camera": "steady hold", "description": "A beauty scene in rock register. high angle framing. slow zoom in movement."}}
{"song": "Neon Crucifix", "artist": "Electric Saints", "beat": 6, "timestamp": "2:02", "duration_seconds": 24, "lyric_line": "Every solo a confession booth", "scene": {"mood": "danger", "colors": ["red", "black", "orange"], "composition": "center frame", "camera": "steady hold", "description": "A danger scene in rock register. close-up framing. static movement."}}
{"song": "Neon Crucifix", "artist": "Electric Saints", "beat": 7, "timestamp": "2:26", "duration_seconds": 26, "lyric_line": "Neon crucifix — the light that doesn't judge", "scene": {"mood": "ecstasy", "colors": ["gold", "red", "white"], "composition": "silhouette frame", "camera": "slow zoom out", "description": "A ecstasy scene in rock register. low angle framing. circular orbit movement."}}
{"song": "Neon Crucifix", "artist": "Electric Saints", "beat": 8, "timestamp": "2:52", "duration_seconds": 24, "lyric_line": "The bridge — three days of silence", "scene": {"mood": "transcendence", "colors": ["white", "gold", "silver"], "composition": "POV", "camera": "crane up", "description": "A transcendence scene in rock register. dutch angle framing. rack focus movement."}}
{"song": "Neon Crucifix", "artist": "Electric Saints", "beat": 9, "timestamp": "3:16", "duration_seconds": 26, "lyric_line": "Then the resurrection riff", "scene": {"mood": "glory", "colors": ["gold", "white", "purple"], "composition": "close-up", "camera": "circular orbit", "description": "A glory scene in rock register. bird's eye framing. circular orbit movement."}}
{"song": "Neon Crucifix", "artist": "Electric Saints", "beat": 10, "timestamp": "3:42", "duration_seconds": 28, "lyric_line": "Neon crucifix — faith in a frequency", "scene": {"mood": "peace", "colors": ["soft blue", "white", "sage green"], "composition": "center frame", "camera": "static", "description": "A peace scene in rock register. extreme close-up framing. handheld sway movement."}}
{"song": "Midnight Transmission", "artist": "Dead Signal", "beat": 1, "timestamp": "0:00", "duration_seconds": 24, "lyric_line": "The radio plays to no one at 3am", "scene": {"mood": "loneliness", "colors": ["dark blue", "grey", "silver"], "composition": "low angle", "camera": "dolly forward", "description": "A loneliness scene in rock register. wide shot framing. slow zoom out movement."}}
{"song": "Midnight Transmission", "artist": "Dead Signal", "beat": 2, "timestamp": "0:24", "duration_seconds": 22, "lyric_line": "Midnight transmission — the signal is the song", "scene": {"mood": "longing", "colors": ["slate blue", "silver", "dusk grey"], "composition": "silhouette frame", "camera": "rack focus", "description": "A longing scene in rock register. symmetrical framing. crane up movement."}}
{"song": "Midnight Transmission", "artist": "Dead Signal", "beat": 3, "timestamp": "0:46", "duration_seconds": 26, "lyric_line": "Distortion like insomnia", "scene": {"mood": "despair", "colors": ["charcoal", "navy", "faded grey"], "composition": "POV", "camera": "handheld sway", "description": "A despair scene in rock register. wide shot framing. static movement."}}
{"song": "Midnight Transmission", "artist": "Dead Signal", "beat": 4, "timestamp": "1:12", "duration_seconds": 24, "lyric_line": "The verse is the dark before the chorus", "scene": {"mood": "hope", "colors": ["pale gold", "sky blue", "white"], "composition": "high angle", "camera": "rack focus", "description": "A hope scene in rock register. close-up framing. floating drift movement."}}
{"song": "Midnight Transmission", "artist": "Dead Signal", "beat": 5, "timestamp": "1:36", "duration_seconds": 26, "lyric_line": "Every note a frequency of loneliness", "scene": {"mood": "anger", "colors": ["red", "black", "iron grey"], "composition": "wide shot", "camera": "slow zoom out", "description": "A anger scene in rock register. POV framing. slow zoom out movement."}}
{"song": "Midnight Transmission", "artist": "Dead Signal", "beat": 6, "timestamp": "2:02", "duration_seconds": 24, "lyric_line": "Midnight transmission — broadcasting into the void", "scene": {"mood": "beauty", "colors": ["white", "gold", "soft pink"], "composition": "extreme close-up", "camera": "slow zoom in", "description": "A beauty scene in rock register. close-up framing. slow zoom out movement."}}
{"song": "Midnight Transmission", "artist": "Dead Signal", "beat": 7, "timestamp": "2:26", "duration_seconds": 26, "lyric_line": "The guitar solo is someone answering", "scene": {"mood": "resilience", "colors": ["green", "brown", "iron"], "composition": "close-up", "camera": "tracking shot", "description": "A resilience scene in rock register. extreme close-up framing. static movement."}}
{"song": "Midnight Transmission", "artist": "Dead Signal", "beat": 8, "timestamp": "2:52", "duration_seconds": 24, "lyric_line": "Static like applause from nowhere", "scene": {"mood": "transcendence", "colors": ["white", "gold", "silver"], "composition": "rule of thirds", "camera": "handheld sway", "description": "A transcendence scene in rock register. high angle framing. steady hold movement."}}
{"song": "Midnight Transmission", "artist": "Dead Signal", "beat": 9, "timestamp": "3:16", "duration_seconds": 26, "lyric_line": "The last chord — the station signs off", "scene": {"mood": "triumph", "colors": ["gold", "red", "white"], "composition": "dutch angle", "camera": "floating drift", "description": "A triumph scene in rock register. high angle framing. rack focus movement."}}
{"song": "Midnight Transmission", "artist": "Dead Signal", "beat": 10, "timestamp": "3:42", "duration_seconds": 28, "lyric_line": "Midnight transmission — the silence receives", "scene": {"mood": "silence", "colors": ["white", "grey", "transparent"], "composition": "extreme close-up", "camera": "crane up", "description": "A silence scene in rock register. silhouette frame framing. floating drift movement."}}
{"song": "Thunder Road Confessional", "artist": "Gasket & Grace", "beat": 1, "timestamp": "0:00", "duration_seconds": 22, "lyric_line": "The open chord is an open road", "scene": {"mood": "freedom", "colors": ["sky blue", "green", "gold"], "composition": "close-up", "camera": "floating drift", "description": "A freedom scene in rock register. center frame framing. dolly forward movement."}}
{"song": "Thunder Road Confessional", "artist": "Gasket & Grace", "beat": 2, "timestamp": "0:22", "duration_seconds": 24, "lyric_line": "Thunder road confessional — sin at 80mph", "scene": {"mood": "joy", "colors": ["bright gold", "warm white", "orange"], "composition": "dutch angle", "camera": "crane up", "description": "A joy scene in rock register. rule of thirds framing. steady hold movement."}}
{"song": "Thunder Road Confessional", "artist": "Gasket & Grace", "beat": 3, "timestamp": "0:46", "duration_seconds": 26, "lyric_line": "Every mile marker a prayer", "scene": {"mood": "nostalgia", "colors": ["sepia", "warm brown", "faded gold"], "composition": "close-up", "camera": "slow zoom in", "description": "A nostalgia scene in rock register. extreme close-up framing. slow zoom in movement."}}
{"song": "Thunder Road Confessional", "artist": "Gasket & Grace", "beat": 4, "timestamp": "1:12", "duration_seconds": 24, "lyric_line": "The backbeat is the engine", "scene": {"mood": "longing", "colors": ["slate blue", "silver", "dusk grey"], "composition": "POV", "camera": "handheld sway", "description": "A longing scene in rock register. silhouette frame framing. slow zoom in movement."}}
{"song": "Thunder Road Confessional", "artist": "Gasket & Grace", "beat": 5, "timestamp": "1:36", "duration_seconds": 26, "lyric_line": "Thunder road confessional — absolution by asphalt", "scene": {"mood": "anger", "colors": ["red", "black", "iron grey"], "composition": "symmetrical", "camera": "steady hold", "description": "A anger scene in rock register. rule of thirds framing. static movement."}}
{"song": "Thunder Road Confessional", "artist": "Gasket & Grace", "beat": 6, "timestamp": "2:02", "duration_seconds": 24, "lyric_line": "The bridge is the state line", "scene": {"mood": "sorrow", "colors": ["deep blue", "grey", "silver"], "composition": "POV", "camera": "static", "description": "A sorrow scene in rock register. extreme close-up framing. handheld sway movement."}}
{"song": "Thunder Road Confessional", "artist": "Gasket & Grace", "beat": 7, "timestamp": "2:26", "duration_seconds": 26, "lyric_line": "A solo that outruns the law", "scene": {"mood": "hope", "colors": ["pale gold", "sky blue", "white"], "composition": "symmetrical", "camera": "rack focus", "description": "A hope scene in rock register. bird's eye framing. tracking shot movement."}}
{"song": "Thunder Road Confessional", "artist": "Gasket & Grace", "beat": 8, "timestamp": "2:52", "duration_seconds": 24, "lyric_line": "The chorus — everyone in the car sings", "scene": {"mood": "defiance", "colors": ["black", "red", "silver"], "composition": "low angle", "camera": "handheld sway", "description": "A defiance scene in rock register. rule of thirds framing. crane up movement."}}
{"song": "Thunder Road Confessional", "artist": "Gasket & Grace", "beat": 9, "timestamp": "3:16", "duration_seconds": 26, "lyric_line": "Thunder road confessional — the destination was the song", "scene": {"mood": "triumph", "colors": ["gold", "red", "white"], "composition": "center frame", "camera": "handheld sway", "description": "A triumph scene in rock register. bird's eye framing. circular orbit movement."}}
{"song": "Thunder Road Confessional", "artist": "Gasket & Grace", "beat": 10, "timestamp": "3:42", "duration_seconds": 28, "lyric_line": "Thunder road confessional — home is the last chord", "scene": {"mood": "homecoming", "colors": ["warm gold", "brown", "cream"], "composition": "center frame", "camera": "rack focus", "description": "A homecoming scene in rock register. wide shot framing. rack focus movement."}}
{"song": "Avalanche Hymn", "artist": "Mountain Teeth", "beat": 1, "timestamp": "0:00", "duration_seconds": 22, "lyric_line": "The mountain exhales — the avalanche begins", "scene": {"mood": "power", "colors": ["gold", "black", "deep red"], "composition": "high angle", "camera": "rack focus", "description": "A power scene in rock register. symmetrical framing. dolly forward movement."}}
{"song": "Avalanche Hymn", "artist": "Mountain Teeth", "beat": 2, "timestamp": "0:22", "duration_seconds": 24, "lyric_line": "Avalanche hymn — the earth's sermon", "scene": {"mood": "menace", "colors": ["dark green", "black", "purple"], "composition": "low angle", "camera": "rack focus", "description": "A menace scene in rock register. close-up framing. dolly forward movement."}}
{"song": "Avalanche Hymn", "artist": "Mountain Teeth", "beat": 3, "timestamp": "0:46", "duration_seconds": 26, "lyric_line": "Every drum fill a boulder falling", "scene": {"mood": "fury", "colors": ["crimson", "dark grey", "fire orange"], "composition": "high angle", "camera": "circular orbit", "description": "A fury scene in rock register. close-up framing. tracking shot movement."}}
{"song": "Avalanche Hymn", "artist": "Mountain Teeth", "beat": 4, "timestamp": "1:12", "duration_seconds": 24, "lyric_line": "The guitar tone is granite and grief", "scene": {"mood": "chaos", "colors": ["red", "orange", "white flash"], "composition": "close-up", "camera": "slow zoom in", "description": "A chaos scene in rock register. symmetrical framing. crane up movement."}}
{"song": "Avalanche Hymn", "artist": "Mountain Teeth", "beat": 5, "timestamp": "1:36", "duration_seconds": 26, "lyric_line": "Avalanche hymn — gravity is the conductor", "scene": {"mood": "destruction", "colors": ["fire orange", "black", "grey ash"], "composition": "symmetrical", "camera": "handheld sway", "description": "A destruction scene in rock register. symmetrical framing. crane up movement."}}
{"song": "Avalanche Hymn", "artist": "Mountain Teeth", "beat": 6, "timestamp": "2:02", "duration_seconds": 24, "lyric_line": "The breakdown — snow settling", "scene": {"mood": "beauty", "colors": ["white", "gold", "soft pink"], "composition": "extreme close-up", "camera": "slow zoom out", "description": "A beauty scene in rock register. rule of thirds framing. rack focus movement."}}
{"song": "Avalanche Hymn", "artist": "Mountain Teeth", "beat": 7, "timestamp": "2:26", "duration_seconds": 26, "lyric_line": "Then the chorus — the mountain rebuilds itself", "scene": {"mood": "resilience", "colors": ["green", "brown", "iron"], "composition": "rule of thirds", "camera": "tracking shot", "description": "A resilience scene in rock register. silhouette frame framing. slow zoom out movement."}}
{"song": "Avalanche Hymn", "artist": "Mountain Teeth", "beat": 8, "timestamp": "2:52", "duration_seconds": 24, "lyric_line": "Every note a geological event", "scene": {"mood": "awe", "colors": ["white", "gold", "deep blue"], "composition": "symmetrical", "camera": "floating drift", "description": "A awe scene in rock register. wide shot framing. crane up movement."}}
{"song": "Avalanche Hymn", "artist": "Mountain Teeth", "beat": 9, "timestamp": "3:16", "duration_seconds": 26, "lyric_line": "Avalanche hymn — what the earth demands", "scene": {"mood": "triumph", "colors": ["gold", "red", "white"], "composition": "wide shot", "camera": "steady hold", "description": "A triumph scene in rock register. symmetrical framing. handheld sway movement."}}
{"song": "Avalanche Hymn", "artist": "Mountain Teeth", "beat": 10, "timestamp": "3:42", "duration_seconds": 28, "lyric_line": "Avalanche hymn — the mountain sings forever", "scene": {"mood": "eternity", "colors": ["gold", "white", "deep blue"], "composition": "symmetrical", "camera": "crane up", "description": "A eternity scene in rock register. bird's eye framing. floating drift movement."}}
{"song": "Cathedral of Feedback", "artist": "Saint Distortion", "beat": 1, "timestamp": "0:00", "duration_seconds": 24, "lyric_line": "The feedback builds like a congregation", "scene": {"mood": "reverence", "colors": ["black", "grey", "red"], "composition": "high angle", "camera": "static", "description": "A reverence scene in rock register. POV framing. slow zoom in movement."}}
{"song": "Cathedral of Feedback", "artist": "Saint Distortion", "beat": 2, "timestamp": "0:24", "duration_seconds": 22, "lyric_line": "Cathedral of feedback — the amp is the altar", "scene": {"mood": "power", "colors": ["gold", "black", "deep red"], "composition": "dutch angle", "camera": "tracking shot", "description": "A power scene in rock register. low angle framing. slow zoom out movement."}}
{"song": "Cathedral of Feedback", "artist": "Saint Distortion", "beat": 3, "timestamp": "0:46", "duration_seconds": 26, "lyric_line": "Every harmonic a stained glass shard", "scene": {"mood": "ecstasy", "colors": ["gold", "red", "white"], "composition": "wide shot", "camera": "steady hold", "description": "A ecstasy scene in rock register. wide shot framing. circular orbit movement."}}
{"song": "Cathedral of Feedback", "artist": "Saint Distortion", "beat": 4, "timestamp": "1:12", "duration_seconds": 24, "lyric_line": "The drummer is the thunder inside", "scene": {"mood": "chaos", "colors": ["red", "orange", "white flash"], "composition": "bird's eye", "camera": "rack focus", "description": "A chaos scene in rock register. bird's eye framing. handheld sway movement."}}
{"song": "Cathedral of Feedback", "artist": "Saint Distortion", "beat": 5, "timestamp": "1:36", "duration_seconds": 26, "lyric_line": "Cathedral of feedback — worship through distortion", "scene": {"mood": "beauty", "colors": ["white", "gold", "soft pink"], "composition": "dutch angle", "camera": "tracking shot", "description": "A beauty scene in rock register. close-up framing. steady hold movement."}}
{"song": "Cathedral of Feedback", "artist": "Saint Distortion", "beat": 6, "timestamp": "2:02", "duration_seconds": 24, "lyric_line": "The solo ascends like a spire", "scene": {"mood": "fury", "colors": ["crimson", "dark grey", "fire orange"], "composition": "POV", "camera": "slow zoom in", "description": "A fury scene in rock register. silhouette frame framing. slow zoom out movement."}}
{"song": "Cathedral of Feedback", "artist": "Saint Distortion", "beat": 7, "timestamp": "2:26", "duration_seconds": 26, "lyric_line": "Feedback as holy spirit", "scene": {"mood": "transcendence", "colors": ["white", "gold", "silver"], "composition": "silhouette frame", "camera": "crane up", "description": "A transcendence scene in rock register. high angle framing. rack focus movement."}}
{"song": "Cathedral of Feedback", "artist": "Saint Distortion", "beat": 8, "timestamp": "2:52", "duration_seconds": 24, "lyric_line": "The breakdown — the cathedral pauses to breathe", "scene": {"mood": "catharsis", "colors": ["gold", "white", "red"], "composition": "rule of thirds", "camera": "rack focus", "description": "A catharsis scene in rock register. high angle framing. crane up movement."}}
{"song": "Cathedral of Feedback", "artist": "Saint Distortion", "beat": 9, "timestamp": "3:16", "duration_seconds": 26, "lyric_line": "Cathedral of feedback — the amp stack is the nave", "scene": {"mood": "glory", "colors": ["gold", "white", "purple"], "composition": "extreme close-up", "camera": "slow zoom in", "description": "A glory scene in rock register. silhouette frame framing. floating drift movement."}}
{"song": "Cathedral of Feedback", "artist": "Saint Distortion", "beat": 10, "timestamp": "3:42", "duration_seconds": 28, "lyric_line": "Cathedral of feedback — silence is the final chord", "scene": {"mood": "silence", "colors": ["white", "grey", "transparent"], "composition": "wide shot", "camera": "dolly forward", "description": "A silence scene in rock register. wide shot framing. floating drift movement."}}