*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-start: #0f0c29;--bg-mid: #302b63;--bg-end: #24243e;--card-bg: rgba(255, 255, 255, .06);--card-border: rgba(255, 255, 255, .1);--primary: #FF6B35;--primary-hover: #ff8555;--secondary: #6C63FF;--secondary-hover: #8580ff;--success: #2ECC71;--success-hover: #3ddb80;--danger: #E84855;--danger-hover: #ff5c68;--text: #FFFFFF;--text-muted: rgba(255, 255, 255, .55);--round-1: #4A9DFF;--round-2: #F7C948;--round-3: #E84855;--radius: 12px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0, 0, 0, .3)}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;background:linear-gradient(135deg,var(--bg-start),var(--bg-mid),var(--bg-end));color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}body,#root{min-height:100dvh}.screen{min-height:100dvh;padding:16px 16px 32px;max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.center-card{margin:auto;display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;width:100%}.logo{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-small{font-size:1.3rem;font-weight:700}.subtitle{color:var(--text-muted);font-size:1.1rem;margin-top:-8px}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius);padding:20px;width:100%;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.game-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px}.team-card{border-left:4px solid var(--secondary)}.header{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.game-code{font-size:.9rem;color:var(--text-muted);display:flex;align-items:center;gap:6px}.game-code strong{color:var(--text);font-family:monospace;font-size:1.1rem;letter-spacing:2px}.game-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.btn{border:none;border-radius:var(--radius-sm);padding:12px 24px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary),#ff8f35);color:#fff;box-shadow:0 2px 12px #ff6b354d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-hover),#ffa555);transform:translateY(-1px)}.btn-secondary{background:linear-gradient(135deg,var(--secondary),#8580ff);color:#fff}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,var(--secondary-hover),#9995ff)}.btn-success{background:linear-gradient(135deg,var(--success),#3ddb80);color:#fff;box-shadow:0 2px 12px #2ecc714d}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,var(--success-hover),#5be896);transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--card-border)}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:#ffffff4d}.btn-large{padding:16px 32px;font-size:1.1rem}.btn-full{width:100%}.btn-huge{padding:24px 48px;font-size:1.4rem;border-radius:var(--radius);width:100%}.btn-tiny{padding:4px 8px;font-size:.75rem;border-radius:6px;background:#ffffff1a;color:var(--text);border:none;cursor:pointer}.btn-tiny:hover{background:#fff3}.btn-icon,.btn-icon-danger{background:#ffffff1a;color:var(--text);border:none;border-radius:8px;width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem}.btn-icon:hover{background:#fff3}.btn-icon-danger{color:var(--danger)}.btn-icon-danger:hover{background:#e8485533}.btn-player{background:var(--card-bg);border:1px solid var(--card-border);color:var(--text);border-radius:var(--radius-sm);padding:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .2s}.btn-player:hover{border-color:var(--primary);background:#ff6b351a}.btn-row{display:flex;gap:12px;width:100%}.btn-row .btn{flex:1}.pulse-btn{animation:pulse 2s ease-in-out infinite}.form-group{width:100%;display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;font-weight:600;color:var(--text-muted);text-align:left}input[type=text]{background:#ffffff14;border:1px solid var(--card-border);border-radius:var(--radius-sm);padding:12px 16px;font-size:1rem;color:var(--text);width:100%;transition:border-color .2s}input[type=text]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #ff6b3526}input[type=text]::placeholder{color:#ffffff4d}.code-input{font-family:monospace;font-size:1.3rem;text-align:center;letter-spacing:4px;text-transform:uppercase}.inline-form{display:flex;gap:8px}.inline-form input{flex:1}.stepper{display:flex;align-items:center;gap:12px}.stepper-value{font-size:1.3rem;font-weight:700;min-width:48px;text-align:center}.player-list{display:flex;flex-direction:column;gap:8px}.player-list.horizontal{flex-direction:row;flex-wrap:wrap}.player-tag{background:#ffffff14;border-radius:8px;padding:8px 12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.player-tag.unassigned{border:1px dashed rgba(255,255,255,.2)}.badge{background:var(--primary);color:#fff;font-size:.7rem;padding:2px 8px;border-radius:12px;font-weight:600}.team-assign-btns{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap}.team-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.player-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;width:100%}.team-label{font-size:.8rem;color:var(--text-muted)}.round-badge{font-size:.85rem;font-weight:700;padding:6px 14px;border-radius:20px}.round-1{background:#4a9dff33;color:var(--round-1);border:1px solid rgba(74,157,255,.3)}.round-2{background:#f7c94833;color:var(--round-2);border:1px solid rgba(247,201,72,.3)}.round-3{background:#e8485533;color:var(--round-3);border:1px solid rgba(232,72,85,.3)}.round-reminder{font-size:.9rem;font-weight:600;padding:8px 16px;border-radius:12px}.mini-scores{display:flex;gap:8px}.mini-score{flex:1;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-sm);padding:8px 12px;display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.mini-score.my-team{border-color:var(--primary);background:#ff6b351a}.team-name{font-weight:600;font-size:.8rem}.team-score{font-weight:800;font-size:1.1rem}.papelitos-count{font-size:.9rem;color:var(--text-muted)}.game-area{flex:1;display:flex;flex-direction:column;gap:16px}.confirm-player{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px}.big-name{font-size:2rem;font-weight:800}.timer-circle{width:100px;height:100px;border-radius:50%;border:4px solid var(--success);display:flex;align-items:center;justify-content:center;transition:border-color .3s}.timer-circle.small{width:70px;height:70px}.timer-circle.timer-danger{border-color:var(--danger);animation:shake .5s ease-in-out infinite}.timer-value{font-size:2rem;font-weight:800;font-variant-numeric:tabular-nums}.timer-circle.small .timer-value{font-size:1.5rem}.papelito-display{background:#ffffff0d;border:2px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:24px;width:100%;min-height:80px;display:flex;align-items:center;justify-content:center}.papelito-text{font-size:1.6rem;font-weight:700;text-align:center;line-height:1.4;animation:fadeIn .3s ease}.turn-stats{font-size:.85rem;color:var(--text-muted)}.turn-result{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px}.result-number{font-size:4rem;font-weight:900;color:var(--success);line-height:1}.round-scores,.total-scores{width:100%}.round-score-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06)}.score{font-weight:700;color:var(--primary)}.score.big{font-size:1.3rem}.total-scores{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.1)}.countdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:100}.countdown-number{font-size:10rem;font-weight:900;color:var(--primary);animation:countPop .8s ease-out;text-shadow:0 0 60px rgba(255,107,53,.5)}.progress-bar{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;margin:8px 0}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:4px;transition:width .5s ease}.submitted-state{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px}.check-icon{font-size:3rem}.player-status-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}.player-status{display:flex;gap:8px;font-size:.9rem}.scoreboard-content{flex:1;display:flex;flex-direction:column;gap:16px;padding-top:24px}.trophy-section{text-align:center;padding:24px 0}.trophy{font-size:5rem;animation:bounce 2s ease-in-out infinite}.trophy-section h1{font-size:2rem;margin-top:8px}.winner-score{font-size:1.5rem;color:var(--primary);font-weight:700}.score-table{width:100%;border-collapse:collapse;margin-top:8px}.score-table th{font-size:.8rem;color:var(--text-muted);font-weight:600;padding:8px 4px;text-align:center}.score-table th:first-child{text-align:left}.score-table td{padding:10px 4px;text-align:center;border-top:1px solid rgba(255,255,255,.06)}.score-table td:first-child{text-align:left;font-weight:600}.total-cell{font-weight:800;color:var(--primary);font-size:1.1rem}.winner-row{background:#ff6b351a}.team-players-section{margin-bottom:12px}.team-players-section h4{font-size:.9rem;color:var(--text-muted);margin-bottom:6px}.turn-order-card{padding:12px 16px}.turn-order-list{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.turn-order-item{font-size:.8rem;padding:4px 10px;border-radius:12px;background:#ffffff0f}.turn-order-item.current{background:var(--primary);color:#fff;font-weight:700}.muted{color:var(--text-muted);font-size:.9rem}.center{text-align:center}.highlight{color:var(--primary);font-weight:700;font-size:1.1rem}.error-text{color:var(--danger);font-size:.9rem;font-weight:600;padding:8px 16px;background:#e8485526;border-radius:var(--radius-sm)}.lobby-content,.writing-content{display:flex;flex-direction:column;gap:16px}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.15);border-top:3px solid var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes countPop{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}@keyframes pulse{0%,to{box-shadow:0 2px 12px #ff6b354d}50%{box-shadow:0 4px 24px #ff6b3599}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(min-width:640px){.screen{padding:24px}.logo{font-size:3rem}.countdown-number{font-size:14rem}}
