: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__sets{position:absolute;top:14px;font-size:var(--sets-font-size);font-weight:600;color:var(--color-text-muted)}.score-half--left .score-half__sets{right:14px}.score-half--right .score-half__sets{left:14px}@media(orientation:portrait){.score-half--left .score-half__sets{top:auto;bottom:14px;right:14px}.score-half--right .score-half__sets{left:auto;right:14px}}.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:20px;font-weight:700;color:var(--color-text);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:row;gap:8px;padding:16px 20px 20px;border-top:1px solid var(--color-input-border)}.settings-modal__close-btn{flex:1;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{flex:1;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}.history-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.history-modal{background:#1a1a1a;border-radius:16px;width:90%;max-width:360px;max-height:80dvh;display:flex;flex-direction:column;overflow:hidden}.history-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--color-input-border);flex-shrink:0}.history-modal__header h3{font-size:18px;font-weight:600}.history-modal__close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:2px;display:flex}.history-modal__body{overflow-y:auto;flex:1;padding:0 0 12px}.history-names{position:sticky;top:0;background:#1a1a1a;display:flex;justify-content:space-between;gap:8px;padding:12px 20px 10px;border-bottom:1px solid var(--color-input-border)}.history-names__name{font-size:13px;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:45%}.history-names__name--right{text-align:right}.history-set{padding:12px 20px 16px}.history-set+.history-set{border-top:1px solid var(--color-input-border)}.history-set__title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:6px}.history-set__empty{font-size:13px;color:var(--color-text-muted);font-style:italic}.history-set__rows{display:flex;flex-direction:column;gap:2px}.history-point{display:flex;align-items:center;gap:6px;padding:3px 0;font-size:14px;font-variant-numeric:tabular-nums}.history-point--0{justify-content:flex-start}.history-point--1{justify-content:flex-end}.history-point__score{width:24px;text-align:center;color:var(--color-text-muted)}.history-point__score--active{color:var(--color-text);font-weight:600}.history-point__dash{color:var(--color-text-muted)}.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__set-score{font-size:36px;font-weight:300;color:var(--color-text);letter-spacing:2px}.setwon-modal__sets-stand{font-size:15px;color:var(--color-text-muted)}.setwon-modal__btn{margin-top:8px;width:100%;padding:14px;background:var(--color-accent);border:none;border-radius:8px;color:#fff;font-family:inherit;cursor:pointer;transition:background .2s;display:flex;flex-direction:column;align-items:center;gap:4px}.setwon-modal__btn:hover{background:var(--color-accent-hover)}.setwon-modal__btn-server{font-size:18px;font-weight:700}.setwon-modal__btn-start{font-size:13px;opacity:.8}.belle-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:90}.belle-modal{background:#1a1a1a;border-radius:16px;padding:32px 28px;width:90%;max-width:320px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.belle-modal__title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--color-accent)}.belle-modal__question{font-size:22px;font-weight:700;color:var(--color-text)}.belle-modal__actions{display:flex;gap:12px;width:100%;margin-top:8px}.belle-modal__btn{flex:1;padding:14px;border:none;border-radius:8px;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .2s}.belle-modal__btn:hover{opacity:.85}.belle-modal__btn--swap{background:var(--color-accent);color:#fff}.belle-modal__btn--keep{background:#2a2a2a;color:var(--color-text-muted)}.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__history{position:absolute;top:12px;right:48px;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__divider{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--color-divider);z-index:5}@media(orientation:portrait){.match-screen{flex-direction:column}.match-screen__divider{inset:50% 0 auto;width:auto;height:2px}}.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)}.match-screen__winner-btn{margin-top:8px;padding:12px 32px;font-size:18px;background:var(--color-accent);color:#fff;border:none;border-radius:8px;cursor:pointer}.login-page{display:flex;flex-direction:column;height:100dvh}.login-body{flex:1;display:flex;align-items:center;justify-content:center}.login-card{display:flex;flex-direction:column;align-items:center;gap:2rem;padding:3rem;border:1px solid var(--color-divider);border-radius:12px;background:var(--color-surface)}.login-card h1{margin:0;font-size:1.6rem}.google-btn{display:flex;align-items:center;gap:.75rem;padding:.65rem 1.25rem;font-size:.95rem;font-weight:500;border:1px solid #555;border-radius:4px;background:transparent;color:var(--color-text);cursor:pointer;font-family:inherit}.google-btn:hover{border-color:#aaa;background:#ffffff0d}.app{height:100dvh;overflow:hidden}
