/* --- CSP COMPLIANT FONT FIX --- */
/* Force font-display: swap for Font Awesome */
@font-face {
    font-family: 'Font Awesome 6 Free';
    font-style: normal;
    font-weight: 900;
    font-display: swap;
    src: url("/assets/fontawesome/webfonts/fa-solid-900.woff2") format("woff2"),
         url("/assets/fontawesome/webfonts/fa-solid-900.ttf") format("truetype");
}

/* ... (Fonts and Root variables) ... */
/* Self-Hosted Fonts */
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 400; font-display: swap; src: url('/fonts/inter-v20-latin-regular.woff2') format('woff2'); }
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 600; font-display: swap; src: url('/fonts/inter-v20-latin-600.woff2') format('woff2'); }
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 700; font-display: swap; src: url('/fonts/inter-v20-latin-700.woff2') format('woff2'); }
@font-face { font-family: 'Orbitron'; font-style: normal; font-weight: 400; font-display: swap; src: url('/fonts/orbitron-v35-latin-regular.woff2') format('woff2'); }
@font-face { font-family: 'Orbitron'; font-style: normal; font-weight: 700; font-display: swap; src: url('/fonts/orbitron-v35-latin-700.woff2') format('woff2'); }

:root { 
    --accent-color: #00C9FF; 
    --accent-dark: #009bc4;
    --highlight-color: #facc15; 
    --winner-color: #a855f7; 
    --manual-color: #ff5555; 
    --bg-main: #1a202c; 
    --bg-container: #1f2937;
    --board-bg: #1e293b; 
    --cell-bg: #334155; 
    --cell-called-bg: #facc15;
    --cell-called-text: #422006; 
    --cell-highlight-border: #00C9FF;
    --dauber-color: #ef4444; 
    --text-color: #e2e8f0; 
    --text-muted: #a0aec0; 
}

html { height: 100%; width: 100%; overflow-x: hidden; scroll-behavior: smooth; box-sizing: border-box; }
*, *::before, *::after { box-sizing: inherit; }
body { font-family: 'Inter', sans-serif; background-color: var(--bg-main); background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="10" height="10" viewBox="0 0 10 10"><rect width="10" height="10" fill="%231a202c"/><path d="M0 0L10 10M10 0L0 10" stroke="%232d3748" stroke-width="0.2"/></svg>'); min-height: 100vh; margin: 0; padding: 0; color: var(--text-color); display: flex; flex-direction: column; }
body.player-mode-active { background-image: none; }

/* Utilities */
.hidden { display: none !important; }
.visible { opacity: 1 !important; pointer-events: auto !important; }
.flex { display: flex !important; }
.mt-10 { margin-top: 10px; }
.sr-only {position: absolute;width: 1px;height: 1px;padding: 0;margin: -1px;overflow: hidden;clip: rect(0, 0, 0, 0);white-space: nowrap;border-width: 0;}

/* QR & Player Utilities */
.player-footer-text { color: white; margin-top: 20px; }
.qr-container { text-align: center; }
.qr-image-style { display: inline-block; background: white; padding: 10px; border-radius: 8px; margin-top: 10px; }
.qr-text-style { margin-top: 15px; font-size: 0.9rem; color: var(--text-muted); }
.qr-url-highlight { color: var(--accent-color); user-select: text; }

/* Layout Wrappers */
.main-content-wrapper { flex-grow: 1; padding: 20px; display: flex; flex-direction: column; align-items: center; justify-content: flex-start; min-height: 100vh; box-sizing: border-box; width: 100%; margin: 0; }
.mobile-header { display: none; } 

/* Game Layout */
.app-container { width: 100%; max-width: 1400px; margin: 0 auto; display: flex; flex-direction: column; flex-grow: 1; }
.page-title { font-family: 'Orbitron', sans-serif; color: var(--accent-color); text-align: center; margin-top: 0; margin-bottom: 25px; text-shadow: 0 0 5px var(--accent-color), 0 0 10px rgba(0, 201, 255, 0.4); font-size: 2.5em; }
.header-subtitle { display: block; font-family: 'Inter', sans-serif; font-size: 1.1rem; color: var(--text-color); margin-top: 0.8rem; font-weight: 400; letter-spacing: 0.5px; text-shadow: none; opacity: 0.9; }

/* Intro Text */
.intro-content { width: 100%; max-width: 900px; margin: 0 auto 1.5rem; text-align: center; color: var(--text-muted); font-size: 1rem; line-height: 1.6; padding: 15px; background: rgba(0,0,0,0.2); border-radius: 12px; border: 1px solid var(--cell-bg); }
.intro-content strong { color: var(--accent-color); }

/* Header & Controls */
.app-header { display: flex; flex-direction: column; padding: 1.5rem; gap: 1rem; margin-bottom: 1rem; background-color: var(--bg-container); border-radius: 1rem; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4); border: 1px solid rgba(0, 201, 255, 0.1); width: 100%; }
.desktop-controls-grid { display: flex; flex-direction: column; gap: 1rem; width: 100%; }
.control-row { display: flex; align-items: center; justify-content: center; gap: 1rem; flex-wrap: wrap; width: 100%; }
.relative-row { position: relative; justify-content: center; }
.row-center-group { display: flex; gap: 0.75rem; align-items: center; justify-content: center; }
.desktop-share-btn { position: absolute; right: 0; margin-left: 0; background: var(--board-bg); border: 1px solid var(--cell-bg); color: var(--text-color); width: 44px; height: 44px; border-radius: 50%; display: flex; justify-content: center; align-items: center; font-size: 1.25rem; cursor: pointer; transition: all 0.2s; }
.desktop-share-btn:hover { background-color: var(--cell-bg); }

/* Buttons & Inputs */
.control-btn, .game-type-btn, .speed-btn, .control-select { background-color: var(--board-bg); border: 1px solid var(--cell-bg); color: var(--text-muted); padding: 0.6rem 1rem; border-radius: 0.5rem; font-weight: 700; cursor: pointer; transition: all 0.2s; font-family: 'Inter', sans-serif; font-size: 1rem; }
.control-select { appearance: none; padding-right: 2rem; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%2394a3b8' viewBox='0 0 24 24'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.5rem center; background-size: 1.5em; }
.control-btn:hover, .game-type-btn:hover, .speed-btn:hover, .control-select:hover { background-color: var(--cell-bg); color: var(--text-color); }
.game-type-btn.active, .speed-btn.active { background-color: var(--accent-color); color: var(--bg-main); border-color: var(--accent-color); text-shadow: none; }
.control-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.highlight-btn { border-color: var(--highlight-color); color: var(--highlight-color); display: flex; align-items: center; gap: 8px; white-space: nowrap; }
.highlight-btn:hover { background-color: var(--highlight-color); color: #422006; }
.winner-btn { width: 100%; border-color: var(--winner-color); color: var(--winner-color); display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 10px; padding: 1rem; font-size: 1.2rem; }
.winner-btn:hover { background-color: var(--winner-color); color: #fff; box-shadow: 0 0 15px var(--winner-color); }

/* Switches */
.auto-call-controls { display: flex; align-items: center; gap: 0.75rem; background-color: var(--board-bg); border-radius: 0.5rem; padding: 0.25rem 0.75rem; border: 1px solid var(--cell-bg);}
.manual-toggle-wrapper { border-color: var(--manual-color); }
.manual-toggle-wrapper .auto-call-label { color: var(--manual-color); }
.manual-toggle-wrapper input:checked + .slider { background-color: var(--manual-color); }
.auto-call-label { font-weight: 700; color: var(--text-muted); font-size: 0.9rem;}
.switch { position: relative; display: inline-block; width: 44px; height: 24px; }
.switch input { opacity: 0; width: 0; height: 0; }
.slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: var(--cell-bg); transition: .4s; border-radius: 24px;}
.slider:before { position: absolute; content: ""; height: 18px; width: 18px; left: 3px; bottom: 3px; background-color: white; transition: .4s; border-radius: 50%;}
input:checked + .slider { background-color: var(--accent-color); }
input:checked + .slider:before { transform: translateX(20px); }
.speed-controls { display: none; align-items: center; gap: 0.5rem; }
.speed-controls.visible { display: flex; }

/* HYPE DECK */
.hype-deck-panel { display: flex; align-items: center; justify-content: center; gap: 20px; margin-bottom: 1.5rem; width: 100%; background: rgba(31, 41, 55, 0.4); padding: 15px; border-radius: 16px; border: 1px solid rgba(255, 255, 255, 0.05); }
.hype-label { font-family: 'Orbitron', sans-serif; color: var(--text-muted); font-size: 1rem; letter-spacing: 2px; font-weight: 700; }
.hype-buttons { display: flex; gap: 15px; }

.hype-btn { background: rgba(0,0,0,0.3); border: 2px solid transparent; width: 50px; height: 50px; border-radius: 12px; font-size: 1.4rem; cursor: pointer; transition: all 0.2s cubic-bezier(0.34, 1.56, 0.64, 1); display: flex; justify-content: center; align-items: center; backdrop-filter: blur(5px); }
.hype-btn:hover { transform: translateY(-3px); box-shadow: 0 5px 15px rgba(0,0,0,0.4); }
.hype-btn:active { transform: translateY(0); }

.hype-btn[data-sound="airhorn"] { border-color: var(--highlight-color); color: var(--highlight-color); }
.hype-btn[data-sound="airhorn"]:hover { background: rgba(250, 204, 21, 0.2); box-shadow: 0 0 15px var(--highlight-color); }

.hype-btn[data-sound="drumroll"] { border-color: var(--accent-color); color: var(--accent-color); }
.hype-btn[data-sound="drumroll"]:hover { background: rgba(0, 201, 255, 0.2); box-shadow: 0 0 15px var(--accent-color); }

.hype-btn[data-sound="applause"] { border-color: var(--winner-color); color: var(--winner-color); }
.hype-btn[data-sound="applause"]:hover { background: rgba(168, 85, 247, 0.2); box-shadow: 0 0 15px var(--winner-color); }

.hype-btn[data-sound="aww"] { border-color: var(--manual-color); color: var(--manual-color); }
.hype-btn[data-sound="aww"]:hover { background: rgba(255, 85, 85, 0.2); box-shadow: 0 0 15px var(--manual-color); }

/* NEW: Winner Button Theme in Hype Deck */
.hype-btn[data-sound="winner"] { border-color: var(--winner-color); color: #fff; background: var(--winner-color); }
.hype-btn[data-sound="winner"]:hover { box-shadow: 0 0 20px var(--winner-color); filter: brightness(1.2); }


/* Main Game Area */
.main-content { display: flex; flex-direction: row; align-items: flex-start; gap: 2rem; flex-grow: 1; margin-top: 1rem; width: 100%; }
.caller-panel { display: flex; flex-direction: column; align-items: center; gap: 1rem; flex: 0 0 320px; position: sticky; top: 1rem; background-color: var(--bg-container); border-radius: 1rem; padding: 2rem; border: 1px solid rgba(0, 201, 255, 0.1); box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4); }
.caller-panel.is-calling { animation: shake 0.5s cubic-bezier(.36,.07,.19,.97) both; }
@keyframes shake { 10%, 90% { transform: translate3d(-1px, 0, 0); } 20%, 80% { transform: translate3d(2px, 0, 0); } 30%, 50%, 70% { transform: translate3d(-4px, 0, 0); } 40%, 60% { transform: translate3d(4px, 0, 0); } }
.action-buttons { width: 100%; margin-top: auto; }

.current-call-display { width: 250px; height: 250px; background-image: radial-gradient(circle at top, #475569, #1e293b); border: 8px solid #334155; box-shadow: inset 0 0 20px rgba(0,0,0,0.5), 0 5px 15px rgba(0,0,0,0.3); border-radius: 50%; display: flex; justify-content: center; align-items: center; position: relative; overflow: hidden; perspective: 800px; }
.initial-call-text { font-family: 'Inter', sans-serif; font-weight: 700; font-size: 5rem; color: var(--cell-bg); }
.bingo-ball { width: 180px; height: 180px; border-radius: 50%; background-color: var(--text-color); position: absolute; display: flex; justify-content: center; align-items: center; font-family: 'Inter', sans-serif; font-weight: 900; font-size: 6rem; color: var(--bg-main); box-shadow: inset -15px -15px 30px rgba(0,0,0,0.2), 0 10px 20px rgba(0,0,0,0.4); transform-style: preserve-3d; animation: roll-in 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) forwards, reveal 0.4s 0.8s ease forwards; }
@keyframes roll-in { from { transform: translateY(-300px) rotate(-360deg) scale(0.5); } to { transform: translateY(0) rotate(0deg) scale(1); } }
@keyframes reveal { from { transform: rotateY(0deg); } to { transform: rotateY(360deg); background-color: var(--cell-called-bg); color: var(--cell-called-text); } }

#lingo-display { font-size: 1.1rem; color: var(--text-muted); font-style: italic; min-height: 1.5rem; text-align: center; font-family: 'Orbitron', sans-serif; margin-top: 0.5rem; }
.history-display h3 { font-size: 1rem; color: var(--text-muted); text-align: center; margin: 0 0 0.5rem 0; text-transform: uppercase; letter-spacing: 1px; font-family: 'Orbitron', sans-serif; }
.history-list { min-height: 50px; display: flex; justify-content: center; gap: 0.75rem; padding: 0; margin: 0; list-style: none; }
.history-item { width: 50px; height: 50px; display: flex; justify-content: center; align-items: center; background-color: var(--board-bg); border-radius: 50%; font-weight: 700; font-size: 1.5rem; opacity: 0.6; }
.history-item:first-child { opacity: 1; background-color: var(--accent-color); color: var(--bg-main); }

.board-panel { background-color: var(--bg-container); border-radius: 1rem; padding: 1.5rem; flex-grow: 1; display: flex; flex-direction: column; min-height: 0; min-width: 0; align-self: flex-start; border: 1px solid rgba(0, 201, 255, 0.1); box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4); width: 100%; }
.bingo-board { display: grid; gap: 0.5rem; height: 100%; align-content: start; grid-template-columns: repeat(15, 1fr); }
.board-cell { display: flex; justify-content: center; align-items: center; background-color: var(--cell-bg); border-radius: 50%; font-weight: 700; font-size: 1.25rem; aspect-ratio: 1 / 1; transition: all 0.3s ease; position: relative; border: 2px solid transparent; cursor: default; }
.manual-mode-active .board-cell:not(.called) { cursor: pointer; box-shadow: inset 0 0 10px rgba(250, 204, 21, 0.2); z-index: 5; }
.manual-mode-active .board-cell:not(.called):hover { background-color: #475569; transform: scale(1.05); }
.board-cell.called { background-color: var(--cell-called-bg); color: var(--cell-called-text); transform: scale(1.1); z-index: 2; border-color: var(--cell-called-bg); }
.board-cell.pattern-highlight { border-color: var(--cell-highlight-border); background-color: rgba(0, 201, 255, 0.1); box-shadow: inset 0 0 10px rgba(0, 201, 255, 0.3); }

.call-next-btn { width: 100%; background-color: var(--accent-color); color: var(--bg-main); border: none; font-family: 'Orbitron', sans-serif; font-size: 1.5rem; font-weight: 700; padding: 1.25rem; border-radius: 0.75rem; cursor: pointer; transition: background-color 0.2s; text-shadow: none; }
.call-next-btn:hover:not(:disabled) { background-color: var(--accent-dark); }
.call-next-btn:disabled { background-color: var(--cell-bg); color: var(--text-muted); cursor: not-allowed; }

/* Voice Selector */
.custom-voice-selector { position: relative; width: 200px; font-family: 'Inter', sans-serif; }
.selected-voice { background-color: var(--board-bg); border: 1px solid var(--cell-bg); color: var(--text-muted); padding: 0.6rem 1rem; border-radius: 0.5rem; font-weight: 700; cursor: pointer; transition: all 0.2s; font-size: 1rem; display: flex; justify-content: space-between; align-items: center; user-select: none; }
.selected-voice:hover { background-color: var(--cell-bg); color: var(--text-color); }
.selected-voice i.fa-chevron-down { transition: transform 0.2s; }
.custom-voice-selector.open .selected-voice i.fa-chevron-down { transform: rotate(180deg); }
.voice-options { visibility: hidden; opacity: 0; position: absolute; top: 100%; left: 0; right: 0; background-color: var(--board-bg); border: 1px solid var(--cell-bg); border-radius: 0.5rem; margin-top: 0.25rem; z-index: 10; max-height: 350px; overflow-y: auto; transition: opacity 0.2s, visibility 0.2s; box-shadow: 0 10px 30px rgba(0,0,0,0.5); }
.custom-voice-selector.open .voice-options { visibility: visible; opacity: 1; }
.voice-group-header { padding: 0.75rem 1rem; color: var(--text-muted); font-size: 0.8rem; font-weight: 700; text-transform: uppercase; border-bottom: 1px solid var(--cell-bg); cursor: pointer; display: flex; justify-content: space-between; align-items: center; }
.voice-group-header:hover { background-color: var(--cell-bg); }
.voice-group-header .chevron { transition: transform 0.3s ease; }
.voice-group.active .voice-group-header .chevron { transform: rotate(180deg); }
.voice-group-content { max-height: 0; overflow: hidden; transition: max-height 0.3s ease-out; }
.voice-group.active .voice-group-content { max-height: 600px; transition: max-height 0.4s ease-in; }
.voice-option { padding: 0.6rem 1rem 0.6rem 1.5rem; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 0.5rem; }
.voice-option:hover, .voice-option.selected { background-color: var(--cell-bg); color: var(--text-color); }
.voice-option.selected { font-weight: 700; }
.voice-option-desc-btn { color: var(--text-muted); font-size: 0.9rem; transition: color 0.2s; padding: 0.25rem; }
.voice-option:hover .voice-option-desc-btn { color: var(--accent-color); }
.voice-tooltip { position: fixed; background-color: #0A0F1E; border: 1px solid var(--accent-color); color: var(--text-color); padding: 0.75rem; border-radius: 0.5rem; font-size: 0.9rem; width: 220px; z-index: 9999; pointer-events: none; opacity: 0; transform: scale(0.95); transition: opacity 0.2s, transform 0.2s; box-shadow: 0 5px 15px rgba(0,0,0,0.3); }
.voice-tooltip.visible { opacity: 1; transform: scale(1); }
.toast-notification { position: fixed; bottom: 30px; left: 50%; transform: translateX(-50%); background-color: var(--accent-color); color: var(--bg-main); padding: 10px 20px; border-radius: 20px; font-weight: bold; opacity: 0; transition: opacity 0.3s; pointer-events: none; z-index: 3000; }
.toast-notification.visible { opacity: 1; }

/* Mobile Controls & Footer */
.mobile-controls-panel { display: none; }
.app-footer { display: none; }
.desktop-share-btn { margin-left: auto; background: var(--board-bg); border: 1px solid var(--cell-bg); color: var(--text-color); width: 44px; height: 44px; border-radius: 50%; display: flex; justify-content: center; align-items: center; font-size: 1.25rem; cursor: pointer; transition: all 0.2s; }
.desktop-share-btn:hover { background-color: var(--cell-bg); }

/* Modal */
.share-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100vh; background-color: rgba(15, 23, 42, 0.8); backdrop-filter: blur(8px); z-index: 2000; display: flex; justify-content: center; align-items: center; opacity: 0; pointer-events: none; transition: opacity 0.3s ease; }
.share-modal.visible { opacity: 1; pointer-events: auto; }
.share-modal-content { background: var(--bg-container); border: 1px solid rgba(0, 201, 255, 0.1); border-radius: 1rem; padding: 2rem; width: 90%; max-width: 500px; box-shadow: 0 10px 30px rgba(0,0,0,0.3); transform: scale(0.95); transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); }
.share-modal.visible .share-modal-content { transform: scale(1); }
.share-modal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1.5rem; }
.share-modal-title { font-family: 'Orbitron', sans-serif; font-size: 1.5rem; margin: 0; color: var(--accent-color); }
.close-modal-btn { background: none; border: none; color: var(--text-muted); font-size: 2rem; cursor: pointer; line-height: 1; padding: 0; transition: color 0.2s; }
.close-modal-btn:hover { color: var(--text-color); }
.print-controls { margin-bottom: 1.5rem; display: flex; flex-direction: column; gap: 0.5rem; }
.print-summary { margin-bottom: 1.5rem; font-weight: bold; color: var(--accent-color); }

/* Print Area Styles */
.print-area { display: none; }
.ticket-90 { border: 2px solid #000; padding: 5px; margin-bottom: 10px; width: 100%; font-family: 'Inter', sans-serif; page-break-inside: avoid; display: flex; flex-direction: column; }
.ticket-90-grid { display: grid; grid-template-columns: repeat(9, 1fr); border: 1px solid #000; flex-grow: 1; }
.ticket-90-cell { border: 1px solid #000; height: 35px; display: flex; justify-content: center; align-items: center; font-weight: bold; font-size: 16px; background: #fff; color: #000; }
.ticket-90-cell.empty { background: #eee; }
.ticket-75 { border: 2px solid #000; padding: 10px; width: 100%; font-family: 'Inter', sans-serif; page-break-inside: avoid; box-sizing: border-box; display: flex; flex-direction: column; }
.ticket-75-header { display: grid; grid-template-columns: repeat(5, 1fr); text-align: center; font-weight: 900; font-size: 24px; margin-bottom: 5px; color: #000; }
.ticket-75-grid { display: grid; grid-template-columns: repeat(5, 1fr); border-top: 2px solid #000; border-left: 2px solid #000; flex-grow: 1; }
.ticket-75-cell { border-right: 2px solid #000; border-bottom: 2px solid #000; height: 50px; display: flex; justify-content: center; align-items: center; font-weight: bold; font-size: 20px; background: #fff; color: #000; }
.ticket-75-cell.free { background: #ddd; font-size: 12px; }
.ticket-footer { text-align: center; font-size: 10px; color: #000; margin-top: 4px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; }
.ticket-75 .ticket-footer { margin-top: 8px; font-size: 12px; }

/* PLAYER VIEW */
.player-view { padding: 20px; display: flex; flex-direction: column; align-items: center; min-height: 100vh; }
.player-header { width: 100%; display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.player-header h2 { margin: 0; font-family: 'Orbitron', sans-serif; color: var(--accent-color); font-size: 1.2rem; }
.player-controls { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.player-card-container { margin: 20px 0; width: 100%; max-width: 500px; }
.player-card-container .ticket-90, .player-card-container .ticket-75 { background: white; border-radius: 8px; }
.player-card-container .ticket-90-cell, .player-card-container .ticket-75-cell { cursor: pointer; user-select: none; }
.player-card-container .daubed { background-color: var(--dauber-color) !important; color: white !important; border-color: var(--dauber-color); position: relative; }
.player-card-container .daubed::after { content: ''; position: absolute; width: 70%; height: 70%; background: rgba(255,255,255,0.3); border-radius: 50%; }
.player-instruction { color: var(--text-muted); font-size: 0.9rem; margin-bottom: 10px; }

/* Confetti Canvas */
.confetti-canvas { position: fixed; top: 0; left: 0; width: 100%; height: 100%; pointer-events: none; z-index: 5000; }

/* Projector Mode */
.projector-mode .app-header, .projector-mode .page-title, .projector-mode .history-display, .projector-mode .mobile-controls-panel, .projector-mode .action-buttons, .projector-mode .mobile-header, .projector-mode .app-footer, .projector-mode .seo-content-wrapper, .projector-mode .intro-content, .projector-mode .legal-footer { display: none !important; }
.projector-mode .main-content-wrapper { margin: 0; padding: 0; width: 100%; height: 100vh; background-color: var(--bg-main); display: flex; justify-content: center; align-items: center; overflow: hidden; }
.projector-mode .main-content { width: 100%; height: 100%; margin: 0; gap: 0; display: flex; }
.projector-mode .board-panel { background: transparent; box-shadow: none; border: none; padding: 10px; height: 100%; display: flex; justify-content: center; align-items: center; }
.projector-mode .bingo-board { width: 100%; height: 100%; align-content: center; gap: 0.5vmin; }
.projector-mode .board-cell { border: 2px solid var(--cell-bg); font-weight: 900; }
.exit-projector-btn { display: none; position: fixed; bottom: 20px; right: 20px; z-index: 6000; background-color: rgba(255, 0, 0, 0.7); color: white; border: none; padding: 10px 20px; font-size: 1rem; border-radius: 8px; cursor: pointer; }
.projector-mode .exit-projector-btn { display: block; }

/* TV Auto Controls */
.tv-auto-controls {
    display: none; 
    background: rgba(0,0,0,0.5);
    padding: 10px;
    border-radius: 8px;
    margin-top: 10px;
    border: 1px solid var(--cell-bg);
    align-items: center; gap: 10px;
}

/* Mobile TV Mode */
@media (max-width: 950px) and (orientation: landscape) and (max-height: 500px) {
    .projector-mode .main-content { flex-direction: row; padding: 5px; gap: 5px; }
    
    .projector-mode .caller-panel {
        display: flex !important;
        flex: 0 0 30%;
        height: 100%;
        background: transparent;
        border: none;
        box-shadow: none;
        justify-content: flex-start;
        align-items: center;
        position: relative;
        top: auto;
        padding: 5px;
    }

    /* Hype Deck visible in mobile TV mode */
    .projector-mode .hype-deck-panel {
        display: flex !important;
        flex-wrap: wrap;
        width: 100%;
        gap: 5px;
        padding: 5px;
        background: transparent;
        border: none;
        justify-content: center;
        margin-bottom: 5px;
    }
    .projector-mode .hype-deck-panel .hype-label { display: none; }
    .projector-mode .hype-deck-panel .hype-buttons { 
        display: flex; flex-wrap: wrap; justify-content: center; width: 100%; gap: 5px;
    }
    .projector-mode .hype-deck-panel .hype-btn { width: 35px; height: 35px; font-size: 0.9rem; }

    .projector-mode .current-call-display {
        display: flex !important;
        width: 100px; height: 100px;
        margin-top: 5px;
        border-width: 3px;
    }
    .projector-mode .bingo-ball { width: 70px; height: 70px; font-size: 2.5rem; }
    .projector-mode .initial-call-text { font-size: 1.5rem; }

    /* Board Scaling */
    .projector-mode .board-panel { flex: 1; height: 100%; padding: 0; }
    .projector-mode .bingo-board {
        grid-template-columns: repeat(15, 1fr) !important;
        align-content: center;
        height: 100%;
        gap: 2px;
    }
    .projector-mode .board-cell {
        aspect-ratio: 1/1;
        font-size: 1.6vmin; 
        border-radius: 50%;
        border-width: 1px;
    }

    /* Show TV Toggle on Mobile TV Mode */
    .projector-mode .tv-auto-controls { display: flex; margin-top: 5px; padding: 5px; }
    .projector-mode .tv-auto-controls .auto-call-label { font-size: 0.7rem; }
    .projector-mode .tv-auto-controls .switch { transform: scale(0.8); }

    .projector-mode .exit-projector-btn {
        bottom: 5px; left: 5px; right: auto; width: 30%; font-size: 0.7rem; padding: 4px;
        background-color: rgba(255, 0, 0, 0.5);
    }
}

@media (orientation: portrait) {
    .projector-mode .rotate-overlay { display: flex !important; }
    .projector-mode .main-content { display: none !important; }
    .projector-mode .exit-projector-btn { z-index: 10000; bottom: 50px; left: 50%; transform: translateX(-50%); width: auto; }
}

@media (orientation: landscape) {
    .rotate-overlay { display: none !important; }
}

@media (min-width: 951px) and (orientation: landscape) {
    .projector-mode .main-content { flex-direction: row; align-items: center; justify-content: center; padding: 2vmin; }
    .projector-mode .caller-panel { display: flex !important; flex: 0 0 35%; height: 100%; background: transparent; border: none; box-shadow: none; justify-content: center; align-items: center; position: relative; top: auto; }
    .projector-mode .current-call-display { width: 30vmin; height: 30vmin; max-width: 100%; border-width: 1.5vmin; box-shadow: 0 0 5vmin rgba(0,0,0,0.5); }
    .projector-mode .bingo-ball { width: 22vmin; height: 22vmin; font-size: 12vmin; }
    .projector-mode #lingo-display { font-size: 3vmin; margin-top: 2vmin; }
    .projector-mode .board-panel { flex: 1; height: 95vh; }
    .projector-mode .board-cell { font-size: 2.2vmin; }
    
    /* Show TV Toggle on Desktop TV Mode */
    .projector-mode .tv-auto-controls { display: flex; position: absolute; bottom: 80px; }

    /* HYPE DECK DESKTOP TV MODE */
    .projector-mode .hype-deck-panel {
        display: flex !important;
        position: fixed;
        bottom: 20px;
        left: 20px;
        width: auto;
        max-width: 30%;
        z-index: 6000;
        background: rgba(0,0,0,0.6);
        border: 1px solid rgba(255, 255, 255, 0.1);
        padding: 10px;
        margin: 0;
        justify-content: center;
    }
    .projector-mode .hype-deck-panel .hype-label { display: none; }
    .projector-mode .hype-deck-panel .hype-buttons { gap: 10px; }
}

/* Print Media Query */
@media print {
    body * { visibility: hidden; }
    .mobile-header, .app-container, .app-footer { display: none !important; }
    .print-area, .print-area * { visibility: visible; }
    .print-area { display: block; position: absolute; top: 0; left: 0; width: 100%; }
    .seo-content-wrapper { display: none !important; }
    .page-90 { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; page-break-after: always; margin: 0 auto; width: 100%; padding: 10px; box-sizing: border-box; }
    .page-90:last-child { page-break-after: auto; }
    .page-75 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; page-break-after: always; margin: 0 auto; width: 100%; padding: 15px; box-sizing: border-box; }
    .page-75:last-child { page-break-after: auto; }
    @page { size: A4; margin: 5mm; }
}

/* Responsive Design */
@media (max-width: 992px) {
    body { flex-direction: column; }
    .main-content-wrapper { padding: 80px 20px 40px; width: 100%; box-sizing: border-box; margin-left: 0; }
    .mobile-header { display: flex; align-items: center; justify-content: space-between; padding: 0 20px; height: 60px; background-color: #1a202c; border-bottom: 1px solid #4a5568; position: fixed; top: 0; left: 0; width: 100%; z-index: 1000; box-sizing: border-box; }
    .mobile-title { font-family: 'Orbitron', sans-serif; color: #fff; font-weight: 600; font-size: 1.2rem; }
    .mobile-header-icon { background: var(--board-bg); border: 1px solid var(--cell-bg); color: var(--text-color); width: 40px; height: 40px; border-radius: 50%; display: flex; justify-content: center; align-items: center; font-size: 1rem; cursor: pointer; transition: all 0.2s; }
    .app-container { padding-top: 0; }
    .page-title { font-size: 1.75rem; }
    .app-header { display: none; }
    .mobile-controls-panel { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.75rem; padding: 1rem; background: var(--bg-container); border: 1px solid rgba(0, 201, 255, 0.1); border-radius: 1rem; margin-bottom: 1rem; min-height: 180px; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4); contain: layout paint; }
    .mobile-controls-panel .control-btn, .mobile-controls-panel .game-type-btn, .mobile-controls-panel .auto-call-controls, .mobile-controls-panel .speed-controls, .mobile-controls-panel .custom-voice-selector, .mobile-select { flex-grow: 1; text-align: center; justify-content: center; }
    .mobile-controls-panel .custom-voice-selector { width: auto; }
    
    /* FIX FOR CLS: Reserve space for voice selector */
    #voice-selector-mobile-container { min-height: 48px; width: 100%; display: flex; justify-content: center; }

    .mobile-controls-panel .speed-controls, .mobile-select, .mobile-full-width { flex-basis: 100%; }
    .main-content { flex-direction: column; align-items: center; gap: 1rem; }
    .caller-panel { position: static; width: 100%; padding: 1.5rem; }
    .board-panel { width: 100%; padding: 1rem; }
    .current-call-display { width: 200px; height: 200px; }
    .bingo-ball { width: 130px; height: 130px; font-size: 4rem; }
    .history-list { min-height: 45px; }
    .history-item { width: 45px; height: 45px; font-size: 1.25rem; }
    #desktop-call-btn { display: none; }
    .app-footer { display: block; padding: 1rem 0; position: sticky; bottom: 0; background-color: var(--bg-main); border-top: 1px solid var(--cell-bg); z-index: 900; width: 100%; }
    
    /* Responsive Grid Engine */
    .bingo-board { display: grid; gap: 0.5rem; height: auto; min-height: 0; grid-template-columns: repeat(5, 1fr); }
    .board-cell { font-size: 0.9rem; aspect-ratio: 1/1; }
    
    .header-subtitle { font-size: 0.9rem; margin-top: 0.5rem; padding: 0 10px; }
}

/* SEO Content Styles */
.seo-content-wrapper { width: 100%; max-width: 900px; margin: 4rem auto 2rem; padding: 40px; box-sizing: border-box; align-self: center; background-color: rgba(31, 41, 55, 0.3); border-radius: 16px; border: 1px solid rgba(255, 255, 255, 0.05); color: var(--text-muted); line-height: 1.7; }
.seo-article { font-family: 'Inter', sans-serif; }
.seo-title { color: var(--accent-color); font-family: 'Orbitron', sans-serif; margin-bottom: 1.5rem; text-align: center; font-size: 1.8rem; }
.seo-lead { font-size: 1.1rem; color: #fff; margin-bottom: 2rem; }
.seo-grid { display: grid; grid-template-columns: 1fr; gap: 20px; margin-bottom: 2rem; }
.seo-card { background: rgba(0,0,0,0.2); padding: 20px; border-radius: 12px; border: 1px solid var(--cell-bg); }
.seo-card h3 { color: var(--highlight-color); margin-top: 0; display: flex; align-items: center; gap: 10px; }
.seo-subtitle { color: #fff; margin-top: 2rem; margin-bottom: 1rem; font-family: 'Orbitron', sans-serif; font-size: 1.4rem; border-bottom: 1px solid var(--cell-bg); padding-bottom: 10px; }
.seo-list { list-style: none; padding: 0; display: grid; grid-template-columns: 1fr; gap: 10px; }
.seo-list li { padding-left: 25px; position: relative; }
.seo-list li::before { content: '✓'; color: var(--accent-color); position: absolute; left: 0; font-weight: bold; }
.faq-grid { display: flex; flex-direction: column; gap: 15px; }
.faq-item { background: rgba(0,0,0,0.2); border-radius: 8px; border: 1px solid var(--cell-bg); }
.faq-question { padding: 15px; cursor: pointer; font-weight: 600; color: #fff; display: flex; align-items: center; gap: 10px; }
.faq-answer { padding: 0 15px 15px 15px; color: var(--text-muted); line-height: 1.6; }
.legal-footer { text-align: center; margin-top: 50px; padding-top: 30px; border-top: 1px solid rgba(255, 255, 255, 0.1); display: flex; justify-content: center; align-items: center; gap: 15px; font-size: 0.9rem; }
.legal-link { color: #e2e8f0; text-decoration: none; font-weight: 500; border-bottom: 1px solid transparent; transition: all 0.2s; }
.legal-link:hover { color: var(--accent-color); border-bottom-color: var(--accent-color); }

@media (min-width: 768px) { .seo-grid { grid-template-columns: 1fr 1fr; } }

/* PULSE ANIMATION (Fixed Visibility) */
@keyframes ballPulse {
    0% { transform: scale(1); border-color: #334155; }
    50% { transform: scale(1.05); border-color: #00C9FF; box-shadow: inset 0 0 40px rgba(0, 201, 255, 0.5); }
    100% { transform: scale(1); border-color: #334155; }
}

.pulse-animation {
    animation: ballPulse 0.5s ease-out;
}

/* JUMBOTRON OVERLAY */
.jumbotron-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100vh;
    background: black; z-index: 9999;
    display: flex; flex-direction: column; justify-content: center; align-items: center;
    overflow: hidden;
}
.marquee-container {
    width: 100%; white-space: nowrap; overflow: hidden; display: flex;
}
.marquee-text {
    display: inline-block;
    font-family: 'Orbitron', sans-serif;
    font-size: 15vw;
    font-weight: 900;
    color: #facc15;
    text-shadow: 0 0 20px #facc15;
    padding-left: 100%;
    animation: marquee 8s linear infinite;
}
@keyframes marquee {
    0% { transform: translateX(0); }
    100% { transform: translateX(-100%); }
}
.close-jumbotron-btn {
    position: absolute; top: 20px; right: 30px;
    background: transparent; border: 2px solid rgba(255,255,255,0.3);
    color: white; font-size: 2rem; width: 50px; height: 50px;
    border-radius: 50%; cursor: pointer;
}