/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ EXPEDIENTE CLASIFICADO - IMPOSTOR GAME Noir Cyberpunk Interrogation Aesthetic ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ @import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Special+Elite&display=swap'); :root { /* LIGHT THEME: Interrogation Room */ --bg-primary: #dcd9d2; --bg-secondary: #c8c3b8; --bg-overlay: rgba(0, 0, 0, 0.05); --surface-glass: rgba(255, 255, 255, 0.85); --surface-card: rgba(255, 255, 255, 0.95); --surface-hover: rgba(255, 255, 255, 1); --text-primary: #0a0a0a; --text-secondary: #2a2a2a; --text-tertiary: #5a5a5a; --text-inverted: #ffffff; --accent-warning: #e6a73c; --accent-danger: #d93626; --accent-success: #2d8b3d; --accent-info: #2e4e7a; --border-light: rgba(0, 0, 0, 0.18); --border-medium: rgba(0, 0, 0, 0.35); --border-heavy: rgba(0, 0, 0, 0.55); --shadow-sm: 0 3px 12px rgba(0, 0, 0, 0.15); --shadow-md: 0 6px 24px rgba(0, 0, 0, 0.22); --shadow-lg: 0 12px 48px rgba(0, 0, 0, 0.28); --shadow-harsh: 6px 6px 0px rgba(0, 0, 0, 0.25); --grain-opacity: 0.05; --scanline-opacity: 0.025; /* Spotlight effect */ --spotlight-color: rgba(255, 235, 180, 0.08); --vignette-intensity: 0.4; } [data-theme="dark"] { /* DARK THEME: Night Investigation */ --bg-primary: #050505; --bg-secondary: #0f0f0f; --bg-overlay: rgba(255, 255, 255, 0.03); --surface-glass: rgba(25, 25, 25, 0.9); --surface-card: rgba(35, 35, 35, 0.95); --surface-hover: rgba(45, 45, 45, 1); --text-primary: #f5f5f5; --text-secondary: #d0d0d0; --text-tertiary: #909090; --text-inverted: #0a0a0a; --accent-warning: #ffb84d; --accent-danger: #ff3d2e; --accent-success: #3dd46b; --accent-info: #4d8ce0; --border-light: rgba(255, 255, 255, 0.12); --border-medium: rgba(255, 255, 255, 0.22); --border-heavy: rgba(255, 255, 255, 0.35); --shadow-sm: 0 3px 12px rgba(0, 0, 0, 0.6); --shadow-md: 0 6px 24px rgba(0, 0, 0, 0.8); --shadow-lg: 0 12px 48px rgba(0, 0, 0, 0.95); --shadow-harsh: 6px 6px 0px rgba(0, 0, 0, 0.7); --grain-opacity: 0.07; --scanline-opacity: 0.035; /* Spotlight effect */ --spotlight-color: rgba(255, 200, 100, 0.04); --vignette-intensity: 0.6; } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ BASE STYLES & TYPOGRAPHY ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ * { margin: 0; padding: 0; box-sizing: border-box; -webkit-tap-highlight-color: transparent; } body { font-family: 'JetBrains Mono', 'Courier Prime', 'Courier New', monospace; background: radial-gradient(ellipse 80% 50% at 50% 20%, var(--spotlight-color) 0%, transparent 50%), radial-gradient(circle at 20% 30%, rgba(230, 167, 60, 0.08) 0%, transparent 40%), radial-gradient(circle at 80% 70%, rgba(217, 54, 38, 0.06) 0%, transparent 40%), var(--bg-primary); min-height: 100vh; min-height: 100dvh; display: flex; justify-content: center; align-items: center; padding: calc(70px + env(safe-area-inset-top, 24px)) 16px calc(16px + env(safe-area-inset-bottom, 0px)); color: var(--text-primary); position: relative; overflow: hidden; font-size: 14px; letter-spacing: 0px; transition: background 0.5s ease, color 0.3s ease; } /* Film grain texture overlay */ body::before { content: ''; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.5'/%3E%3C/svg%3E"); opacity: var(--grain-opacity); pointer-events: none; z-index: 9999; mix-blend-mode: overlay; animation: grain 8s steps(10) infinite; } @keyframes grain { 0%, 100% { transform: translate(0, 0); } 10% { transform: translate(-5%, -10%); } 20% { transform: translate(-15%, 5%); } 30% { transform: translate(7%, -25%); } 40% { transform: translate(-5%, 25%); } 50% { transform: translate(-15%, 10%); } 60% { transform: translate(15%, 0%); } 70% { transform: translate(0%, 15%); } 80% { transform: translate(3%, 35%); } 90% { transform: translate(-10%, 10%); } } /* Scanlines */ body::after { content: ''; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: repeating-linear-gradient( 0deg, transparent, transparent 2px, rgba(0, 0, 0, 0.1) 2px, rgba(0, 0, 0, 0.1) 4px ); opacity: var(--scanline-opacity); pointer-events: none; z-index: 9998; } /* Dramatic vignette overlay */ .vignette-overlay { position: fixed; inset: 0; background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,var(--vignette-intensity)) 100%); pointer-events: none; z-index: 9997; } /* VHS interference effect */ @keyframes vhsInterference { 0%, 100% { opacity: 0; } 5% { opacity: 0.03; transform: translateX(-2px); } 10% { opacity: 0; } 15% { opacity: 0.02; transform: translateX(1px); } 20% { opacity: 0; } } .vhs-line { position: fixed; left: 0; width: 100%; height: 3px; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.8), transparent); pointer-events: none; z-index: 9996; animation: vhsScan 8s linear infinite; opacity: 0.04; } @keyframes vhsScan { 0% { top: -10px; } 100% { top: 110%; } } h1 { font-family: 'Bebas Neue', 'Crimson Text', Georgia, serif; text-align: center; margin-bottom: 20px; font-size: 2.6em; font-weight: 400; letter-spacing: 4px; text-transform: uppercase; position: relative; text-shadow: 3px 3px 0px var(--bg-secondary), 0 0 30px rgba(230, 167, 60, 0.2); line-height: 1.1; animation: titleReveal 0.6s cubic-bezier(0.22, 1, 0.36, 1) forwards; } @keyframes titleReveal { from { opacity: 0; letter-spacing: 20px; filter: blur(8px); } to { opacity: 1; letter-spacing: 4px; filter: blur(0); } } h1::after { content: ''; display: block; width: 80px; height: 4px; background: linear-gradient(90deg, var(--accent-danger) 0%, var(--accent-warning) 50%, var(--accent-danger) 100%); background-size: 200% 100%; margin: 14px auto 0; box-shadow: 0 0 15px rgba(230, 167, 60, 0.5); animation: shimmer 3s ease-in-out infinite; } @keyframes shimmer { 0%, 100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } } h2 { font-family: 'Crimson Text', Georgia, serif; text-align: center; margin: 16px 0; font-size: 1.4em; font-weight: 700; letter-spacing: 0.5px; } h3 { font-family: 'JetBrains Mono', monospace; font-size: 1em; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 12px; } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ CONTAINER & SCREENS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .container { width: 100%; max-width: 480px; background: var(--surface-glass); backdrop-filter: blur(20px) saturate(150%); border-radius: 0; padding: 28px 22px; box-shadow: var(--shadow-harsh), var(--shadow-lg); border: 4px solid var(--border-heavy); display: flex; flex-direction: column; transition: all 0.4s ease; margin-bottom: 20px; position: relative; overflow: hidden; clip-path: polygon( 0 20px, 20px 0, 100% 0, 100% calc(100% - 20px), calc(100% - 20px) 100%, 0 100% ); } .container::before { content: '⬢ CLASSIFIED ⬢'; position: absolute; top: 8px; left: 50%; transform: translateX(-50%); font-size: 0.65em; letter-spacing: 3px; opacity: 0.4; font-weight: 800; color: var(--accent-danger); text-shadow: 0 0 10px rgba(217, 54, 38, 0.3); animation: classifiedPulse 4s ease-in-out infinite; } @keyframes classifiedPulse { 0%, 100% { opacity: 0.4; text-shadow: 0 0 10px rgba(217, 54, 38, 0.3); } 50% { opacity: 0.6; text-shadow: 0 0 20px rgba(217, 54, 38, 0.6); } } /* Diagonal classified stamp */ .container::after { content: 'EXPEDIENTE'; position: absolute; bottom: 15px; right: -30px; font-family: 'Special Elite', 'Courier Prime', monospace; font-size: 0.7em; letter-spacing: 3px; color: var(--accent-danger); opacity: 0.12; transform: rotate(-45deg); font-weight: 400; white-space: nowrap; pointer-events: none; } .screen { display: none; animation: screenEnter 0.35s cubic-bezier(0.22, 1, 0.36, 1); flex: 1; overflow: hidden; min-height: 0; } .screen.active { display: flex; flex-direction: column; } @keyframes screenEnter { 0% { opacity: 0; transform: translateY(30px) scale(0.95); filter: blur(4px); } 60% { opacity: 1; filter: blur(0); } 100% { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); } } /* Staggered children animation */ .screen.active > * { animation: fadeSlideUp 0.5s cubic-bezier(0.22, 1, 0.36, 1) backwards; } .screen.active > *:nth-child(1) { animation-delay: 0.05s; } .screen.active > *:nth-child(2) { animation-delay: 0.1s; } .screen.active > *:nth-child(3) { animation-delay: 0.15s; } .screen.active > *:nth-child(4) { animation-delay: 0.2s; } .screen.active > *:nth-child(5) { animation-delay: 0.25s; } .screen.active > *:nth-child(6) { animation-delay: 0.3s; } .screen.active > *:nth-child(7) { animation-delay: 0.35s; } .screen.active > *:nth-child(8) { animation-delay: 0.4s; } @keyframes fadeSlideUp { from { opacity: 0; transform: translateY(15px); } to { opacity: 1; transform: translateY(0); } } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ FORM CONTROLS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .form-group { margin-bottom: 16px; } .form-group.compact { margin-bottom: 12px; } label { display: block; margin-bottom: 8px; font-weight: 700; font-size: 0.8em; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 1.2px; } input { width: 100%; padding: 12px 14px; border: 2px solid var(--border-medium); border-radius: 0; font-size: 0.95em; font-family: 'JetBrains Mono', monospace; background: var(--surface-card); color: var(--text-primary); transition: all 0.2s ease; box-shadow: inset 2px 2px 4px rgba(0, 0, 0, 0.1); } input:focus { outline: none; border-color: var(--accent-warning); box-shadow: inset 2px 2px 4px rgba(0, 0, 0, 0.1), 0 0 0 3px rgba(212, 165, 116, 0.2); transform: translateY(-1px); } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ BUTTONS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ button { width: 100%; padding: 16px 20px; border: 3px solid var(--text-primary); border-radius: 0; font-size: 0.9em; font-weight: 800; font-family: 'JetBrains Mono', monospace; cursor: pointer; background: var(--text-primary); color: var(--text-inverted); box-shadow: var(--shadow-harsh); transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1); margin-top: 12px; text-transform: uppercase; letter-spacing: 0.8px; position: relative; overflow: hidden; clip-path: polygon( 0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 12px) ); } button::before { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-radius: 50%; background: rgba(255, 255, 255, 0.2); transform: translate(-50%, -50%); transition: width 0.5s ease, height 0.5s ease; } button:hover::before { width: 300px; height: 300px; } button:hover { box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.3); filter: brightness(1.1); } button:active { box-shadow: 2px 2px 0px rgba(0, 0, 0, 0.15); filter: brightness(0.95); } button.secondary { background: linear-gradient(135deg, var(--accent-warning) 0%, #c48a2e 100%); border-color: var(--accent-warning); color: var(--text-inverted); box-shadow: var(--shadow-harsh), 0 0 15px rgba(230, 167, 60, 0.25); } button.ghost { background: transparent; color: var(--text-primary); border-color: var(--border-medium); box-shadow: none; } button.ghost:hover { background: var(--surface-hover); box-shadow: var(--shadow-harsh); } button:disabled { opacity: 0.4; cursor: not-allowed; pointer-events: none; } .btn-primary { background: linear-gradient(135deg, var(--accent-danger) 0%, #b8301e 100%); border-color: var(--accent-danger); box-shadow: var(--shadow-harsh), 0 0 20px rgba(217, 54, 38, 0.3); } .btn-secondary { background: linear-gradient(135deg, var(--accent-info) 0%, #1e3a5f 100%); border-color: var(--accent-info); box-shadow: var(--shadow-harsh), 0 0 20px rgba(46, 78, 122, 0.3); } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ WELCOME SCREEN ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .welcome-content { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; height: 100%; gap: 24px; padding: 20px 0; } .welcome-logo { width: 140px; height: 140px; object-fit: contain; filter: drop-shadow(5px 5px 0px var(--bg-secondary)) drop-shadow(0 0 30px rgba(230, 167, 60, 0.3)) grayscale(0.2) contrast(1.15); animation: logoFloat 4s ease-in-out infinite, logoGlitch 8s step-end infinite; position: relative; } @keyframes logoFloat { 0%, 100% { transform: translateY(0) rotate(0deg); } 25% { transform: translateY(-8px) rotate(-2deg); } 75% { transform: translateY(-8px) rotate(2deg); } } @keyframes logoGlitch { 0%, 90%, 100% { filter: drop-shadow(4px 4px 0px var(--bg-secondary)) drop-shadow(0 0 20px var(--border-heavy)) grayscale(0.3) contrast(1.1); } 91% { filter: drop-shadow(6px 4px 0px var(--accent-danger)) drop-shadow(0 0 20px var(--accent-danger)) grayscale(0) contrast(1.3); } 92% { filter: drop-shadow(4px 6px 0px var(--accent-info)) drop-shadow(0 0 20px var(--accent-info)) grayscale(0) contrast(1.3); } 93% { filter: drop-shadow(4px 4px 0px var(--bg-secondary)) drop-shadow(0 0 20px var(--border-heavy)) grayscale(0.3) contrast(1.1); } } .welcome-title { font-size: 2.8em; margin: 0; font-family: 'Bebas Neue', 'Crimson Text', Georgia, serif; font-weight: 400; text-shadow: 4px 4px 0px var(--bg-secondary), 0 0 40px rgba(230, 167, 60, 0.25); letter-spacing: 6px; line-height: 1; position: relative; animation: welcomeTitleReveal 0.8s cubic-bezier(0.22, 1, 0.36, 1) forwards; } @keyframes welcomeTitleReveal { 0% { opacity: 0; letter-spacing: 30px; filter: blur(10px); transform: scale(0.9); } 100% { opacity: 1; letter-spacing: 6px; filter: blur(0); transform: scale(1); } } .welcome-subtitle { font-size: 0.95em; color: var(--text-secondary); margin: -10px 0 0 0; font-weight: 400; letter-spacing: 0.5px; font-family: 'JetBrains Mono', monospace; } .welcome-buttons { display: flex; flex-direction: column; gap: 12px; width: 100%; max-width: 320px; margin-top: 10px; } .welcome-credits { color: var(--text-tertiary); font-size: 0.75em; margin-top: auto; font-weight: 400; letter-spacing: 1px; text-transform: uppercase; } .welcome-credits::before { content: '───── '; } .welcome-credits::after { content: ' ─────'; } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ RULES SCREEN ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .rules-content { flex: 1; overflow-y: auto; overflow-x: hidden; padding: 10px 0; -webkit-overflow-scrolling: touch; scrollbar-width: none; -ms-overflow-style: none; } .rules-content::-webkit-scrollbar { display: none; } .rule-section { background: var(--surface-card); border: 3px solid var(--border-medium); border-left: 8px solid var(--accent-warning); border-radius: 0; padding: 18px; margin-bottom: 16px; transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1); position: relative; box-shadow: var(--shadow-md); clip-path: polygon( 0 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100% ); animation: ruleSlideIn 0.4s cubic-bezier(0.22, 1, 0.36, 1) backwards; } .rule-section:nth-child(1) { animation-delay: 0.1s; } .rule-section:nth-child(2) { animation-delay: 0.2s; } .rule-section:nth-child(3) { animation-delay: 0.3s; } .rule-section:nth-child(4) { animation-delay: 0.4s; } @keyframes ruleSlideIn { from { opacity: 0; transform: translateX(-20px); } to { opacity: 1; transform: translateX(0); } } .rule-section::before { content: '▸'; position: absolute; left: -3px; top: 18px; font-size: 1.5em; color: var(--accent-warning); animation: blink 2s ease-in-out infinite; } @keyframes blink { 0%, 49%, 100% { opacity: 1; } 50%, 99% { opacity: 0; } } .rule-section:hover { background: var(--surface-hover); border-left-color: var(--accent-danger); box-shadow: var(--shadow-lg); } .rule-section h3 { margin: 0 0 14px 0; color: var(--text-primary); font-size: 0.95em; } .rule-section p { margin: 8px 0; color: var(--text-secondary); line-height: 1.7; font-size: 0.85em; letter-spacing: 0.3px; } .rule-section strong { color: var(--accent-danger); font-weight: 800; text-transform: uppercase; font-size: 0.9em; letter-spacing: 0.5px; } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ PLAYER MANAGEMENT ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .player-names-list { flex: 1 1 auto; min-height: 0; max-height: 360px; /* Altura máxima para activar scroll y mostrar fila parcial - efecto peek */ overflow-y: scroll; overflow-x: hidden; margin-bottom: 12px; -webkit-overflow-scrolling: touch; scrollbar-width: none; /* Firefox */ -ms-overflow-style: none; /* IE y Edge */ /* Visual frame to indicate scrollable area */ background: var(--surface-card); border: 4px solid var(--border-heavy); border-radius: 0; padding: 12px; box-shadow: inset 0 4px 12px rgba(0, 0, 0, 0.15), inset 0 -4px 12px rgba(0, 0, 0, 0.15), var(--shadow-md); /* Gradiente para crear efecto peek - texto cortado visible */ -webkit-mask-image: linear-gradient(to bottom, black 0%, black calc(100% - 40px), transparent 100%); mask-image: linear-gradient(to bottom, black 0%, black calc(100% - 40px), transparent 100%); } .player-names-list::-webkit-scrollbar { display: none; /* Chrome, Safari, Opera */ } .player-name-item { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; background: var(--bg-secondary); padding: 12px; border-radius: 0; border: 2px solid var(--border-light); border-left: 4px solid var(--accent-info); transition: all 0.2s ease; box-shadow: var(--shadow-sm); } .player-name-item:last-child { margin-bottom: 0; } .player-name-item:hover { background: var(--surface-hover); border-left-color: var(--accent-warning); transform: translateX(2px); } .player-name-item span { font-weight: 800; min-width: 80px; font-size: 0.8em; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 1px; } .player-name-item input { flex: 1; padding: 10px; margin: 0; font-size: 0.85em; border-width: 2px; } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ CURTAIN REVEAL MECHANISM ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .curtain { position: relative; width: 100%; height: 280px; background: var(--bg-secondary); border-radius: 0; overflow: hidden; margin: 12px 0; box-shadow: inset 0 0 40px rgba(0, 0, 0, 0.3), var(--shadow-harsh); cursor: grab; user-select: none; border: 3px solid var(--border-heavy); flex-shrink: 0; } .curtain:active { cursor: grabbing; } .curtain-cover { position: absolute; inset: 0; background: repeating-linear-gradient( 0deg, #2a2a2a 0px, #2a2a2a 8px, #1a1a1a 8px, #1a1a1a 12px ), linear-gradient(180deg, rgba(255,200,100,0.03) 0%, transparent 50%); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; font-size: 1.1em; font-weight: 800; color: #888; transition: transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1); z-index: 10; user-select: none; box-shadow: inset 0 -20px 40px rgba(0, 0, 0, 0.5), inset 0 0 60px rgba(0,0,0,0.3); letter-spacing: 2px; font-family: 'Bebas Neue', 'JetBrains Mono', monospace; } .curtain-cover::after { content: ''; position: absolute; bottom: -8px; left: 0; right: 0; height: 8px; background: linear-gradient(90deg, transparent 0%, rgba(0,0,0,0.3) 25%, rgba(0,0,0,0.5) 50%, rgba(0,0,0,0.3) 75%, transparent 100%); } .curtain-cover.lifted { transform: translateY(-100%); } .curtain-icon { font-size: 2.5em; animation: bounce 2s ease-in-out infinite; } @keyframes bounce { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-12px); } } .curtain-content { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 20px; padding: 20px; text-align: center; } .role { font-size: 2.4em; font-weight: 400; padding: 16px 32px; border-radius: 0; text-transform: uppercase; border: 4px solid; font-family: 'Bebas Neue', 'JetBrains Mono', monospace; letter-spacing: 6px; box-shadow: var(--shadow-harsh); position: relative; animation: roleReveal 0.4s cubic-bezier(0.22, 1, 0.36, 1) forwards; } @keyframes roleReveal { 0% { opacity: 0; transform: scale(0.5) rotate(-5deg); filter: blur(10px); } 50% { transform: scale(1.1) rotate(2deg); } 100% { opacity: 1; transform: scale(1) rotate(0); filter: blur(0); } } .role.civil { background: var(--accent-success); color: var(--text-inverted); border-color: #3d5a40; animation: civilPulse 2s ease-in-out infinite; } .role.impostor { background: var(--accent-danger); color: var(--text-inverted); border-color: #8a2e26; animation: impostorPulse 1.5s ease-in-out infinite; } @keyframes civilPulse { 0%, 100% { box-shadow: 4px 4px 0px rgba(0, 0, 0, 0.3), 0 0 0px rgba(90, 125, 95, 0.5); } 50% { box-shadow: 4px 4px 0px rgba(0, 0, 0, 0.3), 0 0 25px rgba(90, 125, 95, 0.8); } } @keyframes impostorPulse { 0%, 100% { box-shadow: 4px 4px 0px rgba(0, 0, 0, 0.3), 0 0 0px rgba(196, 69, 54, 0.5); } 50% { box-shadow: 4px 4px 0px rgba(0, 0, 0, 0.3), 0 0 30px rgba(196, 69, 54, 0.9); } } .word { font-size: 2em; font-weight: 400; background: var(--surface-card); padding: 20px 36px; border-radius: 0; border: 3px solid var(--border-heavy); font-family: 'Special Elite', 'Crimson Text', serif; letter-spacing: 2px; box-shadow: var(--shadow-harsh); color: var(--text-primary); text-transform: uppercase; animation: wordReveal 0.5s cubic-bezier(0.22, 1, 0.36, 1) 0.2s forwards; opacity: 0; } @keyframes wordReveal { 0% { opacity: 0; transform: translateY(20px); filter: blur(5px); } 100% { opacity: 1; transform: translateY(0); filter: blur(0); } } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ TIMER ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .timer { font-size: 4em; font-weight: 800; text-align: center; margin: 20px 0; padding: 24px; background: var(--surface-card); border-radius: 0; border: 5px solid var(--border-heavy); font-family: 'Bebas Neue', 'JetBrains Mono', monospace; letter-spacing: 8px; box-shadow: var(--shadow-harsh), inset 0 0 30px rgba(0, 0, 0, 0.2); position: relative; clip-path: polygon( 16px 0, calc(100% - 16px) 0, 100% 16px, 100% calc(100% - 16px), calc(100% - 16px) 100%, 16px 100%, 0 calc(100% - 16px), 0 16px ); animation: timerAppear 0.5s cubic-bezier(0.22, 1, 0.36, 1) forwards; } @keyframes timerAppear { from { opacity: 0; transform: scale(0.8); filter: blur(5px); } to { opacity: 1; transform: scale(1); filter: blur(0); } } .timer::before { content: ''; position: absolute; top: 8px; right: 8px; width: 12px; height: 12px; background: var(--accent-success); border-radius: 50%; box-shadow: 0 0 10px var(--accent-success); animation: statusBlink 2s ease-in-out infinite; } @keyframes statusBlink { 0%, 49%, 100% { opacity: 1; } 50%, 99% { opacity: 0.3; } } .timer.warning { color: var(--accent-warning); border-color: var(--accent-warning); animation: timerShake 0.5s ease-in-out infinite; } .timer.warning::before { background: var(--accent-warning); box-shadow: 0 0 10px var(--accent-warning); } .timer.danger { color: var(--accent-danger); border-color: var(--accent-danger); animation: timerShake 0.25s ease-in-out infinite, dangerFlash 1s ease-in-out infinite; } .timer.danger::before { background: var(--accent-danger); box-shadow: 0 0 15px var(--accent-danger); animation: statusBlink 0.5s ease-in-out infinite; } @keyframes timerShake { 0%, 100% { transform: translateX(0); } 25% { transform: translateX(-4px); } 75% { transform: translateX(4px); } } @keyframes dangerFlash { 0%, 100% { background: var(--surface-card); } 50% { background: rgba(196, 69, 54, 0.15); } } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ INFO BOXES & CONTENT ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .info-text { text-align: center; margin: 14px 0; font-size: 0.85em; line-height: 1.7; background: var(--surface-card); padding: 14px 16px; border-radius: 0; color: var(--text-secondary); border: 2px solid var(--border-light); border-left: 5px solid var(--accent-info); box-shadow: var(--shadow-sm), inset 4px 0 8px rgba(46, 78, 122, 0.1); letter-spacing: 0.3px; } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ PLAYER SELECTION GRID ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .player-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 10px; margin: 12px 0; flex: 1; overflow-y: auto; overflow-x: hidden; -webkit-overflow-scrolling: touch; padding: 4px; scrollbar-width: none; -ms-overflow-style: none; } .player-list::-webkit-scrollbar { display: none; } .player-item { padding: 18px 14px; min-height: 80px; /* Altura fija para evitar cambios de tamaño con vote-count */ background: var(--surface-card); border-radius: 0; text-align: center; cursor: pointer; transition: all 0.25s cubic-bezier(0.22, 1, 0.36, 1); font-weight: 800; font-size: 0.85em; border: 3px solid var(--border-medium); box-shadow: var(--shadow-sm); letter-spacing: 0.5px; text-transform: uppercase; position: relative; display: flex; flex-direction: column; justify-content: center; align-items: center; clip-path: polygon( 8px 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%, 0 8px ); animation: playerItemAppear 0.3s cubic-bezier(0.22, 1, 0.36, 1) backwards; } .player-item:nth-child(1) { animation-delay: 0.05s; } .player-item:nth-child(2) { animation-delay: 0.1s; } .player-item:nth-child(3) { animation-delay: 0.15s; } .player-item:nth-child(4) { animation-delay: 0.2s; } .player-item:nth-child(5) { animation-delay: 0.25s; } .player-item:nth-child(6) { animation-delay: 0.3s; } .player-item:nth-child(7) { animation-delay: 0.35s; } .player-item:nth-child(8) { animation-delay: 0.4s; } .player-item:nth-child(9) { animation-delay: 0.45s; } .player-item:nth-child(10) { animation-delay: 0.5s; } @keyframes playerItemAppear { from { opacity: 0; transform: scale(0.8); } to { opacity: 1; transform: scale(1); } } .player-item::before { content: '□'; position: absolute; top: 6px; right: 6px; font-size: 1.2em; transition: all 0.2s ease; } .player-item:hover { background: var(--surface-hover); box-shadow: 6px 6px 0px rgba(0, 0, 0, 0.25); filter: brightness(1.05); } .player-item:active { box-shadow: 2px 2px 0px rgba(0, 0, 0, 0.15); filter: brightness(0.95); } .player-item.selected { background: var(--accent-danger); border-color: var(--text-primary); color: var(--text-inverted); box-shadow: 0 0 0 4px rgba(217, 54, 38, 0.5), 6px 6px 0px rgba(0, 0, 0, 0.4); animation: selectPulse 0.3s ease-out; } @keyframes selectPulse { 0% { transform: scale(1); } 50% { transform: scale(1.08); } 100% { transform: scale(1); } } .player-item.selected::before { content: '☑'; animation: checkAppear 0.2s ease-out; } @keyframes checkAppear { from { transform: scale(0) rotate(-180deg); } to { transform: scale(1) rotate(0); } } .player-item.disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; background: var(--bg-secondary); border-color: var(--border-light); filter: grayscale(0.6); animation: playerItemAppearDisabled 0.3s cubic-bezier(0.22, 1, 0.36, 1) backwards !important; } .player-item.disabled::before { content: '✕'; color: var(--text-tertiary); } .player-item .vote-count { display: block; font-size: 0.7em; margin-top: 4px; opacity: 0.75; font-weight: 600; letter-spacing: 0.3px; min-height: 1em; /* Reservar espacio siempre */ } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ RESULTS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .results { background: var(--surface-card); border-radius: 0; padding: 14px; margin: 8px 0; flex: 1; overflow: visible; border: 2px solid var(--border-medium); box-shadow: var(--shadow-md); animation: resultsReveal 0.5s cubic-bezier(0.22, 1, 0.36, 1) forwards; } @keyframes resultsReveal { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } } .results h2 { font-family: 'Bebas Neue', 'Crimson Text', Georgia, serif; font-size: 1.6em; letter-spacing: 3px; margin-bottom: 10px; animation: winnerReveal 0.6s cubic-bezier(0.22, 1, 0.36, 1) forwards; } @keyframes winnerReveal { 0% { opacity: 0; transform: scale(0.5); filter: blur(10px); } 60% { transform: scale(1.1); } 100% { opacity: 1; transform: scale(1); filter: blur(0); } } .role-reveal { background: var(--bg-secondary); padding: 8px 10px; border-radius: 0; margin: 5px 0; border-left: 4px solid; font-size: 0.8em; letter-spacing: 0.2px; box-shadow: var(--shadow-sm); transition: all 0.2s ease; animation: roleRevealSlide 0.4s cubic-bezier(0.22, 1, 0.36, 1) backwards; } .role-reveal:nth-child(1) { animation-delay: 0.3s; } .role-reveal:nth-child(2) { animation-delay: 0.4s; } .role-reveal:nth-child(3) { animation-delay: 0.5s; } .role-reveal:nth-child(4) { animation-delay: 0.6s; } .role-reveal:nth-child(5) { animation-delay: 0.7s; } .role-reveal:nth-child(6) { animation-delay: 0.8s; } .role-reveal:nth-child(7) { animation-delay: 0.9s; } .role-reveal:nth-child(8) { animation-delay: 1s; } .role-reveal:nth-child(9) { animation-delay: 1.1s; } .role-reveal:nth-child(10) { animation-delay: 1.2s; } @keyframes roleRevealSlide { from { opacity: 0; transform: translateX(-20px); } to { opacity: 1; transform: translateX(0); } } .role-reveal:hover { transform: translateX(3px); } .role-reveal.civil-reveal { border-left-color: var(--accent-success); } .role-reveal.impostor-reveal { border-left-color: var(--accent-danger); } .role-reveal.executed { opacity: 0.5; background: rgba(0, 0, 0, 0.2); text-decoration: line-through; } .tag { display: inline-block; padding: 6px 10px; border-radius: 0; background: var(--surface-hover); margin: 4px 0; font-weight: 800; font-size: 0.75em; border: 2px solid var(--border-medium); letter-spacing: 1px; text-transform: uppercase; } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ POOL SELECTION ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .pool-buttons { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; padding: 0; } .pool-buttons-wrapper { position: relative; flex: 1 1 auto; min-height: 0; max-height: 320px; /* Ajustado para mostrar fila parcial - efecto peek */ overflow-y: scroll; overflow-x: hidden; -webkit-overflow-scrolling: touch; scrollbar-width: none; /* Firefox */ -ms-overflow-style: none; /* IE y Edge */ /* Visual frame to indicate scrollable area */ background: var(--surface-card); border: 4px solid var(--border-heavy); border-radius: 0; padding: 12px; margin: 12px 0; box-shadow: inset 0 4px 12px rgba(0, 0, 0, 0.15), inset 0 -4px 12px rgba(0, 0, 0, 0.15), var(--shadow-md); /* Gradiente para crear efecto peek - texto cortado visible */ -webkit-mask-image: linear-gradient(to bottom, black 0%, black calc(100% - 50px), transparent 100%); mask-image: linear-gradient(to bottom, black 0%, black calc(100% - 50px), transparent 100%); } .pool-buttons-wrapper::-webkit-scrollbar { display: none; /* Chrome, Safari, Opera */ } .pool-btn { padding: 12px 10px; border-radius: 0; border: 2px solid var(--border-medium); background: var(--surface-card); color: var(--text-primary); font-weight: 700; font-size: 0.8em; cursor: pointer; transition: all 0.18s ease; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; text-transform: uppercase; letter-spacing: 0.5px; box-shadow: var(--shadow-sm); } .pool-btn:hover { background: var(--surface-hover); box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.15); filter: brightness(1.05); } .pool-btn.selected { border-color: var(--text-primary); background: var(--accent-warning); color: var(--text-inverted); box-shadow: 0 0 0 3px rgba(212, 165, 116, 0.3), 3px 3px 0px rgba(0, 0, 0, 0.2); } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ FIXED UI CONTROLS (Theme, Language, Exit) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ .theme-toggle { position: fixed; top: calc(20px + env(safe-area-inset-top, 24px)); right: 20px; width: 56px; height: 56px; border-radius: 0; border: 3px solid var(--border-heavy); background: var(--surface-glass); backdrop-filter: blur(20px); cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 1.6em; box-shadow: var(--shadow-harsh); transition: all 0.2s ease; z-index: 1000; margin: 0; padding: 0; } .theme-toggle:hover { box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.2); filter: brightness(1.1); } .theme-toggle:active { box-shadow: 2px 2px 0px rgba(0, 0, 0, 0.15); filter: brightness(0.95); } .theme-icon { transition: transform 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55); display: inline-block; } .theme-toggle:hover .theme-icon { transform: rotate(180deg) scale(1.1); } .language-toggle { position: fixed; top: calc(86px + env(safe-area-inset-top, 24px)); right: 20px; width: auto; min-width: 56px; height: 56px; padding: 0 16px; border-radius: 0; border: 3px solid var(--border-heavy); background: var(--surface-glass); backdrop-filter: blur(20px); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-size: 1em; font-weight: 800; box-shadow: var(--shadow-harsh); transition: all 0.2s ease; z-index: 1000; color: var(--text-primary); margin: 0; text-transform: uppercase; letter-spacing: 1px; } .language-toggle:hover { box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.2); filter: brightness(1.1); } .language-toggle:active { box-shadow: 2px 2px 0px rgba(0, 0, 0, 0.15); filter: brightness(0.95); } .language-icon { font-size: 1.3em; transition: transform 0.3s ease; display: inline-block; } .language-text { font-size: 0.85em; letter-spacing: 1.5px; font-family: 'JetBrains Mono', monospace; } .exit-game { position: fixed; top: calc(20px + env(safe-area-inset-top, 24px)); left: 20px; width: auto; height: 56px; padding: 0 16px; border-radius: 0; border: 3px solid var(--border-heavy); background: var(--surface-glass); backdrop-filter: blur(20px); cursor: pointer; display: none; align-items: center; justify-content: center; gap: 10px; font-size: 0.85em; font-weight: 800; box-shadow: var(--shadow-harsh); transition: all 0.2s ease; z-index: 1000; color: var(--text-primary); text-transform: uppercase; letter-spacing: 1px; } .exit-game.visible { display: inline-flex; } .exit-game:hover { box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.2); background: var(--accent-danger); color: var(--text-inverted); } .exit-game:active { box-shadow: 2px 2px 0px rgba(0, 0, 0, 0.15); } .exit-icon { font-size: 1.3em; } .exit-text { font-size: 0.9em; font-family: 'JetBrains Mono', monospace; } .screen-lock-toggle { position: fixed; top: calc(152px + env(safe-area-inset-top, 24px)); right: 20px; width: 56px; height: 56px; border-radius: 0; border: 3px solid var(--border-heavy); background: var(--surface-glass); backdrop-filter: blur(20px); cursor: pointer; display: none; align-items: center; justify-content: center; font-size: 1.6em; box-shadow: var(--shadow-harsh); transition: all 0.2s ease; z-index: 1000; margin: 0; padding: 0; } .screen-lock-toggle.visible { display: inline-flex; } .screen-lock-toggle:hover { box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.2); filter: brightness(1.1); } .screen-lock-toggle:active { box-shadow: 2px 2px 0px rgba(0, 0, 0, 0.15); filter: brightness(0.95); } .screen-lock-toggle.active { background: var(--accent-success); color: var(--text-inverted); border-color: var(--accent-success); } .screen-lock-icon { transition: transform 0.3s ease; display: inline-block; } .screen-lock-toggle:hover .screen-lock-icon { transform: scale(1.1); } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ RESPONSIVE DESIGN ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ @media (max-width: 600px) { body { padding: 60px 10px 10px 10px; font-size: 13px; } h1 { font-size: 1.7em; margin-bottom: 14px; } .container { padding: 20px 16px; } .theme-toggle, .language-toggle, .exit-game, .screen-lock-toggle { top: 8px; width: 44px; height: 44px; min-width: 44px; } .language-toggle { top: 58px; } .screen-lock-toggle { top: 108px; } .exit-game { padding: 0 12px; font-size: 0.75em; height: 44px; } /* Ocultar textos en móvil, solo emojis */ .exit-text, .language-text { display: none; } .exit-game { padding: 0; width: 44px; min-width: 44px; } .language-toggle { padding: 0; width: 44px; min-width: 44px; } .exit-icon, .language-icon { font-size: 1.4em; } .timer { font-size: 2.5em; padding: 16px; } .welcome-title { font-size: 1.8em; } .role { font-size: 1.6em; padding: 10px 18px; } .word { font-size: 1.3em; padding: 12px 20px; } .form-group { margin-bottom: 10px; } .form-group.compact { margin-bottom: 8px; } button { padding: 12px 16px; margin-top: 8px; } .rule-section { padding: 12px; margin-bottom: 12px; } .rule-section h3 { font-size: 0.85em; margin-bottom: 10px; } .rule-section p { font-size: 0.8em; margin: 6px 0; } .player-name-item { padding: 10px; margin-bottom: 6px; } .player-name-item span { font-size: 0.75em; min-width: 70px; } .player-item { padding: 14px 10px; min-height: 72px; /* Altura fija también en móvil */ font-size: 0.8em; } .pool-btn { padding: 10px 8px; font-size: 0.75em; } .pool-buttons-wrapper { max-height: 240px; /* Ajustado para mostrar fila parcial en móvil - efecto peek */ padding: 10px; margin: 10px 0; } .player-names-list { max-height: 280px; /* Ajustado para mostrar fila parcial en móvil - efecto peek */ padding: 10px; } .info-text { padding: 12px 14px; font-size: 0.8em; margin: 10px 0; } .curtain { height: 240px; margin: 10px 0; } } /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ UTILITY ANIMATIONS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */ @keyframes typewriter { from { width: 0; } to { width: 100%; } } @keyframes glitch { 0% { transform: translate(0); } 20% { transform: translate(-2px, 2px); } 40% { transform: translate(-2px, -2px); } 60% { transform: translate(2px, 2px); } 80% { transform: translate(2px, -2px); } 100% { transform: translate(0); } } /* Smooth scrolling */ * { scrollbar-width: thin; scrollbar-color: var(--border-medium) transparent; } ::-webkit-scrollbar { width: 8px; height: 8px; } ::-webkit-scrollbar-track { background: transparent; } ::-webkit-scrollbar-thumb { background: var(--border-medium); border-radius: 0; } ::-webkit-scrollbar-thumb:hover { background: var(--border-heavy); }