:root{--color-bg: #0a0a0a;--color-surface: #141414;--color-serving: #1a2e1a;--color-divider: #333;--color-text: #ffffff;--color-text-muted: #888;--color-accent: #4a90d9;--color-accent-hover: #5aa0e9;--color-input-bg: #1a1a1a;--color-input-border: #333;--score-font-size: min(28vw, 180px);--sets-font-size: 22px;--name-font-size: 16px;font-family:system-ui,-apple-system,sans-serif;color:var(--color-text);background:var(--color-bg)}*{margin:0;padding:0;box-sizing:border-box}body,#root{height:100vh;height:100dvh;overflow:hidden;touch-action:manipulation;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.setup-screen{height:100dvh;overflow-y:auto;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 20px 40px}.setup-title{font-size:24px;margin-bottom:4px;font-weight:600}.setup-form{width:100%;max-width:min(600px,90vw);display:flex;flex-direction:column;gap:20px}.setup-col{display:contents}@media(orientation:landscape){.setup-form{max-width:min(900px,94vw);display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;column-gap:32px;row-gap:20px}.setup-col{display:flex;flex-direction:column;gap:20px}.setup-title{grid-column:1 / -1;grid-row:1;margin-bottom:0}.setup-col--left{grid-column:1;grid-row:2}.setup-col--right{grid-column:2;grid-row:2}.start-button{grid-column:1 / -1;grid-row:3;margin-top:0}}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;color:var(--color-text-muted)}.form-group input,.form-group select{background:var(--color-input-bg);border:1px solid var(--color-input-border);border-radius:8px;padding:10px 12px;color:var(--color-text);font-size:16px;font-family:inherit;outline:none}.form-group input:focus,.form-group select:focus{border-color:var(--color-accent)}.form-row{display:flex;gap:12px;align-items:flex-end}.toggle-group{display:flex;gap:0;border-radius:8px;overflow:hidden;border:1px solid var(--color-input-border)}.toggle-group button{flex:1;padding:10px 16px;background:var(--color-input-bg);color:var(--color-text-muted);border:none;font-size:14px;font-family:inherit;cursor:pointer;transition:background .2s,color .2s}.toggle-group button.active{background:var(--color-accent);color:#fff}.start-button{margin-top:12px;padding:14px;background:var(--color-accent);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s}.start-button:hover{background:var(--color-accent-hover)}.player-input-row{display:flex;gap:8px;align-items:center}.player-input-row input[type=text]{flex:1;min-width:0}.player-score-stepper{display:flex;align-items:center;border:1px solid var(--color-input-border);border-radius:8px;overflow:hidden;flex-shrink:0}.player-score-stepper button{width:32px;height:100%;padding:10px 0;background:var(--color-input-bg);border:none;color:var(--color-text);font-size:16px;cursor:pointer;font-family:inherit}.player-score-stepper input[type=number]{width:44px;padding:10px 4px;text-align:center;border:none;border-left:1px solid var(--color-input-border);border-right:1px solid var(--color-input-border);border-radius:0;background:var(--color-input-bg)}.score-half{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:background-color .3s;background:var(--color-bg)}.score-half--serving{background:var(--color-serving)}.score-half__score{font-size:var(--score-font-size);font-weight:700;line-height:1;font-variant-numeric:tabular-nums}.score-half__name{position:absolute;bottom:24px;font-size:var(--name-font-size);color:var(--color-text-muted);text-align:center;max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:6px}.paddle-icon{flex-shrink:0;color:var(--color-accent)}.score-half__start-score{font-size:.8em;opacity:.6}.correction-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.correction-modal{background:#1a1a1a;border-radius:16px;padding:24px;width:90%;max-width:340px;display:flex;flex-direction:column;gap:16px}.correction-modal h3{font-size:18px;font-weight:600;text-align:center}.correction-toggle{display:flex;align-items:center;gap:12px;cursor:pointer;padding:8px 0}.correction-toggle span{font-size:14px;color:var(--color-text-muted)}.correction-toggle__switch{width:44px;height:24px;background:#333;border-radius:12px;position:relative;transition:background .2s;flex-shrink:0}.correction-toggle__switch.active{background:var(--color-accent)}.correction-toggle__thumb{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .2s}.correction-toggle__switch.active .correction-toggle__thumb{transform:translate(20px)}.correction-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.correction-grid__btn{padding:14px 0;background:var(--color-input-bg);border:1px solid var(--color-input-border);border-radius:8px;color:var(--color-text);font-size:18px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s}.correction-grid__btn:active{background:var(--color-accent)}.correction-cancel{padding:14px;background:transparent;border:1px solid var(--color-input-border);border-radius:8px;color:var(--color-text-muted);font-size:16px;font-family:inherit;cursor:pointer}.settings-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.settings-modal{background:#1a1a1a;border-radius:16px;width:90%;max-width:360px;overflow:hidden}.settings-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--color-input-border)}.settings-modal__header h3{font-size:18px;font-weight:600}.settings-modal__close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:2px;display:flex}.settings-modal__body{padding:8px 0}.settings-row{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;gap:12px}.settings-row__label{font-size:14px;color:var(--color-text-muted);flex-shrink:0}.settings-row__value{font-size:14px;text-align:right}.settings-modal__actions{display:flex;flex-direction:column;gap:8px;padding:16px 20px 20px;border-top:1px solid var(--color-input-border)}.settings-modal__close-btn{padding:12px;background:transparent;border:1px solid var(--color-input-border);border-radius:8px;color:var(--color-text-muted);font-size:15px;font-family:inherit;cursor:pointer}.settings-modal__quit-btn{padding:12px;background:#5a1a1a;border:none;border-radius:8px;color:#ff8080;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s}.settings-modal__quit-btn:hover{background:#6a2020}.setwon-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:90}.setwon-modal{background:#1a1a1a;border-radius:16px;padding:32px 28px;width:90%;max-width:340px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.setwon-modal__winner{font-size:16px;color:var(--color-text-muted);display:flex;flex-direction:column;gap:6px}.setwon-modal__winner span{font-size:26px;font-weight:700;color:var(--color-text)}.setwon-modal__server{font-size:15px;color:var(--color-accent);padding:8px 0}.setwon-modal__btn{margin-top:8px;width:100%;padding:14px;background:var(--color-accent);border:none;border-radius:8px;color:#fff;font-size:16px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s}.setwon-modal__btn:hover{background:var(--color-accent-hover)}.match-screen{display:flex;height:100dvh;position:relative}.match-screen__fullscreen{position:absolute;top:12px;left:12px;z-index:10;background:none;border:none;color:var(--color-text-muted);opacity:.4;cursor:pointer;padding:4px}.match-screen__settings{position:absolute;top:12px;right:12px;z-index:10;background:none;border:none;color:var(--color-text-muted);opacity:.4;cursor:pointer;padding:4px}.match-screen__sets{position:absolute;top:14px;left:50%;transform:translate(-50%);display:flex;gap:20px;z-index:10;font-size:var(--sets-font-size);font-weight:600}.match-screen__sets-left,.match-screen__sets-right{color:var(--color-text-muted)}.match-screen__divider{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--color-divider);z-index:5}.match-screen__winner-overlay{position:absolute;inset:0;background:#000000d9;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:50;gap:16px}.match-screen__winner-text{font-size:32px;font-weight:700}.match-screen__winner-score{font-size:48px;font-weight:300;color:var(--color-text-muted)}.app{height:100dvh;overflow:hidden}
