@import "https://fonts.googleapis.com/css2?family=Righteous&family=Josefin+Sans:wght@400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--navy:#073b4c;--teal:#4bb5c1;--teal-dark:#3a9ba6;--teal-light:#6ed3de;--yellow:#ffd166;--yellow-dim:#e5b94a;--red:#ef476f;--red-dim:#d1385b;--cream:#fdf9f1;--cream-dim:#f2eada;--green:#06d6a0;--green-alert:#82d647;--blue:#118ab2;--text-primary:var(--navy);--text-dim:#4b6e7d;--card-bg:var(--cream);--card-shadow:3px 3px 0px var(--navy);--card-shadow-hover:5px 5px 0px var(--navy);--radius:8px;--radius-sm:4px;--border-thick:3px solid var(--navy);--border-thin:2px solid var(--navy);--font-heading:"Righteous", "Impact", sans-serif;--font-body:"Josefin Sans", "Century Gothic", "Futura", sans-serif}html,body,#root{background:var(--teal);height:100%;color:var(--text-primary);font-family:var(--font-body)}.app{background:var(--teal);background-image:radial-gradient(var(--teal-light) 2px, transparent 2px);background-size:24px 24px;min-height:100vh;padding:0 0 80px}.header{background:var(--cream);border-bottom:var(--border-thick);z-index:100;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0;box-shadow:0 4px #073b4c1a}.logo{align-items:baseline;gap:8px;display:flex}.logo-text{font-family:var(--font-heading);color:var(--navy);text-transform:uppercase;letter-spacing:1px;text-shadow:2px 2px 0px var(--yellow);font-size:24px}.logo-badge{background:var(--red);color:#fff;border:2px solid var(--navy);text-transform:uppercase;box-shadow:1px 1px 0 var(--navy);border-radius:20px;padding:2px 8px;font-size:11px;font-weight:700}.header-right{align-items:center;gap:12px;display:flex}.round-indicator{font-family:var(--font-heading);color:var(--navy);background:var(--yellow);border:2px solid var(--navy);box-shadow:2px 2px 0 var(--navy);border-radius:20px;padding:4px 10px;font-size:14px}.view-toggle{background:var(--cream-dim);border:var(--border-thin);border-radius:20px;gap:2px;padding:2px;display:flex;box-shadow:inset 1px 1px 3px #0000001a}.toggle-btn{font-family:var(--font-heading);color:var(--text-dim);cursor:pointer;background:0 0;border:2px solid #0000;border-radius:16px;padding:4px 12px;font-size:13px;transition:all .2s}.toggle-btn.active{background:var(--yellow);color:var(--navy);border:2px solid var(--navy);box-shadow:2px 2px 0 var(--navy);transform:scale(1.05)}.share-banner{background:var(--yellow);border-bottom:var(--border-thick);justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex}.share-info{flex-direction:column;flex:1;justify-content:center;display:flex}.share-label{color:var(--navy);text-transform:uppercase;opacity:.8;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:700;line-height:1}.share-code{font-family:var(--font-heading);color:var(--navy);letter-spacing:2px;text-shadow:1px 1px 0 var(--cream);font-size:24px;line-height:1}.share-copy{background:var(--cream);border:var(--border-thin);border-radius:var(--radius-sm);color:var(--navy);cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font-heading);text-transform:uppercase;box-shadow:2px 2px 0 var(--navy);padding:6px 12px;transition:all .2s}.share-copy:hover{box-shadow:3px 3px 0 var(--navy);transform:translate(-1px,-1px)}.share-copy:active{box-shadow:1px 1px 0 var(--navy);transform:translate(1px,1px)}.setup-screen{max-width:460px;margin:0 auto;padding:32px 20px}.setup-title{font-family:var(--font-heading);color:var(--yellow);text-align:center;text-shadow:4px 4px 0 var(--navy), 8px 8px 0 #073b4c33;letter-spacing:2px;margin-bottom:0;font-size:64px;line-height:1}.setup-sub{text-align:center;color:var(--navy);text-transform:uppercase;background:var(--cream);border:var(--border-thin);box-shadow:2px 2px 0 var(--navy);border-radius:20px;margin-bottom:32px;margin-left:50%;padding:4px 12px;font-size:18px;font-weight:700;display:inline-block;transform:rotate(-2deg)translate(-50%)}.setup-tabs{gap:8px;margin-bottom:24px;display:flex}.setup-tab{background:var(--cream);border:var(--border-thick);border-radius:var(--radius);font-family:var(--font-heading);color:var(--navy);cursor:pointer;box-shadow:var(--card-shadow);text-transform:uppercase;flex:1;padding:12px;font-size:16px;transition:all .2s}.setup-tab.active{background:var(--yellow);box-shadow:var(--card-shadow-hover);transform:translate(-2px,-2px)}.player-list{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.player-input-row{background:var(--cream);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--card-shadow);align-items:center;gap:10px;padding:8px 12px 8px 16px;transition:transform .2s;display:flex}.player-input-row:focus-within{box-shadow:var(--card-shadow-hover);transform:translate(-2px,-2px)}.player-num{font-family:var(--font-heading);color:var(--teal);width:24px;text-shadow:1px 1px 0 var(--navy);flex-shrink:0;font-size:18px}.player-input{color:var(--navy);font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1;padding:6px 0;font-size:18px;font-weight:700}.player-input::placeholder{color:var(--text-dim);opacity:.5;font-weight:500}.btn-icon{background:var(--red);border:2px solid var(--navy);cursor:pointer;color:#fff;width:28px;height:28px;box-shadow:1px 1px 0 var(--navy);border-radius:50%;justify-content:center;align-items:center;padding-bottom:2px;font-size:18px;font-weight:700;transition:all .15s;display:flex}.btn-icon:hover{transform:scale(1.1)}.btn-icon:active{box-shadow:0 0 0 var(--navy);transform:scale(.95)}.btn-add{border:3px dashed var(--navy);border-radius:var(--radius);width:100%;color:var(--navy);font-family:var(--font-heading);cursor:pointer;text-transform:uppercase;background:0 0;margin-bottom:28px;padding:14px;font-size:16px;transition:all .2s}.btn-add:hover{background:#fff3}.btn-primary{background:var(--red);border:var(--border-thick);border-radius:var(--radius);color:#fff;width:100%;font-family:var(--font-heading);cursor:pointer;box-shadow:var(--card-shadow);text-transform:uppercase;letter-spacing:1px;text-shadow:1px 1px 0 var(--navy);padding:18px;font-size:20px;transition:all .2s}.btn-primary:hover{box-shadow:var(--card-shadow-hover);background:var(--red-bright);transform:translate(-2px,-2px)}.btn-primary:active{box-shadow:1px 1px 0 var(--navy);transform:translate(1px,1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;border-color:var(--text-dim);background:var(--text-dim);transform:none}.join-input-wrap{margin-bottom:20px}.join-input{background:var(--cream);border:var(--border-thick);border-radius:var(--radius);width:100%;color:var(--navy);font-family:var(--font-heading);text-align:center;letter-spacing:4px;box-shadow:var(--card-shadow);text-transform:uppercase;outline:none;padding:16px;font-size:28px;transition:transform .2s}.join-input:focus{box-shadow:var(--card-shadow-hover);transform:translate(-2px,-2px)}.join-input::placeholder{color:var(--text-dim);letter-spacing:2px;font-size:20px;font-family:var(--font-body);font-weight:600}.error-msg{text-align:center;background:var(--cream);color:var(--red);border:2px solid var(--red);border-radius:var(--radius-sm);box-shadow:2px 2px 0 var(--red);margin-top:16px;padding:8px;font-size:14px;font-weight:700}.leaderboard-full{flex-direction:column;gap:14px;padding:20px 16px 0;display:flex}.lb-row{background:var(--cream);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--card-shadow);align-items:center;gap:16px;padding:16px 20px;display:flex;position:relative;overflow:hidden}.lb-rank-num{font-family:var(--font-heading);color:var(--teal);text-align:center;flex-shrink:0;width:32px;font-size:24px}.lb-rank-num.gold{color:var(--red);font-size:32px;transform:rotate(-5deg)}.near-win .lb-rank-num{color:var(--navy)}.lb-player-name{color:var(--navy);white-space:nowrap;text-overflow:ellipsis;text-transform:uppercase;flex:1;font-size:22px;font-weight:700;overflow:hidden}.lb-scores{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.lb-locked-score{font-family:var(--font-heading);color:var(--navy);text-shadow:2px 2px #0000001a;font-size:36px;line-height:1}.lb-wip-line{font-family:var(--font-heading);background:var(--cream-dim);border:1px solid var(--navy);border-radius:12px;align-items:center;gap:6px;height:18px;margin-top:4px;padding:2px 8px;font-size:14px;display:flex}.lb-wip-line .wip-delta{color:var(--red)}.lb-wip-line .wip-arrow{color:var(--navy);opacity:.5}.lb-wip-line .wip-total{color:var(--navy)}.game-screen{padding:16px 12px 0}.leaderboard-strip{scrollbar-width:none;gap:12px;margin-top:-8px;padding:12px 4px 16px;display:flex;overflow-x:auto}.leaderboard-strip::-webkit-scrollbar{display:none}.leader-card{background:var(--cream);border:var(--border-thick);border-radius:var(--radius);text-align:center;min-width:90px;box-shadow:var(--card-shadow);flex-shrink:0;padding:12px 16px;position:relative}.leader-card.rank-1{box-shadow:var(--card-shadow-hover);transform:translateY(-4px)}.leader-rank{font-family:var(--font-heading);color:var(--navy);opacity:.7;margin-bottom:2px;font-size:12px}.leader-name{color:var(--navy);white-space:nowrap;text-overflow:ellipsis;text-transform:uppercase;max-width:80px;margin-bottom:4px;font-size:14px;font-weight:700;overflow:hidden}.leader-score{font-family:var(--font-heading);color:var(--navy);font-size:28px;line-height:1}.leader-score-wip{font-family:var(--font-heading);color:var(--red);border:1px solid var(--navy);background:#ffffff80;border-radius:10px;margin-top:4px;padding:2px 6px;font-size:13px}.round-section{background:var(--cream);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--card-shadow);margin:0 0 20px;overflow:hidden}.round-header{background:var(--navy);border-bottom:var(--border-thick);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.round-label{font-family:var(--font-heading);color:var(--yellow);text-transform:uppercase;letter-spacing:1px;font-size:18px}.btn-end-round{background:var(--red);border:2px solid var(--cream);border-radius:var(--radius-sm);color:#fff;font-family:var(--font-heading);cursor:pointer;text-transform:uppercase;padding:6px 12px;font-size:13px;transition:transform .2s;box-shadow:2px 2px #00000080}.btn-end-round:hover{transform:translate(-1px,-1px);box-shadow:3px 3px #00000080}.entry-list{background:var(--cream);flex-direction:column;display:flex}.entry-row{border-bottom:2px dashed #073b4c26;align-items:center;gap:16px;padding:12px 16px;display:flex}.entry-row:last-child{border-bottom:none}.entry-left{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.entry-player-name{color:var(--navy);white-space:nowrap;text-overflow:ellipsis;text-transform:uppercase;font-size:18px;font-weight:700;overflow:hidden}.entry-sub{font-family:var(--font-heading);color:var(--text-dim);min-height:18px;font-size:14px}.entry-sub .wip-highlight{color:var(--red)}.entry-input{background:var(--cream-dim);border:var(--border-thin);border-radius:var(--radius-sm);width:84px;color:var(--navy);font-family:var(--font-heading);text-align:center;-moz-appearance:textfield;outline:none;flex-shrink:0;padding:8px;font-size:24px;transition:all .15s;box-shadow:inset 2px 2px #0000000d}.entry-input::-webkit-outer-spin-button{-webkit-appearance:none}.entry-input::-webkit-inner-spin-button{-webkit-appearance:none}.entry-input:focus{box-shadow:2px 2px 0 var(--navy);border-color:var(--navy);z-index:2;background:#fff;position:relative;transform:scale(1.05)}.entry-input-readonly{width:84px;font-family:var(--font-heading);color:var(--navy);text-align:center;background:var(--cream-dim);border-radius:var(--radius-sm);border:var(--border-thin);opacity:.7;flex-shrink:0;padding:8px;font-size:24px}.history-title{font-family:var(--font-heading);color:var(--navy);text-transform:uppercase;letter-spacing:1px;text-shadow:1px 1px #ffffff80;padding:8px 4px;font-size:16px}.history-table{background:var(--cream);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--card-shadow);margin-bottom:20px;overflow:hidden}.history-row{border-bottom:2px solid var(--navy);display:grid}.history-row:last-child{border-bottom:none}.history-row.header-row{background:var(--navy);border-bottom:var(--border-thick)}.history-row.total-highlight{background:var(--yellow);border-top:var(--border-thick)}.history-cell{font-family:var(--font-heading);text-align:center;color:var(--navy);border-right:2px solid #073b4c1a;padding:10px 8px;font-size:16px}.history-cell:last-child{border-right:none}.history-cell.round-col{text-align:left;color:var(--text-dim);border-right:var(--border-thin);background:var(--cream-dim);padding-left:14px;font-size:14px}.history-row.header-row .history-cell.round-col{background:var(--navy);color:var(--yellow);border-right-color:var(--navy)}.history-cell.header{background:var(--navy);color:var(--cream);text-transform:uppercase;letter-spacing:.5px;border-right-color:#ffffff1a;font-size:12px}.history-cell.total-row{color:var(--navy);font-size:20px}.history-row.total-highlight .history-cell.round-col{color:var(--navy);border-right-color:var(--navy);background:0 0;font-size:16px}.editable-score{color:inherit;font:inherit;text-align:center;cursor:pointer;-moz-appearance:textfield;background:0 0;border:2px solid #0000;border-radius:4px;width:100%;padding:4px;transition:all .15s}.editable-score::-webkit-outer-spin-button{-webkit-appearance:none}.editable-score::-webkit-inner-spin-button{-webkit-appearance:none}.editable-score:focus{border-color:var(--navy);background:#fff;outline:none;box-shadow:2px 2px #073b4c33}.editable-score:hover{border-color:#073b4c4d}.empty-history{text-align:center;color:var(--navy);border-radius:var(--radius);border:2px dashed var(--navy);background:#fff6;padding:32px;font-size:16px;font-weight:700}.action-bar{background:var(--cream);border-top:var(--border-thick);z-index:100;gap:12px;padding:16px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px #073b4c1a}.btn-secondary{background:var(--cream-dim);border:var(--border-thick);border-radius:var(--radius-sm);color:var(--navy);font-family:var(--font-heading);cursor:pointer;text-transform:uppercase;box-shadow:2px 2px 0 var(--navy);flex:1;padding:14px;font-size:16px;transition:all .2s}.btn-secondary:hover{box-shadow:3px 3px 0 var(--navy);background:#fff;transform:translate(-1px,-1px)}.btn-secondary:active{box-shadow:1px 1px 0 var(--navy);transform:translate(1px,1px)}.btn-danger{background:var(--red)!important;color:#fff!important}.btn-danger:hover{background:var(--red-dim)!important}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#073b4ccc;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--cream);border:var(--border-thick);border-radius:var(--radius);width:100%;max-width:400px;box-shadow:8px 8px 0 var(--navy);padding:24px 20px 32px;animation:.3s cubic-bezier(.175,.885,.32,1.275) popIn}@keyframes popIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-title{font-family:var(--font-heading);color:var(--red);text-transform:uppercase;text-shadow:1px 1px 0 var(--navy);text-align:center;margin-bottom:8px;font-size:28px}.modal-sub{color:var(--navy);text-align:center;margin-bottom:24px;font-size:16px;font-weight:600;line-height:1.5}.modal-actions{gap:12px;margin-top:24px;display:flex}.lb-row.near-win,.leader-card.near-win{background:var(--green-alert)!important}.entry-row.near-win{outline-offset:-3px;z-index:10;position:relative;outline:3px solid var(--green-alert)!important;background:#82d64740!important;border-bottom-color:#0000!important;border-radius:0!important}.loading-state{color:var(--navy);font-family:var(--font-heading);text-transform:uppercase;letter-spacing:1px;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem 0;font-size:18px;display:flex}.spinner{border:3px solid var(--surface-2);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.setup-tab.disabled{opacity:.45;cursor:not-allowed;background:var(--cream-dim);color:var(--text-dim);box-shadow:none}.setup-tab.disabled:hover{box-shadow:none;transform:none}.join-unavailable{text-align:center;background:var(--cream);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--card-shadow);color:var(--navy);padding:32px 16px;font-size:16px;font-weight:700}.join-unavailable-sub{color:var(--text-dim);margin-top:8px;font-size:13px;font-weight:500}.share-prompt{padding:8px 16px;display:flex}.btn-share-game{background:var(--yellow);border:var(--border-thick);border-radius:var(--radius);font-family:var(--font-heading);color:var(--navy);cursor:pointer;text-transform:uppercase;letter-spacing:.5px;box-shadow:var(--card-shadow);flex:1;padding:12px 16px;font-size:16px;transition:all .2s}.btn-share-game:hover{box-shadow:var(--card-shadow-hover);transform:translate(-2px,-2px)}.btn-share-game:active{box-shadow:1px 1px 0 var(--navy);transform:translate(1px,1px)}.btn-share-game:disabled{opacity:.6;cursor:not-allowed;transform:none}
