*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:#1a1a2e;color:#eee;touch-action:manipulation}#setup-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100dvh;padding:1rem;gap:1.5rem}#setup-screen h1{font-size:1.6rem;color:#e94560}.team-block{width:100%;max-width:400px}.team-name-input{font-size:1rem;font-weight:700;color:#0f3460;background:#e94560;padding:.3rem .8rem;border-radius:6px;border:none;text-align:center}.team-name-input::placeholder{color:#0f3460;opacity:.7}.team-block input{width:100%;padding:.8rem;margin-bottom:.5rem;border:2px solid #0f3460;border-radius:8px;background:#16213e;color:#eee;font-size:1.1rem}#start-btn,#history-btn,#continue-btn{padding:1rem 3rem;font-size:1.3rem;font-weight:700;background:#e94560;color:#fff;border:none;border-radius:12px;cursor:pointer}#continue-btn{background:#1b6b3a}#history-btn{background:#0f3460;font-size:1rem;padding:.7rem 2rem}#history-screen{display:none;flex-direction:column;align-items:center;height:100dvh;padding:1rem;gap:1rem;overflow-y:auto}#history-screen h1{font-size:1.6rem;color:#e94560}#history-list{width:100%;max-width:500px;display:flex;flex-direction:column;gap:.8rem}.history-card{background:#16213e;border:1px solid #0f3460;border-radius:10px;padding:.8rem 1rem;cursor:pointer}.history-card:active{opacity:.7}.history-date{font-size:.8rem;color:#888;margin-bottom:.3rem}.history-teams{font-size:1.1rem;font-weight:700;color:#e94560;margin-bottom:.4rem}.history-results{display:flex;flex-direction:column;gap:.2rem;font-size:.85rem}.history-results span{color:#ccc}#history-back{padding:.7rem 2rem;font-size:1rem;font-weight:600;background:#e94560;color:#fff;border:none;border-radius:8px;cursor:pointer;margin-top:.5rem}.history-empty{text-align:center;color:#888;font-size:1rem;padding:2rem}#scorer-screen{display:none;height:100dvh;flex-direction:column}.header{background:#16213e;padding:.2rem .4rem;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;border-bottom:2px solid #0f3460}.match-status{display:flex;gap:.5rem;font-size:.95rem;width:100%}.match-individuals{display:flex;flex-direction:column;gap:.5rem;flex:1}.match-badge{padding:.8rem 1.4rem;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;user-select:none;-webkit-tap-highlight-color:transparent;text-align:center}.match-badge:active{opacity:.7}.badge-individual{background:#533483;flex:1}.badge-fourball{background:#0f3460;width:20%;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.match-badge.badge-up{background:#1b6b3a}.match-badge.badge-down{background:#b71c1c}.hole-nav{display:flex;align-items:center;justify-content:space-between;padding:.2rem .3rem;background:#0f3460;flex-shrink:0}.hole-nav button{width:56px;height:40px;font-size:1.4rem;font-weight:700;background:#533483;color:#fff;border:none;border-radius:8px;cursor:pointer}.hole-nav button:disabled{opacity:.3}.hole-label{font-size:1.3rem;font-weight:700;color:#e94560}.hole-dots{display:flex;justify-content:center;gap:3px;padding:.2rem .3rem;background:#16213e;flex-shrink:0}.hole-dot{width:12px;height:12px;border-radius:50%;background:#333;border:1px solid #555;cursor:pointer}.hole-dot.filled{background:#4ecca3;border-color:#4ecca3}.hole-dot.active{border:2px solid #e94560;width:16px;height:16px}.players-area{flex:1;display:flex;flex-direction:column}.player-row{flex:1;padding:4px;border-bottom:1px solid #0f3460}.player-row:nth-child(2){border-bottom:3px solid #e94560}.player-name{font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.team-color-1{color:#4ecca3}.team-color-2{color:#f0c040}.score-buttons{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:2px;width:100%;height:calc(100% - 22px)}.score-btn{font-size:clamp(1.2rem,5vw,2rem);font-weight:700;background:#16213e;color:#888;border:2px solid #0f3460;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-tap-highlight-color:transparent}.score-btn.selected{background:#4ecca3;color:#000;border-color:#4ecca3}.score-btn.other-btn{background:#16213e;color:#888;border-color:#0f3460}.score-btn.other-btn.selected{background:#4ecca3;color:#000;border-color:#4ecca3}.score-btn:active{transform:scale(.95)}.other-overlay{display:none;position:fixed;inset:0;background:#000000f2;z-index:50;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:1rem}.other-overlay.visible{display:flex}.other-overlay-title{font-size:1.1rem;font-weight:700;color:#e94560;margin-bottom:8px}.other-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:320px}.other-grid-btn{padding:1.2rem;font-size:1.3rem;font-weight:700;background:#16213e;color:#888;border:2px solid #0f3460;border-radius:10px;cursor:pointer;text-align:center;user-select:none}.other-grid-btn.selected{background:#4ecca3;color:#000;border-color:#4ecca3}.other-grid-btn.pickup{background:#c0392b;color:#fff;border-color:#c0392b}.other-grid-btn.pickup.selected{background:#e74c3c;color:#fff;border-color:#fff}.other-cancel{margin-top:12px;padding:.8rem 2rem;font-size:1rem;font-weight:700;background:#e94560;color:#fff;border:none;border-radius:8px;cursor:pointer}#scorecard-overlay{display:none;position:fixed;inset:0;background:#1a1a2e;z-index:100;flex-direction:column;overflow-y:auto;padding:1rem}#scorecard-overlay.visible{display:flex}#scorecard-overlay h2{text-align:center;color:#e94560;margin-bottom:.5rem}.scorecard-table{width:100%;border-collapse:collapse;font-size:.75rem;margin-bottom:1rem}.scorecard-table th,.scorecard-table td{border:1px solid #333;padding:.25rem .3rem;text-align:center}.scorecard-table th{background:#0f3460;color:#eee}.scorecard-table td{background:#16213e}.scorecard-table .won-hole{background:#1b4332;color:#4ecca3;font-weight:700}.scorecard-table .lost-hole{background:#3d0000;color:#e94560}.scorecard-table .halved-hole{background:#333}.final-result{text-align:center;font-size:1.3rem;font-weight:700;padding:.6rem;margin-top:.5rem;border-radius:6px}.final-result.won-hole{background:#1b6b3a;color:#fff}.final-result.lost-hole{background:#b71c1c;color:#fff}.final-result.halved-hole{background:#333;color:#ccc}#close-scorecard{align-self:center;padding:.6rem 2rem;font-size:1rem;background:#e94560;color:#fff;border:none;border-radius:8px;cursor:pointer;margin-top:.5rem}.back-home-bar{padding:.4rem;flex-shrink:0}.back-home-link{display:block;width:100%;padding:.8rem;font-size:1.1rem;font-weight:600;color:#ccc;background:#16213e;border:1px solid #0f3460;border-radius:8px;text-align:center;cursor:pointer}@media(min-width:500px){.score-btn{font-size:2rem}.player-name{font-size:.9rem}.player-row{padding:3px 6px}.score-buttons{gap:3px}}@media(max-height:500px){.header{padding:1px 4px}.match-status{font-size:.7rem}.hole-nav{padding:1px 3px}.hole-nav button{height:32px;width:48px;font-size:1.1rem}.hole-label{font-size:1rem}.hole-dots{padding:1px 3px;gap:2px}.hole-dot{width:10px;height:10px}}
