/* ═══════════════════════════════════════════════════════════════════════════
   KRIMINIS v12.0 — STYLES
   #1 Modo Noir  |  #2 Informe PDF  |  #3 ARG Easter Eggs
   #4 Modo Podcast  |  #5 Temporadas  |  #6 Reconstrucción de Escena
   #7 Tablero de Evidencias
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────────────────
   #1 — MODO NOIR
   Full B&W + red accent visual mode with serif typography
   ─────────────────────────────────────────────────────────────────────────  */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Lora:ital,wght@0,400;0,700;1,400&display=swap');

body.noir-mode {
    --noir-bg: #0a0a0a;
    --noir-surface: #141414;
    --noir-text: #d4d0c8;
    --noir-accent: #8b0000;
    --noir-accent-bright: #cc1100;
    --noir-muted: #666;
    --noir-border: #333;
    --noir-highlight: #f5f0e8;
    --font-noir-title: 'Playfair Display', 'Georgia', serif;
    --font-noir-body: 'Lora', 'Times New Roman', serif;
    filter: saturate(0.08) contrast(1.1);
}

body.noir-mode .noir-accent-el,
body.noir-mode .btn-primary,
body.noir-mode .btn-danger,
body.noir-mode .neon-red,
body.noir-mode .achievement-popup,
body.noir-mode .caso-completo-bar,
body.noir-mode .streak-badge {
    filter: saturate(12) !important;
}

body.noir-mode::before {
    content: '';
    position: fixed;
    inset: 0;
    background: radial-gradient(ellipse at 50% 0%, rgba(139,0,0,0.06) 0%, transparent 70%);
    pointer-events: none;
    z-index: 1;
}

body.noir-mode * {
    font-family: var(--font-noir-body) !important;
}

body.noir-mode h1, body.noir-mode h2, body.noir-mode h3,
body.noir-mode .section-title, body.noir-mode .hero-title,
body.noir-mode .logo, body.noir-mode .category-name,
body.noir-mode .theory-title, body.noir-mode .episode-title {
    font-family: var(--font-noir-title) !important;
    font-style: italic;
}

body.noir-mode .hero-subtitle,
body.noir-mode .section-tag {
    font-family: var(--font-noir-body) !important;
    font-style: italic;
    letter-spacing: 0.1em;
}

body.noir-mode .hero-title .glitch-text {
    animation: none !important;
    text-shadow: 2px 2px 0 rgba(139,0,0,0.3);
}

body.noir-mode .cyber-grid,
body.noir-mode .ambient-orb {
    display: none !important;
}

body.noir-mode .film-grain {
    opacity: 0.12 !important;
}

body.noir-mode .crt-scanlines {
    opacity: 0.03 !important;
}

body.noir-mode .vignette-overlay {
    opacity: 1 !important;
    background: radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.8) 100%) !important;
}

/* Noir rain effect */
body.noir-mode .rain-overlay {
    opacity: 0.4 !important;
}

/* Noir narrative overlay */
.noir-narrator {
    position: fixed;
    bottom: 80px;
    left: 50%;
    transform: translateX(-50%);
    max-width: 700px;
    width: 90%;
    background: rgba(10,10,10,0.95);
    border: 1px solid #333;
    border-left: 3px solid #8b0000;
    padding: 20px 25px;
    font-family: 'Lora', serif !important;
    font-style: italic;
    color: #d4d0c8;
    font-size: 0.95rem;
    line-height: 1.8;
    z-index: 9990;
    opacity: 0;
    transition: opacity 0.8s ease, transform 0.8s ease;
    transform: translateX(-50%) translateY(20px);
    pointer-events: none;
    box-shadow: 0 10px 40px rgba(0,0,0,0.6);
}

.noir-narrator.visible {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

.noir-narrator::before {
    content: '» ';
    color: #8b0000;
    font-weight: bold;
}

/* ─────────────────────────────────────────────────────────────────────────
   #2 — INFORME POLICIAL PDF
   ─────────────────────────────────────────────────────────────────────────  */
.pdf-report-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    background: linear-gradient(135deg, #1a1a2e, #16213e);
    border: 1px solid var(--neon-gold, #ffd700);
    color: var(--neon-gold, #ffd700);
    font-family: var(--font-mono, monospace);
    font-size: 0.8rem;
    letter-spacing: 1px;
    cursor: pointer;
    transition: all 0.3s;
    border-radius: 4px;
    margin-top: 15px;
}

.pdf-report-btn:hover {
    background: linear-gradient(135deg, #ffd700, #ff8c00);
    color: #000;
    box-shadow: 0 0 20px rgba(255,215,0,0.3);
}

.pdf-generating {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(0,0,0,0.95);
    border: 1px solid var(--neon-cyan, #0ff);
    padding: 40px;
    text-align: center;
    z-index: 99999;
    border-radius: 8px;
}

.pdf-generating .spinner {
    width: 40px;
    height: 40px;
    border: 3px solid rgba(255,255,255,0.1);
    border-top-color: var(--neon-cyan, #0ff);
    border-radius: 50%;
    animation: pdfSpin 0.8s linear infinite;
    margin: 0 auto 15px;
}

@keyframes pdfSpin {
    to { transform: rotate(360deg); }
}

/* ─────────────────────────────────────────────────────────────────────────
   #3 — ARG EASTER EGGS
   ─────────────────────────────────────────────────────────────────────────  */
.arg-clue-found {
    position: fixed;
    top: 20px;
    right: 20px;
    background: rgba(0,0,0,0.95);
    border: 1px solid #8b0000;
    border-left: 3px solid #ff0000;
    padding: 15px 20px;
    z-index: 99999;
    max-width: 350px;
    animation: argSlideIn 0.5s ease;
    box-shadow: 0 5px 30px rgba(139,0,0,0.3);
}

@keyframes argSlideIn {
    from { transform: translateX(120%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

.arg-clue-found__header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
    font-family: var(--font-mono, monospace);
    font-size: 0.75rem;
    color: #ff0000;
    letter-spacing: 2px;
}

.arg-clue-found__text {
    font-size: 0.85rem;
    color: #ccc;
    line-height: 1.5;
}

.arg-clue-found__progress {
    margin-top: 10px;
    display: flex;
    gap: 4px;
}

.arg-clue-found__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #333;
    transition: background 0.3s;
}

.arg-clue-found__dot.found {
    background: #ff0000;
    box-shadow: 0 0 6px rgba(255,0,0,0.5);
}

/* Hidden source code clue */
.arg-source-clue {
    display: none;
    /* ARG_CLUE: La primera víctima fue encontrada en coordenadas 40.4168, -3.7038 */
    /* Busca "CASO CERO" en el terminal para continuar... */
}

/* ARG Secret Case Modal */
.arg-secret-case {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.97);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: argFadeIn 1s ease;
}

@keyframes argFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.arg-secret-case__inner {
    max-width: 650px;
    width: 90%;
    border: 1px solid #8b0000;
    background: #0a0a0a;
    padding: 0;
    max-height: 80vh;
    overflow-y: auto;
}

.arg-secret-case__header {
    background: linear-gradient(135deg, #1a0000, #2a0000);
    padding: 25px 30px;
    border-bottom: 1px solid #8b0000;
    text-align: center;
}

.arg-secret-case__header h2 {
    font-family: var(--font-display, monospace);
    color: #ff0000;
    letter-spacing: 3px;
    font-size: 1.3rem;
    margin-bottom: 5px;
}

.arg-secret-case__header p {
    color: #666;
    font-size: 0.8rem;
    font-family: var(--font-mono, monospace);
}

.arg-secret-case__body {
    padding: 30px;
    color: #ccc;
    font-size: 0.9rem;
    line-height: 1.8;
}

.arg-secret-case__body .classified {
    color: #ff0000;
    font-family: var(--font-mono, monospace);
    font-size: 0.75rem;
    letter-spacing: 3px;
    text-align: center;
    margin: 20px 0;
    padding: 10px;
    border: 1px dashed #8b0000;
}

.arg-secret-case__close {
    position: absolute;
    top: 15px;
    right: 15px;
    background: none;
    border: 1px solid #333;
    color: #666;
    font-size: 1.2rem;
    padding: 5px 10px;
    cursor: pointer;
}

/* ─────────────────────────────────────────────────────────────────────────
   #4 — MODO PODCAST
   ─────────────────────────────────────────────────────────────────────────  */
.podcast-player {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(180deg, rgba(10,10,15,0.98), rgba(5,5,10,1));
    border-top: 1px solid rgba(0,255,255,0.2);
    padding: 12px 20px;
    display: flex;
    align-items: center;
    gap: 15px;
    z-index: 9998;
    transform: translateY(100%);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    backdrop-filter: blur(20px);
}

.podcast-player.active {
    transform: translateY(0);
}

.podcast-player__controls {
    display: flex;
    align-items: center;
    gap: 8px;
}

.podcast-player__btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid rgba(0,255,255,0.3);
    background: rgba(0,255,255,0.05);
    color: var(--neon-cyan, #0ff);
    font-size: 1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s;
}

.podcast-player__btn:hover {
    background: rgba(0,255,255,0.15);
    border-color: var(--neon-cyan, #0ff);
}

.podcast-player__btn--play {
    width: 44px;
    height: 44px;
    font-size: 1.3rem;
    background: linear-gradient(135deg, rgba(0,255,255,0.15), rgba(255,0,255,0.1));
    border: 1px solid var(--neon-cyan, #0ff);
}

.podcast-player__info {
    flex: 1;
    min-width: 0;
}

.podcast-player__title {
    font-family: var(--font-mono, monospace);
    font-size: 0.7rem;
    color: var(--neon-cyan, #0ff);
    letter-spacing: 2px;
    text-transform: uppercase;
}

.podcast-player__text {
    font-size: 0.8rem;
    color: #999;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 2px;
}

.podcast-player__wave {
    display: flex;
    align-items: center;
    gap: 2px;
    height: 30px;
}

.podcast-player__wave span {
    width: 3px;
    background: var(--neon-cyan, #0ff);
    border-radius: 2px;
    animation: podcastWave 1.2s ease-in-out infinite;
    opacity: 0.7;
}

.podcast-player__wave span:nth-child(1) { height: 30%; animation-delay: 0s; }
.podcast-player__wave span:nth-child(2) { height: 60%; animation-delay: 0.1s; }
.podcast-player__wave span:nth-child(3) { height: 100%; animation-delay: 0.2s; }
.podcast-player__wave span:nth-child(4) { height: 60%; animation-delay: 0.3s; }
.podcast-player__wave span:nth-child(5) { height: 30%; animation-delay: 0.4s; }

.podcast-player.paused .podcast-player__wave span {
    animation-play-state: paused;
}

@keyframes podcastWave {
    0%, 100% { transform: scaleY(0.3); }
    50% { transform: scaleY(1); }
}

.podcast-player__speed {
    font-family: var(--font-mono, monospace);
    font-size: 0.7rem;
    padding: 4px 8px;
    border: 1px solid #333;
    background: rgba(255,255,255,0.05);
    color: #999;
    cursor: pointer;
    border-radius: 4px;
}

.podcast-player__close {
    background: none;
    border: none;
    color: #666;
    font-size: 1.2rem;
    cursor: pointer;
    padding: 5px;
}

/* ─────────────────────────────────────────────────────────────────────────
   #5 — SISTEMA DE TEMPORADAS
   ─────────────────────────────────────────────────────────────────────────  */
.seasons-section .season-banner {
    position: relative;
    background: linear-gradient(135deg, #0a001a 0%, #1a002a 50%, #0a0015 100%);
    border: 1px solid rgba(139,0,139,0.3);
    border-radius: 12px;
    padding: 40px;
    margin-bottom: 30px;
    overflow: hidden;
}

.season-banner::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='40' height='40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h40v40H0z' fill='none'/%3E%3Cpath d='M0 20h40M20 0v40' stroke='rgba(139,0,139,0.08)' stroke-width='1'/%3E%3C/svg%3E");
    pointer-events: none;
}

.season-banner__tag {
    display: inline-block;
    background: rgba(139,0,139,0.2);
    border: 1px solid rgba(139,0,139,0.4);
    padding: 4px 12px;
    font-family: var(--font-mono, monospace);
    font-size: 0.65rem;
    letter-spacing: 3px;
    color: #da70d6;
    margin-bottom: 15px;
}

.season-banner__title {
    font-family: var(--font-display, monospace);
    font-size: 1.8rem;
    color: #fff;
    margin-bottom: 8px;
}

.season-banner__subtitle {
    color: #999;
    font-size: 0.9rem;
    max-width: 500px;
}

.season-banner__villain {
    position: absolute;
    right: 40px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 5rem;
    opacity: 0.15;
}

.season-timeline {
    display: flex;
    gap: 0;
    position: relative;
    padding: 20px 0;
}

.season-timeline::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, rgba(139,0,139,0.4), rgba(0,255,255,0.4));
}

.season-month {
    flex: 1;
    text-align: center;
    position: relative;
    padding: 10px 5px;
    cursor: pointer;
    transition: transform 0.3s;
}

.season-month:hover {
    transform: translateY(-5px);
}

.season-month__dot {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: #333;
    border: 2px solid #555;
    margin: 0 auto 10px;
    position: relative;
    z-index: 1;
    transition: all 0.3s;
}

.season-month.active .season-month__dot {
    background: var(--neon-cyan, #0ff);
    border-color: var(--neon-cyan, #0ff);
    box-shadow: 0 0 15px rgba(0,255,255,0.5);
}

.season-month.completed .season-month__dot {
    background: var(--neon-green, #0f8);
    border-color: var(--neon-green, #0f8);
}

.season-month.locked .season-month__dot {
    background: #222;
    border-color: #444;
}

.season-month__label {
    font-family: var(--font-mono, monospace);
    font-size: 0.6rem;
    color: #666;
    letter-spacing: 1px;
}

.season-month.active .season-month__label {
    color: var(--neon-cyan, #0ff);
}

.season-content-card {
    background: rgba(255,255,255,0.02);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 8px;
    padding: 25px;
    margin-top: 20px;
}

.season-content-card__header {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 20px;
}

.season-content-card__icon {
    font-size: 2rem;
}

.season-content-card__title {
    font-family: var(--font-display, monospace);
    font-size: 1.1rem;
    color: #fff;
}

.season-content-card__subtitle {
    font-size: 0.75rem;
    color: #666;
    font-family: var(--font-mono, monospace);
}

.season-episodes {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 15px;
}

.season-ep-card {
    background: rgba(0,0,0,0.3);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 6px;
    padding: 20px;
    cursor: pointer;
    transition: all 0.3s;
}

.season-ep-card:hover {
    border-color: rgba(0,255,255,0.3);
    transform: translateY(-2px);
}

.season-ep-card.locked {
    opacity: 0.4;
    pointer-events: none;
}

.season-ep-card__number {
    font-family: var(--font-mono, monospace);
    font-size: 0.65rem;
    color: var(--neon-cyan, #0ff);
    letter-spacing: 2px;
    margin-bottom: 8px;
}

.season-ep-card__title {
    font-size: 1rem;
    color: #fff;
    margin-bottom: 6px;
}

.season-ep-card__desc {
    font-size: 0.8rem;
    color: #888;
    line-height: 1.5;
}

.season-ep-card__lock {
    display: inline-block;
    margin-top: 10px;
    font-size: 0.7rem;
    color: #555;
}

/* ─────────────────────────────────────────────────────────────────────────
   #6 — RECONSTRUCCIÓN DE ESCENA (Drag & Drop)
   ─────────────────────────────────────────────────────────────────────────  */
.scene-reconstruction {
    position: relative;
    max-width: 900px;
    margin: 0 auto;
}

.scene-reconstruction__canvas {
    position: relative;
    width: 100%;
    aspect-ratio: 16/10;
    background: linear-gradient(180deg, #0a0a12 0%, #12121f 100%);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 8px;
    overflow: hidden;
    user-select: none;
}

.scene-reconstruction__bg {
    position: absolute;
    inset: 0;
    opacity: 0.15;
    background-image:
        linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
    background-size: 40px 40px;
}

.scene-reconstruction__room {
    position: absolute;
    inset: 5%;
    border: 1px dashed rgba(255,255,255,0.1);
    border-radius: 4px;
}

/* Furniture items in scene */
.scene-furniture {
    position: absolute;
    font-size: 1.8rem;
    opacity: 0.3;
    pointer-events: none;
}

/* Drop zones */
.scene-drop-zone {
    position: absolute;
    border: 2px dashed rgba(0,255,255,0.2);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s;
    background: rgba(0,255,255,0.02);
}

.scene-drop-zone.highlight {
    border-color: rgba(0,255,255,0.6);
    background: rgba(0,255,255,0.08);
    box-shadow: 0 0 15px rgba(0,255,255,0.15);
}

.scene-drop-zone.correct {
    border-color: rgba(0,255,136,0.6);
    background: rgba(0,255,136,0.08);
}

.scene-drop-zone.incorrect {
    border-color: rgba(255,0,0,0.6);
    background: rgba(255,0,0,0.08);
    animation: sceneShake 0.4s;
}

@keyframes sceneShake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-5px); }
    75% { transform: translateX(5px); }
}

.scene-drop-zone__label {
    font-family: var(--font-mono, monospace);
    font-size: 0.6rem;
    color: rgba(0,255,255,0.4);
    letter-spacing: 1px;
    text-align: center;
    pointer-events: none;
}

/* Draggable evidence items */
.scene-evidence-tray {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 20px;
    margin-top: 15px;
    background: rgba(0,0,0,0.3);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 8px;
}

.scene-evidence-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 15px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 6px;
    cursor: grab;
    transition: all 0.3s;
    user-select: none;
    font-size: 0.85rem;
}

.scene-evidence-item:active {
    cursor: grabbing;
}

.scene-evidence-item:hover {
    border-color: rgba(0,255,255,0.4);
    background: rgba(0,255,255,0.05);
}

.scene-evidence-item.placed {
    opacity: 0.3;
    pointer-events: none;
    border-style: dashed;
}

.scene-evidence-item__icon {
    font-size: 1.2rem;
}

.scene-evidence-item__name {
    font-family: var(--font-mono, monospace);
    font-size: 0.75rem;
    color: #ccc;
}

.scene-reconstruction__hud {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 0;
}

.scene-hud__score {
    font-family: var(--font-mono, monospace);
    font-size: 0.8rem;
    color: var(--neon-cyan, #0ff);
}

.scene-hud__timer {
    font-family: var(--font-mono, monospace);
    font-size: 0.9rem;
    color: var(--neon-gold, #ffd700);
}

.scene-result {
    text-align: center;
    padding: 30px;
    background: rgba(0,0,0,0.5);
    border: 1px solid rgba(0,255,255,0.2);
    border-radius: 8px;
    margin-top: 20px;
}

.scene-result__stars {
    font-size: 2rem;
    margin: 10px 0;
}

/* ─────────────────────────────────────────────────────────────────────────
   #7 — TABLERO DE EVIDENCIAS (Detective Board)
   ─────────────────────────────────────────────────────────────────────────  */
.evidence-board-section {
    position: relative;
}

.evidence-board {
    position: relative;
    width: 100%;
    height: 600px;
    background: linear-gradient(135deg, #1a1812 0%, #231f17 100%);
    border: 3px solid #3a3020;
    border-radius: 4px;
    overflow: hidden;
    cursor: default;
    box-shadow: inset 0 0 60px rgba(0,0,0,0.5);
}

.evidence-board::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        url("data:image/svg+xml,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='100' height='100' fill='none'/%3E%3Cline x1='0' y1='0' x2='100' y2='100' stroke='rgba(100,80,50,0.05)' stroke-width='1'/%3E%3C/svg%3E");
    pointer-events: none;
}

/* Toolbar */
.evidence-board__toolbar {
    display: flex;
    gap: 8px;
    padding: 10px 15px;
    background: rgba(0,0,0,0.5);
    border-bottom: 1px solid #3a3020;
}

.board-tool {
    padding: 6px 12px;
    font-family: var(--font-mono, monospace);
    font-size: 0.7rem;
    border: 1px solid #3a3020;
    background: rgba(0,0,0,0.3);
    color: #999;
    cursor: pointer;
    transition: all 0.3s;
    border-radius: 3px;
    display: flex;
    align-items: center;
    gap: 5px;
}

.board-tool:hover, .board-tool.active {
    border-color: var(--neon-cyan, #0ff);
    color: var(--neon-cyan, #0ff);
}

.board-tool--clear {
    margin-left: auto;
    color: #ff4444;
    border-color: #ff4444;
}

/* Board canvas area */
.evidence-board__canvas {
    position: relative;
    width: 100%;
    height: calc(100% - 45px);
    overflow: auto;
}

/* Pinned items on the board */
.board-pin {
    position: absolute;
    min-width: 120px;
    max-width: 200px;
    cursor: move;
    user-select: none;
    z-index: 2;
    transition: box-shadow 0.3s;
}

.board-pin:hover {
    z-index: 10;
}

.board-pin.dragging {
    z-index: 100;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

/* Photo pin */
.board-pin--photo {
    background: #f5f0e0;
    padding: 8px 8px 25px;
    transform: rotate(var(--pin-rotation, -2deg));
    box-shadow: 2px 3px 10px rgba(0,0,0,0.4);
}

.board-pin--photo .pin-image {
    width: 100%;
    aspect-ratio: 4/3;
    background: #ddd;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
    border: 1px solid #ccc;
}

.board-pin--photo .pin-caption {
    font-size: 0.65rem;
    color: #333;
    text-align: center;
    margin-top: 5px;
    font-family: 'Courier New', monospace;
}

/* Note pin (sticky note) */
.board-pin--note {
    background: #fef68a;
    padding: 15px;
    min-height: 80px;
    transform: rotate(var(--pin-rotation, 1deg));
    box-shadow: 2px 3px 10px rgba(0,0,0,0.3);
}

.board-pin--note .pin-text {
    font-size: 0.75rem;
    color: #333;
    font-family: 'Comic Sans MS', cursive, sans-serif;
    line-height: 1.4;
    word-break: break-word;
}

.board-pin--note.editing .pin-text {
    outline: none;
    min-height: 60px;
}

/* Tack/pin on top */
.board-pin__tack {
    position: absolute;
    top: -6px;
    left: 50%;
    transform: translateX(-50%);
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: radial-gradient(circle at 40% 40%, #ff6666, #cc0000);
    box-shadow: 0 2px 4px rgba(0,0,0,0.4);
    z-index: 3;
}

/* Red thread lines (SVG) */
.board-threads {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
}

.board-threads line {
    stroke: #cc0000;
    stroke-width: 1.5;
    opacity: 0.7;
    stroke-dasharray: none;
}

.board-threads line.dashed {
    stroke-dasharray: 6 4;
    opacity: 0.4;
}

/* Suspect card on board */
.board-pin--suspect {
    background: #1a1a2e;
    border: 1px solid #333;
    border-radius: 4px;
    padding: 12px;
    text-align: center;
    transform: rotate(var(--pin-rotation, 0deg));
    box-shadow: 2px 3px 10px rgba(0,0,0,0.5);
}

.board-pin--suspect .suspect-icon {
    font-size: 2rem;
    margin-bottom: 5px;
}

.board-pin--suspect .suspect-name {
    font-family: var(--font-mono, monospace);
    font-size: 0.7rem;
    color: #ccc;
    letter-spacing: 1px;
}

.board-pin--suspect .suspect-status {
    font-size: 0.6rem;
    margin-top: 4px;
    padding: 2px 8px;
    border-radius: 3px;
    display: inline-block;
}

.board-pin--suspect .suspect-status.prime {
    background: rgba(255,0,0,0.2);
    color: #ff4444;
    border: 1px solid rgba(255,0,0,0.3);
}

.board-pin--suspect .suspect-status.cleared {
    background: rgba(0,255,0,0.1);
    color: #0f8;
    border: 1px solid rgba(0,255,0,0.2);
}

/* Thread drawing mode */
.evidence-board__canvas.threading {
    cursor: crosshair;
}

/* Board item context menu */
.board-context-menu {
    position: fixed;
    background: rgba(0,0,0,0.95);
    border: 1px solid #333;
    border-radius: 4px;
    padding: 5px 0;
    z-index: 99999;
    min-width: 150px;
}

.board-context-menu__item {
    padding: 8px 15px;
    font-size: 0.8rem;
    color: #ccc;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
}

.board-context-menu__item:hover {
    background: rgba(0,255,255,0.1);
    color: #fff;
}

.board-context-menu__item--danger {
    color: #ff4444;
}

/* ─────────────────────────────────────────────────────────────────────────
   RESPONSIVE
   ─────────────────────────────────────────────────────────────────────────  */
@media (max-width: 768px) {
    .podcast-player {
        flex-wrap: wrap;
        padding: 10px;
        gap: 8px;
    }
    .podcast-player__wave { display: none; }
    .podcast-player__info { order: -1; width: 100%; }

    .evidence-board { height: 400px; }

    .season-banner__villain { display: none; }
    .season-banner { padding: 25px; }
    .season-banner__title { font-size: 1.3rem; }

    .scene-reconstruction__canvas { aspect-ratio: 4/3; }

    .season-timeline { flex-wrap: wrap; gap: 5px; }
    .season-month { flex: 0 0 calc(25% - 4px); }
}
