.loading-container{display:flex;align-items:center;justify-content:center;height:100vh;width:100%;background-color:var(--background-color)}.loading-spinner{width:40px;height:40px;border:3px solid var(--background-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}:root{--primary-color: #007AFF;--background-color: #F2F2F7;--card-background: #FFFFFF;--text-primary: #000000;--text-secondary: #6C6C6C;--border-radius: 16px;--spacing: 16px;--safe-area-inset-bottom: env(safe-area-inset-bottom, 20px)}*{margin:0;padding:0;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-tap-highlight-color:transparent}body{background-color:var(--background-color);color:var(--text-primary);-webkit-font-smoothing:antialiased}.welcome-container,.setup-container,.game-container,.scores-container{height:100vh;overflow:hidden}.welcome-container{position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing);text-align:center;width:100%;padding-top:48px}.welcome-container h1{font-size:42px;margin-bottom:8px;background:linear-gradient(135deg,#007aff,#5856d6);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;transition:transform .1s ease}.welcome-container h1:active{animation:titlePulse .2s ease}.subtitle{color:var(--text-secondary);margin-bottom:24px}.primary-button,.secondary-button,.scores-button,.back-button{width:100%}.primary-button{background:var(--primary-color);color:#fff;padding:16px 32px;border:none;border-radius:var(--border-radius);font-size:17px;font-weight:600;width:100%;max-width:300px;margin-bottom:12px;cursor:pointer}.secondary-button{background:transparent;color:var(--primary-color);padding:16px 32px;border:none;font-size:17px;font-weight:600;width:100%;max-width:300px;cursor:pointer}.game-container{height:100svh;display:flex;flex-direction:column;gap:8px;padding:var(--spacing);padding-bottom:calc(var(--safe-area-inset-bottom) + var(--spacing));position:fixed;top:0;left:0;right:0;background-color:var(--background-color)}.game-header{flex:0 0 auto;display:grid;grid-template-columns:44px 1fr 44px;align-items:center;background:var(--card-background);border-radius:var(--border-radius);padding:12px 16px;margin:0 0 16px;position:sticky;z-index:10;box-shadow:0 1px #0000000d}.game-header h2{margin:0;font-size:24px;text-align:center;grid-column:2;padding:0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scores-button{grid-column:3;background:transparent;color:var(--primary-color);border:none;padding:8px;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:22px;transition:background-color .2s}.scores-button:hover{background-color:#007aff1a}.scores-button:active{opacity:.6}.header-text{display:flex;align-items:center;justify-content:center;height:44px;position:relative;perspective:400px;width:100%}.cube-wrapper{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform 3s}.cube-face{position:absolute;width:100%;height:100%;backface-visibility:hidden;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:600;background:var(--card-background)}.cube-face.back,.cube-wrapper.flipped{transform:rotateX(180deg)}.hole-number{font-weight:700;color:var(--primary-color);font-size:24px}.current-player{background:var(--card-background);padding:24px;border-radius:var(--border-radius);margin-bottom:32px;text-align:center;box-shadow:0 2px 6px #0000000d}.current-player p{color:var(--text-secondary);margin-bottom:4px}.current-player h3{font-size:24px;font-weight:700}.score-buttons{flex:1;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto;gap:8px;width:100%}.game-controls{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%;margin-bottom:8px}.control-button{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--border-radius);font-size:17px;font-weight:600;background:var(--card-background);color:var(--primary-color);cursor:pointer}.control-button:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.control-button svg{width:24px;height:24px}.score-button{border:none;border-radius:var(--border-radius);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;background:var(--card-background);padding:20px;min-height:120px;transition:transform .2s ease,opacity .2s ease}.score-button:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.score-button:active:not(:disabled){transform:scale(.98)}.score-button .points{font-size:32px;font-weight:700;margin-bottom:4px}.score-button .label{font-size:15px;color:var(--text-secondary)}.treble{color:#34c759}.double{color:#007aff}.small{color:#5856d6}.large{color:#ff9500}.miss{color:#ff3b30}.scores-container{position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden;padding:var(--spacing);width:100%}.scores-header{display:grid;grid-template-columns:44px 1fr 44px;margin:0 0 24px;box-shadow:0 1px #0000000d}.scores-header h2{margin:0;font-size:20px;text-align:center;grid-column:2}.back-button{background:transparent;border:none;font-size:24px;padding:8px 16px;margin-right:16px;cursor:pointer;width:44px;height:44px;border-radius:22px;transition:background-color .2s}.back-button:active{background-color:#007aff1a}.score-card{background:var(--card-background);padding:24px;border-radius:var(--border-radius);margin-bottom:16px;box-shadow:0 2px 6px #0000000d;width:100%;margin-left:auto;margin-right:auto;max-width:600px}.score-card h3{margin-bottom:16px}.score-details{display:flex;flex-direction:column;align-items:center}.total-score{font-size:42px;font-weight:700;color:var(--primary-color)}.score-label{color:var(--text-secondary);font-size:15px}.input-group{margin-bottom:24px;width:100%;max-width:600px;margin-left:auto;margin-right:auto}.input-group label{display:block;margin-bottom:2px;font-weight:600}.input-hint{display:block;color:var(--text-secondary);font-size:13px;margin-top:0;margin-bottom:8px}.player-input{width:100%;padding:16px;border:1px solid #E5E5EA;border-radius:var(--border-radius);font-size:17px}.setup-container{position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden;display:flex;flex-direction:column;width:100%}.setup-container h2{text-align:center;margin-bottom:32px;font-size:34px;width:100%}.rules-container{position:fixed;top:0;left:0;right:0;bottom:0;overflow-y:auto;padding:var(--spacing);display:flex;flex-direction:column;width:100%;background:var(--background)}.rules-container h2{text-align:center;margin-bottom:24px;font-size:28px;font-weight:700;width:100%}.rules-container .back-button{align-self:flex-start;margin-bottom:16px}.rules-content{background:var(--card-background);padding:24px;border-radius:var(--border-radius);margin-top:8px;width:100%;max-width:800px;margin-left:auto;margin-right:auto;box-shadow:0 2px 8px #0000000d}.rule-item{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(0,0,0,.05)}.rule-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.rule-item h3{margin-bottom:12px;font-size:20px;font-weight:600;color:var(--primary-color)}.rule-item p{color:var(--text-secondary);line-height:1.5;margin-bottom:16px}.rule-item ul,.rule-item ol{list-style-position:inside;padding-left:8px}.rule-item li{margin-bottom:12px;color:var(--text-secondary);line-height:1.5}.rule-item li:last-child{margin-bottom:0}.rule-item li strong{color:var(--text-primary);font-weight:600}@media (min-width: 768px){.rules-container h2{font-size:34px}.rules-content{padding:32px}.rule-item h3{font-size:22px}}.scores-icon{width:24px;height:24px}.scores-icon svg{width:100%;height:100%}.setup-form{flex:1;overflow-y:auto;width:100%;padding:0 var(--spacing);padding-bottom:calc(var(--safe-area-inset-bottom) + var(--spacing))}.button-container{width:100%;max-width:600px;margin:0 auto}.primary-button,.secondary-button{width:100%;max-width:100%;margin-left:auto;margin-right:auto}.home-button{grid-column:1;background:transparent;border:none;color:var(--primary-color);padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:22px;transition:background-color .2s}.home-icon{width:24px;height:24px}.score-button.miss{grid-column:1 / -1;min-height:80px}.scores-list{width:100%;max-width:600px;margin:0 auto 32px}.welcome-container .scores-list{margin-bottom:48px}.welcome-container .score-card{background:var(--card-background);padding:20px;border-radius:var(--border-radius);margin-bottom:16px;width:100%;max-width:300px;box-shadow:0 2px 6px #0000000d}.welcome-container .score-card-content{display:flex;justify-content:space-between;align-items:center}.welcome-container .score-card h3{margin:0;font-size:20px;font-weight:600}.welcome-container .score-details{display:flex;align-items:center;gap:8px}.welcome-container .score-details .total-score{font-size:24px;font-weight:700;color:var(--primary-color)}.welcome-container .score-details .score-label{color:var(--text-secondary);font-size:15px}.welcome-container .score-card:last-of-type{margin-bottom:32px}.game-container .scores-list{flex:1;overflow-y:hidden;margin-bottom:16px}.game-container .score-card{display:flex;justify-content:space-between;align-items:center;padding:16px 24px}.game-container .score-card h3{margin:0;font-size:20px}.game-container .score-details{display:flex;align-items:center;gap:8px}.game-container .button-container{padding-bottom:var(--safe-area-inset-bottom)}.winner-section{text-align:center;margin-bottom:32px}.current-player .score-details{display:flex}.final-scoreboard{background:var(--card-background);border-radius:var(--border-radius);margin:0 auto 32px;width:100%;max-width:300px;box-shadow:0 2px 6px #0000000d;overflow:hidden;overflow-y:auto;max-height:280px}.scores-container .final-scoreboard{max-height:500px}.ranking-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--background-color)}.ranking-row:last-child{border-bottom:none}.rank-and-name{display:flex;align-items:center;gap:12px}.rank{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--background-color);border-radius:12px;font-size:14px;font-weight:600;color:var(--text-secondary)}.player-name{font-size:17px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:4px}.verified-badge{display:inline-flex;margin-left:4px;vertical-align:middle;color:#007aff}.player-score{display:flex;align-items:center;gap:4px}.score-number{font-size:20px;font-weight:700;color:var(--primary-color)}.score-label{font-size:14px;color:var(--text-secondary)}.setup-form .final-scoreboard{margin:16px 0 24px;max-width:100%;max-height:228px}.setup-form .ranking-row{padding:8px 16px}.setup-form .player-input{margin-bottom:0}.setup-form button[type=submit]:disabled{cursor:not-allowed}.hole-number{color:var(--primary-color)}.setup-header{flex:0 0 auto;display:grid;grid-template-columns:44px 1fr 44px;align-items:center;background:var(--card-background);padding:16px;margin:0 0 24px;position:sticky;top:0;z-index:10;box-shadow:0 1px #0000000d}.setup-header h2{margin:0;font-size:20px;font-weight:600;text-align:center;grid-column:2}.setup-header .back-button{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--primary-color);padding:0;cursor:pointer;border-radius:22px;transition:background-color .2s;margin:0}.setup-header .back-button:active{background-color:#007aff1a}.feedback-container{position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden;display:flex;flex-direction:column;width:100%}.feedback-form{flex:1;overflow-y:auto;width:100%;padding:0 var(--spacing);padding-bottom:calc(var(--safe-area-inset-bottom) + var(--spacing))}.feedback-success{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px var(--spacing);text-align:center;overflow-y:auto}.feedback-success h3{font-size:24px;margin-bottom:16px;color:var(--primary-color)}.admin-login{height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing)}.admin-tabs{display:flex;gap:8px;margin-bottom:24px}.tab-button{flex:1;padding:12px;border:none;border-radius:var(--border-radius);background:var(--card-background);color:var(--text-secondary);cursor:pointer}.tab-button.active{background:var(--primary-color);color:#fff}.feedback-item{background:var(--card-background);padding:16px;border-radius:var(--border-radius);margin-bottom:16px}.feedback-type{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600}.feedback-type.bug{background:#ff3b30;color:#fff}.feedback-type.suggestion{background:#34c759;color:#fff}.stats-overview{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:32px}.stat-card{background:var(--card-background);padding:16px;border-radius:var(--border-radius);text-align:center;box-shadow:0 2px 6px #0000000d}.stat-card h3{font-size:14px;color:var(--text-secondary);margin-bottom:8px}.stat-card p{font-size:24px;font-weight:700;color:var(--primary-color)}.stat-card.compact{padding:10px 8px}.stat-card.compact h3{font-size:11px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.stat-card.compact p{font-size:20px}.stat-card.compact.wide{grid-column:span 2}.stat-card.compact.wide p{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.game-record{background:var(--card-background);padding:20px;border-radius:var(--border-radius);margin-bottom:16px;box-shadow:0 2px 6px #0000000d}.game-record-header{display:flex;justify-content:space-between;padding-bottom:12px;border-bottom:1px solid var(--background-color);margin-bottom:16px}.game-timestamp{display:flex;flex-direction:column;gap:2px}.game-date{font-weight:500}.game-time{font-size:13px;color:var(--text-secondary)}.game-actions{display:flex;align-items:center;gap:12px}.players-count{color:var(--text-secondary);font-size:14px}.delete-button{background:none;border:none;color:#ff3b30;font-size:16px;width:24px;height:24px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background-color .2s;margin-left:8px}.delete-button:hover{background-color:#ff3b301a}.delete-button:active{background-color:#ff3b3033}.game-record-details{display:flex;justify-content:space-between;font-weight:600}.game-results h4{margin-bottom:12px;font-size:16px;color:var(--text-secondary)}.player-results{display:flex;flex-direction:column;gap:16px}.player-result-row{background:var(--background-color);border-radius:12px;padding:12px}.player-result-header{display:flex;align-items:center;margin-bottom:8px;gap:8px}.player-position{background:var(--primary-color);color:#fff;width:24px;height:24px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.hole-scores{padding:8px 16px;background:#0000000d;margin:0 -16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:8px;max-height:200px;overflow-y:auto}.hole-score{display:flex;flex-direction:column;align-items:center;padding:4px;background:#ffffff80;border-radius:4px}.hole-number{font-size:.8em;color:#666}.score{font-weight:700}.admin-prompt-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.admin-prompt{background:var(--card-background);padding:24px;border-radius:var(--border-radius);width:90%;max-width:320px;position:relative}.admin-prompt h3{text-align:center;margin-bottom:24px;font-size:20px}.close-button{position:absolute;top:12px;right:12px;background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:16px}.close-button:hover{background:var(--background-color)}@keyframes titlePulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.feedback-name{font-weight:600;color:var(--primary-color)}.feedback-email{font-size:14px;color:var(--text-secondary);margin-bottom:8px}.admin-actions{display:flex;flex-direction:column;gap:8px;margin:24px 0}.game-history{margin-top:24px}.game-players{margin-top:8px;font-size:14px;color:var(--text-secondary)}.feedback-user{display:flex;flex-direction:column;gap:2px}.feedback-email{font-size:13px;color:var(--text-secondary)}.feedback-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px}.roadmap-screen{min-height:100vh;padding:var(--spacing)}.roadmap-list{max-width:600px;margin:0 auto}.roadmap-item{background:var(--card-background);padding:20px;border-radius:var(--border-radius);margin-bottom:16px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 6px #0000000d}.roadmap-content{flex:1}.roadmap-content h3{margin-bottom:8px;font-size:18px}.roadmap-content p{color:var(--text-secondary);font-size:14px;margin-bottom:8px}.vote-button{display:flex;flex-direction:column;align-items:center;padding:8px 16px;border:none;border-radius:var(--border-radius);background:var(--primary-color);color:#fff;cursor:pointer;margin-left:16px}.vote-button.voted{background:var(--background-color);color:var(--text-secondary);cursor:default}.vote-count{font-weight:700;font-size:18px}.vote-text{font-size:12px}.roadmap-form{max-width:600px;margin:0 auto 32px}.vote-override{display:flex;align-items:center;gap:8px;margin-top:8px}.vote-input{width:80px;padding:8px;border:1px solid #E5E5EA;border-radius:8px;font-size:14px;text-align:center}.vote-label{color:var(--text-secondary);font-size:14px}.final-results{height:100%;overflow-y:auto;padding-bottom:calc(var(--safe-area-inset-bottom) + var(--spacing))}.character-count{margin-top:8px;font-size:14px;color:var(--text-secondary)}.error-message{color:#ff3b30;margin-top:8px;font-size:14px}.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px;max-width:600px;margin:0 auto;width:100%}.admin-card{background:var(--card-background);border:none;border-radius:var(--border-radius);padding:32px;display:flex;flex-direction:column;align-items:center;gap:16px;cursor:pointer;transition:transform .2s ease,background-color .2s ease;box-shadow:0 2px 6px #0000000d}.admin-card:active{transform:scale(.98);background-color:var(--background-color)}.admin-card-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center}.admin-card-icon svg{width:32px;height:32px}.admin-card-label{font-size:17px;font-weight:600;color:var(--text-primary)}.admin-navigation{display:flex;flex-direction:column;gap:16px;padding:0 16px var(--safe-area-inset-bottom) 16px;width:100%}.admin-navigation .primary-button{margin:0}.game-summary{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.game-summary span{white-space:nowrap}.makeup-turn{color:#ff9500;font-weight:600;font-size:28px}.makeup-turn-banner{grid-column:1 / -1;background:#ff9500;color:#fff;padding:12px;border-radius:var(--border-radius);text-align:center;font-weight:600;margin-bottom:8px;position:relative;z-index:1;box-shadow:0 2px 6px #0000000d}.guest-warning-banner{display:flex;align-items:flex-start;gap:12px;background:#ff9500;color:#fff;padding:12px 16px;border-radius:var(--border-radius);margin-bottom:24px;box-shadow:0 2px 6px #ff95004d}.guest-warning-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding-top:2px}.guest-warning-icon svg{color:#fff}.guest-warning-content{flex:1}.guest-warning-content strong{display:block;font-size:15px;font-weight:600;margin-bottom:4px}.guest-warning-content p{margin:0;font-size:14px;line-height:1.4;opacity:.95}.guest-warning-continue{margin-top:12px;padding:8px 20px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:var(--border-radius);font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.guest-warning-continue:hover{background:#ffffff4d}.live-stats{background:var(--card-background);border-radius:var(--border-radius);padding:12px 16px;margin-top:16px;display:flex;flex-direction:column;align-items:center;gap:4px;box-shadow:0 1px 3px #0000001a}.live-stats-position{display:flex;align-items:baseline;gap:2px}.position-number{font-size:24px;font-weight:700;color:var(--primary-color)}.position-suffix{font-size:14px;color:var(--text-secondary);font-weight:500}.live-stats-diff{font-size:14px;color:var(--text-secondary)}.static-header{font-size:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;text-align:center}.login-container{display:flex;flex-direction:column;align-items:center;padding:24px;max-width:600px;margin:0 auto}.login-container h1{font-size:42px;margin-bottom:8px;background:linear-gradient(135deg,#007aff,#5856d6);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-info{text-align:center;margin:24px 0;max-width:300px}.login-info h2{font-size:24px;margin-bottom:12px;color:var(--text-primary)}.login-info p{color:var(--text-secondary);line-height:1.5}.login-form{width:100%;max-width:300px;display:flex;flex-direction:column;gap:24px}.phone-input-container{display:flex;align-items:center;background:var(--background-secondary);border-radius:var(--border-radius);padding:4px;margin-top:8px}.country-code{padding:8px 12px;color:var(--text-primary);font-weight:500;border-right:1px solid var(--border-color)}.phone-input{flex:1;border:none!important;background:transparent!important;padding-left:12px!important;font-size:17px!important}.phone-input:focus{outline:none!important;box-shadow:none!important}.input-hint{font-size:14px;color:var(--text-secondary);margin-top:8px}.ios-button{margin-top:12px;background:linear-gradient(135deg,#007aff,#5856d6);transition:transform .2s ease,opacity .2s ease}.ios-button:active{transform:scale(.98);opacity:.9}.welcome-message{color:var(--text-primary);font-size:18px;margin-bottom:24px;text-align:center}.login-buttons{width:100%;max-width:300px;display:flex;flex-direction:column;gap:12px;margin-top:24px}.form-buttons{display:flex;flex-direction:column;gap:12px}.otp-container{width:100%;max-width:300px;display:flex;flex-direction:column;align-items:center;gap:24px;margin-top:24px}.otp-input{width:42px;height:52px;border-radius:12px;background:var(--background-secondary);border:1px solid var(--border-color);font-size:24px;font-weight:600;color:var(--text-primary);text-align:center;caret-color:#007aff;transition:all .2s ease}.otp-input:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 2px #007aff33}.otp-input.waiting{border-color:#007aff;box-shadow:0 0 0 2px #007aff1a}.otp-inputs{display:flex;gap:12px;justify-content:center;margin-bottom:24px}.otp-input[readonly]{cursor:default}.status-message{text-align:center;color:var(--text-secondary);font-size:14px;min-height:20px;margin-top:16px}.phone-display{font-size:16px;color:var(--text-primary);font-weight:500;margin-top:4px}.status-message{color:var(--text-secondary);text-align:center;font-size:14px;min-height:20px}.status-message.verified{color:#34c759}.status-message.deleting{color:var(--text-secondary);font-style:italic}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.status-message.sending,.status-message.verifying{animation:pulse 1.5s infinite}.auth-mode-selector{width:100%;max-width:300px;display:flex;background:var(--background-secondary);border-radius:var(--border-radius);padding:4px;margin-bottom:24px}.mode-button{flex:1;padding:8px;border:none;border-radius:calc(var(--border-radius) - 2px);background:transparent;color:var(--text-secondary);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.mode-button.active{background:#fff;color:var(--text-primary);box-shadow:0 2px 4px #0000001a}.login-container.compact{padding:16px}.login-info.compact{margin:12px 0}.login-info.compact h2{margin-bottom:0}.login-form.compact{gap:12px}.input-group.compact{margin-bottom:0}.input-group.compact label{margin-bottom:4px;font-size:14px}.player-input.compact{padding:8px 12px;font-size:15px}.form-buttons.compact{margin-top:8px;gap:8px}.phone-display{color:var(--text-secondary);font-size:15px;margin-bottom:16px;text-align:center}.ios-form{padding:20px}.ios-fields{gap:32px}.ios-field-group{background:var(--background-secondary);border-radius:16px;padding:8px 0}.ios-field-group .input-group{padding:8px 16px;margin:0;border-bottom:1px solid var(--border-color)}.ios-field-group .input-group:last-child{border-bottom:none}.ios-field-group label{font-size:14px;font-weight:500;color:var(--text-secondary);margin-bottom:4px}.ios-input{border:none!important;background:transparent!important;padding:8px 0!important;font-size:17px!important;width:100%}.ios-input:focus{outline:none!important}.ios-input::placeholder{color:var(--text-secondary);opacity:.5}.search-input-container{position:relative;width:100%;display:flex;gap:8px;align-items:center}.search-input-container .player-input{flex:1;width:auto}.search-status{position:absolute;right:60px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--text-secondary);pointer-events:none}.add-player-button{flex:0 0 auto;width:44px;height:44px;border-radius:12px;background:var(--primary-color);border:none;color:#fff;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .2s ease,transform .2s ease}.add-player-button:disabled{opacity:.5;cursor:not-allowed}.add-player-button:not(:disabled):active{transform:scale(.95)}.search-results{position:absolute;top:100%;left:0;right:0;background:var(--card-background);border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-top:4px;max-height:200px;overflow-y:auto;z-index:1000}.search-result-item{display:flex;align-items:center;padding:12px 16px;cursor:pointer;transition:background-color .2s;border-bottom:1px solid var(--border-color)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background-color:var(--background-color)}.search-result-item .display-name{font-weight:600;margin-right:8px}.search-result-item .first-name{color:var(--text-secondary);font-size:14px}.turn-complete-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.turn-complete-message{background:var(--primary-color);color:#fff;padding:16px 32px;border-radius:12px;font-size:24px;font-weight:600;animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.dart-animation-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;pointer-events:none}.dart{position:absolute;width:40px;height:40px;transform-origin:center;animation:throwDart .6s cubic-bezier(.25,.46,.45,.94);filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.dart svg{width:100%;height:100%;transform:rotate(45deg)}.hit-effect{position:absolute;width:60px;height:60px;transform:translate(-50%,-50%);opacity:0;animation:hitEffect .4s ease-out forwards}@keyframes throwDart{0%{left:-80px;top:60%;transform:scale(.4) rotate(0);opacity:0}20%{opacity:1;transform:scale(.6) rotate(180deg)}to{transform:scale(1) rotate(360deg);opacity:1}}@keyframes hitEffect{0%{transform:translate(-50%,-50%) scale(.3);opacity:0}40%{opacity:1}to{transform:translate(-50%,-50%) scale(1.5);opacity:0}}.miss-dart{position:absolute;width:40px;height:40px;transform-origin:center;animation:missDartPath 1.2s cubic-bezier(.25,.46,.45,.94);filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.miss-text{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:48px;font-weight:700;color:#ff3b30;animation:missText .5s ease-out;text-shadow:2px 2px 4px rgba(0,0,0,.2);animation-delay:.7s;opacity:0;animation-fill-mode:forwards}.bounce-effect{position:absolute;width:40px;height:40px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.8) 0%,transparent 70%);transform:translate(-50%,-50%);animation:bounceEffect .3s ease-out;pointer-events:none}@keyframes missDartPath{0%{left:-80px;top:60%;transform:scale(.4) rotate(0);opacity:0}10%{opacity:1;transform:scale(.8) rotate(180deg)}25%{left:30%;top:30%;transform:scale(1) rotate(360deg)}45%{left:70%;top:60%;transform:scale(1) rotate(540deg)}65%{left:40%;top:40%;transform:scale(1) rotate(720deg)}85%{left:50%;top:50%;transform:scale(1) rotate(900deg);opacity:1}to{left:50%;top:50%;transform:scale(1) rotate(1080deg);opacity:0}}@keyframes bounceEffect{0%{transform:translate(-50%,-50%) scale(.2);opacity:1}to{transform:translate(-50%,-50%) scale(1.5);opacity:0}}@keyframes missText{0%{transform:translate(-50%,-50%) scale(.5);opacity:0}20%{transform:translate(-50%,-50%) scale(1.2);opacity:1}80%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.users-container{display:flex;gap:24px;padding:16px;height:calc(100vh - 60px);overflow:hidden}.users-list{flex:1;max-width:400px;overflow-y:auto;background:var(--card-background);border-radius:var(--border-radius);box-shadow:0 2px 6px #0000000d}.user-item{padding:16px;border-bottom:1px solid var(--background-color);cursor:pointer;transition:background-color .2s}.user-item:last-child{border-bottom:none}.user-item:hover,.user-item.selected{background-color:var(--background-color)}.user-info{margin-bottom:8px}.user-name{font-size:17px;font-weight:600;margin-bottom:4px}.user-details{font-size:14px;color:var(--text-secondary);display:flex;gap:8px}.user-meta{font-size:12px;color:var(--text-secondary)}.user-details-panel{flex:2;background:var(--card-background);border-radius:var(--border-radius);padding:24px;overflow-y:auto;box-shadow:0 2px 6px #0000000d}.user-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.user-header h3{font-size:24px;margin:0}.user-info-section,.user-stats-section{margin-bottom:32px}.user-info-section h4,.user-stats-section h4{font-size:18px;margin-bottom:16px;color:var(--text-secondary)}.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:24px}.info-item,.stat-item{display:flex;flex-direction:column;gap:4px}.info-item input{padding:8px;border:1px solid var(--background-color);border-radius:8px;font-size:16px;width:100%}.info-item input:focus{outline:none;border-color:var(--primary-color)}.recent-games .game-record{background:var(--background-color);border-radius:12px;padding:16px}.recent-games .game-header{display:flex;justify-content:space-between;margin-bottom:12px;font-size:14px;color:var(--text-secondary)}.recent-games .game-scores{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px}.user-details-screen{padding:16px;overflow-y:auto;height:calc(100vh - 60px)}.user-info-section,.user-stats-section,.user-games-section{background:var(--card-background);border-radius:var(--border-radius);padding:24px;margin-bottom:24px;box-shadow:0 2px 6px #0000000d}.user-info-section h4,.user-stats-section h4,.user-games-section h4{font-size:18px;margin-bottom:16px;color:var(--text-secondary)}.info-item,.stat-item{display:flex;flex-direction:column;gap:8px}.info-item label,.stat-item label{font-size:14px;color:var(--text-secondary)}.info-item input{padding:12px;border:1px solid var(--background-color);border-radius:8px;font-size:16px;width:100%;background:var(--background-color);color:var(--text-primary)}.info-item input:focus{outline:none;border-color:var(--primary-color);background:var(--card-background)}.recent-games{display:flex;flex-direction:column;gap:16px}.game-record{background:var(--background-color);border-radius:var(--border-radius);padding:16px}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px;color:var(--text-secondary)}.game-scores{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px}.hole-score{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:32px}.hole-number{font-size:12px;color:var(--text-secondary)}.score{font-size:16px;font-weight:600;color:var(--text-primary)}.loading-section{background:var(--card-background);border-radius:var(--border-radius);padding:24px;margin-bottom:24px;box-shadow:0 2px 6px #0000000d;display:flex;justify-content:center;align-items:center;min-height:200px}.loading-section .loading{color:var(--text-secondary);font-size:16px}.no-stats{background:var(--card-background);border-radius:var(--border-radius);padding:24px;margin-bottom:24px;box-shadow:0 2px 6px #0000000d;display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--text-secondary);font-size:16px}.sort-toggle-container{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:20px;padding:0 16px}.sort-toggle{width:51px;height:31px;background-color:#78788029;border-radius:31px;position:relative;cursor:pointer;transition:background-color .3s cubic-bezier(.4,0,.2,1)}.sort-label{font-size:15px;color:var(--text-secondary);transition:color .3s ease}.sort-label.active{color:var(--text-primary);font-weight:600}@keyframes sortMove{0%{opacity:.5;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.sort-settings-button{background:transparent;border:none;width:44px;height:44px;padding:8px;display:flex;align-items:center;justify-content:center;color:var(--primary-color);cursor:pointer;border-radius:22px;transition:background-color .2s}.sort-settings-button:active{background-color:#007aff1a}.sort-settings-button svg{width:24px;height:24px;stroke-width:2px}.sort-settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.sort-settings-modal{background:var(--card-background);border-radius:var(--border-radius);padding:24px;width:90%;max-width:320px;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.sort-settings-modal h3{text-align:center;margin:0 0 24px;font-size:20px;color:var(--text-primary)}.sort-toggle-container{display:flex;align-items:center;justify-content:center;gap:12px}.settings-button{background:transparent;border:none;width:44px;height:44px;padding:8px;display:flex;align-items:center;justify-content:center;color:var(--primary-color);cursor:pointer;border-radius:22px;transition:background-color .2s}.settings-button:active{background-color:#007aff1a}.settings-button svg{width:24px;height:24px}.settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.settings-modal{background:var(--card-background);border-radius:var(--border-radius);width:90%;max-width:320px;animation:slideUp .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.settings-header{padding:16px;border-bottom:1px solid var(--background-color);display:flex;align-items:center;justify-content:center;position:relative}.settings-header h3{margin:0;font-size:17px;font-weight:600;color:var(--text-primary)}.settings-header .close-button{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:28px;color:var(--text-secondary);width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:22px;transition:background-color .2s}.settings-header .close-button:active{background-color:var(--background-color)}.settings-section{padding:16px}.settings-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--background-color);border-radius:var(--border-radius);margin-bottom:16px}.settings-item:last-child{margin-bottom:0}.settings-item-content{flex:1;margin-right:16px}.settings-item-content h4{margin:0 0 4px;font-size:17px;font-weight:600;color:var(--text-primary)}.settings-item-content p{margin:0;font-size:13px;color:var(--text-secondary)}.settings-item-control{display:flex;align-items:center;gap:8px}.settings-value{font-size:13px;color:var(--text-secondary);min-width:70px;text-align:right}.sort-toggle{width:51px;height:31px;background-color:#78788029;border-radius:31px;position:relative;cursor:pointer;transition:background-color .3s cubic-bezier(.4,0,.2,1);flex-shrink:0}.sort-toggle.active{background-color:#34c759}.toggle-handle{width:27px;height:27px;background-color:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 3px 8px #00000026,0 1px 1px #00000029;transition:transform .3s cubic-bezier(.4,0,.2,1)}.sort-toggle.active .toggle-handle{transform:translate(20px)}.ranking-row-container{transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s ease}.ranking-row-container.sorted{animation:sortMove .3s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.feedback-screen{padding:20px;max-width:800px;margin:0 auto;height:100vh;display:flex;flex-direction:column}.feedback-options{display:flex;flex-direction:column;gap:16px;padding:20px 0}.feedback-option{display:flex;align-items:center;gap:16px;background:var(--card-background);border:none;border-radius:var(--border-radius);padding:20px;cursor:pointer;text-align:left;transition:transform .2s ease}.feedback-option:hover{transform:translateY(-2px)}.feedback-option-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--background-color);border-radius:var(--border-radius)}.feedback-option-content{flex:1}.feedback-option-content h3{margin:0 0 4px;font-size:18px;color:var(--text-primary)}.feedback-option-content p{margin:0;font-size:14px;color:var(--text-secondary)}.feedback-form{padding:20px 0}.feedback-input{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--card-background);color:var(--text-primary);font-size:16px;margin-top:8px}.feedback-input:focus{outline:none;border-color:var(--primary-color)}.feedback-success{text-align:center;padding:40px 20px}.feedback-success h3{margin:0 0 16px;color:var(--text-primary)}.feedback-success p{margin:0 0 24px;color:var(--text-secondary)}.statistics-screen{min-height:100vh;padding:var(--spacing);background-color:var(--background-color)}.statistics-header{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;background:var(--card-background);border-radius:var(--border-radius);padding:12px 16px;margin-bottom:24px;box-shadow:0 1px #0000000d}.statistics-header h2{margin:0;font-size:20px;text-align:center;grid-column:2}.menu-options{display:flex;gap:12px;margin-bottom:24px}.menu-option{flex:1;padding:16px;background:var(--card-background);border:none;border-radius:var(--border-radius);font-size:17px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.menu-option.active{background:var(--primary-color);color:#fff}.global-stats-filter{display:flex;gap:8px;margin-bottom:16px;padding:4px;background:var(--card-background);border-radius:calc(var(--border-radius) - 4px)}.filter-option{flex:1;padding:10px 16px;background:transparent;border:none;border-radius:calc(var(--border-radius) - 6px);font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.filter-option.active{background:var(--primary-color);color:#fff}.filter-option:not(.active):hover{background:#007aff1a}.stats-content{background:var(--card-background);border-radius:var(--border-radius);padding:16px;margin-bottom:16px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.stat-card{background:var(--background-color);padding:10px 8px;border-radius:var(--border-radius);text-align:center}.stat-card h3{font-size:11px;text-transform:uppercase;letter-spacing:.3px;color:var(--text-secondary);margin-bottom:8px}.stat-card p{font-size:20px;font-weight:700;color:var(--primary-color);margin:0}.stat-card h3{margin-bottom:4px}.stat-card.wide{grid-column:span 2}.stat-card.wide p{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-card.full-width{grid-column:1 / -1}.stat-card.full-width p{font-size:16px}.recent-games{margin-top:16px}.recent-games h3{font-size:18px;color:var(--text-secondary);margin-bottom:16px}.game-record{background:var(--background-color);border-radius:var(--border-radius);padding:16px;margin-bottom:16px}.game-record:last-child{margin-bottom:0}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.game-date{font-size:14px;color:var(--text-secondary)}.game-score{font-weight:600;color:var(--primary-color)}.loading-section{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--text-secondary)}.error-section{text-align:center;color:#ff3b30;padding:24px}.leaderboards{display:flex;flex-direction:column;gap:16px;margin-top:16px}.leaderboard-section{background:var(--background-color);border-radius:var(--border-radius);padding:16px}.leaderboard-section h3{font-size:15px;color:var(--text-secondary);margin:0 0 12px;text-transform:uppercase;letter-spacing:.3px}.leaderboard-section h3.collapsible-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;margin:0;padding:4px 0}.leaderboard-section h3.collapsible-header:hover{color:var(--primary-color)}.leaderboard-section .toggle-icon{font-size:18px;font-weight:700;color:var(--primary-color)}.leaderboard{display:flex;flex-direction:column;gap:8px}.leaderboard-entry{display:grid;grid-template-columns:32px 1fr auto;align-items:center;padding:10px 12px;background:var(--card-background);border-radius:var(--border-radius);gap:12px}.leaderboard-entry .rank{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:var(--primary-color);color:#fff;font-weight:600;font-size:13px;border-radius:50%}.leaderboard-entry .player-name{font-weight:500;font-size:15px;color:var(--text-primary)}.leaderboard-entry .score{font-weight:600;font-size:16px;color:var(--primary-color)}.power-button{position:absolute;top:16px;right:16px;width:44px;height:44px;border-radius:22px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s,color .2s;z-index:10}.power-button:hover{background-color:#0000000d;color:var(--text-primary)}.power-button:active{background-color:#0000001a}.beer-screen{min-height:100vh;display:flex;flex-direction:column;background-color:var(--background-color)}.beer-header{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;background:var(--card-background);padding:12px 16px;box-shadow:0 1px #0000000d}.beer-header h2{margin:0;font-size:20px;text-align:center;grid-column:2}.beer-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:32px 24px;max-width:400px;margin:0 auto}.beer-icon{font-size:80px;margin-bottom:24px}.beer-message{text-align:center;margin-bottom:32px}.beer-message p{color:var(--text-secondary);line-height:1.6;margin-bottom:16px;font-size:16px}.beer-message p:last-child{margin-bottom:0}.beer-message strong{color:var(--text-primary)}.beer-tagline{font-style:italic;color:var(--text-primary)!important}.kofi-button{background:linear-gradient(135deg,#ff5e5b,#ff9500);color:#fff;padding:16px 32px;border:none;border-radius:var(--border-radius);font-size:17px;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s;box-shadow:0 4px 12px #ff5e5b4d}.kofi-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #ff5e5b66}.kofi-button:active{transform:scale(.98);opacity:.9}.beer-bribe-note{margin-top:24px;font-size:13px;font-style:italic;color:var(--text-secondary);text-align:center}.beer-divider{width:100%;border:none;border-top:1px solid rgba(0,0,0,.1);margin:16px 0}.beer-promo-button{background:transparent;border:none;color:var(--text-secondary);font-size:14px;padding:16px;cursor:pointer;margin-top:8px;transition:color .2s}.beer-promo-button:hover{color:var(--text-primary)}
