:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.4;font-weight:450;color:#111827;background:radial-gradient(circle at top,#f9fafb,#f2f4f7 45%,#e9edf3);--bg-surface: rgba(255, 255, 255, .9);--bg-surface-strong: rgba(255, 255, 255, .98);--bg-soft: #eef2f7;--text-main: #111827;--text-muted: #6b7280;--text-subtle: #4b5563;--line-soft: rgba(107, 114, 128, .24);--line-strong: rgba(107, 114, 128, .36);--action: #2563eb;--action-hover: #1d4ed8;--on-action: #f8faff;--serve: #ea580c;--error: #b91c1c;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}a{color:inherit}button,input,select{font:inherit}#root{margin:0 auto}.app-shell{max-width:1040px;margin:0 auto;padding:1rem}.brand{margin:0;font-size:1.15rem;font-weight:700;letter-spacing:.04em}.top-controls{display:flex;justify-content:center;align-items:center;gap:.45rem;margin-top:.2rem;margin-bottom:.6rem}.top-brand{margin:0;display:inline-flex;align-items:center;gap:.35rem;color:var(--text-subtle);font-size:.92rem;font-weight:700;padding:.25rem .5rem}.top-controls a{text-decoration:none;color:var(--text-muted);font-weight:600;font-size:.95rem;padding:.35rem .65rem;border-radius:999px}.top-controls a.active,.top-controls a:hover{background:var(--bg-soft)}.page{margin-top:1rem;display:grid;gap:1rem}.page h1,.page h2,.page h3{margin:0}.helper{margin:0;color:var(--text-muted)}.error{margin:0;color:var(--error);font-weight:600}.panel{background:var(--bg-surface);border:1px solid var(--line-soft);border-radius:18px;padding:1rem;display:grid;gap:.75rem}.start-panel{gap:1rem}.start-top-controls{display:grid;gap:.7rem}.team-setup-grid{display:grid;gap:.9rem}.team-card{border:1px solid var(--line-soft);border-radius:14px;padding:.8rem;display:grid;gap:.6rem;background:var(--bg-surface)}.team-card h2{margin:0;font-size:1rem;color:var(--text-subtle)}.start-footer{display:flex;align-items:center;justify-content:space-between;gap:.8rem}.start-footer .helper{font-size:.95rem}label{display:grid;gap:.35rem;font-weight:600}input,select{background:var(--bg-surface-strong);border:1px solid var(--line-strong);border-radius:12px;min-height:44px;padding:.5rem .65rem}button{border:none;border-radius:12px;min-height:44px;padding:.5rem .85rem;cursor:pointer;background:var(--action);color:var(--on-action);font-weight:650}button:disabled{opacity:.48;cursor:not-allowed}.row{display:flex;gap:.7rem}.row input{flex:1}.scoreboard{display:grid;gap:.9rem}.player-card{border-radius:18px;padding:1rem;background:var(--bg-surface);border:2px solid transparent;display:grid;gap:.55rem}.player-card.tappable{cursor:pointer}.player-card.tappable:active{transform:scale(.995)}.player-card.serving{border-color:var(--serve)}.player-card h2{margin:0;font-size:1.35rem}.score{margin:0;font-size:clamp(2.7rem,12vw,4.4rem);font-weight:750}.score-actions{display:grid;grid-template-columns:1fr auto auto;gap:.5rem}.serve-progress{display:flex;gap:.55rem;align-items:center;min-height:2.2rem}.serve-progress.placeholder{visibility:hidden}.serve-step{width:2.2rem;height:2.2rem;border-radius:999px;display:grid;place-items:center;font-size:1.1rem;font-weight:700;border:2px solid var(--line-strong);color:var(--text-subtle);background:var(--bg-surface-strong)}.serve-step.filled{background:var(--serve);color:#fff;border-color:var(--serve)}.serve-pill{display:inline-flex;align-items:center;justify-content:center;min-height:2.2rem;min-width:10rem;border-radius:999px;padding:0 1rem;font-weight:800;letter-spacing:.06em;border:2px solid var(--line-strong);color:var(--text-subtle);background:var(--bg-surface-strong)}.serve-pill.deuce{background:var(--serve);color:#fff;border-color:var(--serve)}.controls-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:1rem}.control-actions{display:flex;gap:.45rem;flex-wrap:wrap;justify-content:flex-end}@media(max-width:560px){.score-actions{grid-template-columns:1fr 1fr}.score-actions button:first-child{grid-column:1 / -1}.controls-row{grid-template-columns:1fr}}.status-line{margin:0;font-weight:650;min-width:0}.timeline ul,.history-list,.user-list{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}.timeline li{display:grid;grid-template-columns:auto 1fr;gap:.8rem;font-size:.95rem;padding:.45rem .55rem;border-radius:9px;background:var(--bg-surface-strong)}.timeline li.undone{opacity:.55;text-decoration:line-through}.history-item{width:100%;text-align:left;display:grid;gap:.25rem;background:var(--bg-soft);color:var(--text-main)}.user-list li{display:flex;gap:.7rem}.user-list input{flex:1}@media(min-width:760px){.app-shell{padding:1.4rem}.scoreboard,.start-top-controls,.team-setup-grid{grid-template-columns:1fr 1fr}.controls-row{grid-column:1 / -1}}
