:root{--accent:#2ecc71;--accent-hover:#27ae60;--accent-bg:#2ecc711a;--text:#222;--text-muted:#666;--bg:#f9f9fb;--surface:#fff;--border:#e0e0e0;--font-sans:"Inter", system-ui, -apple-system, sans-serif}*{box-sizing:border-box}body{font-family:var(--font-sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;margin:0;font-size:16px;line-height:1.5}#app{max-width:480px;min-height:100svh;padding:1rem;padding-left:max(1rem, env(safe-area-inset-left));padding-right:max(1rem, env(safe-area-inset-right));padding-bottom:max(1rem, env(safe-area-inset-bottom));margin:0 auto}.setup-screen{padding:0 0 1rem}.setup-hero{text-align:center;padding:1.5rem 1rem 1.25rem}.cold-resume-banner{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin:0 0 1rem;padding:1rem}.cold-resume-text{color:var(--text-muted);margin:0 0 .75rem;font-size:.95rem}.cold-resume-actions{flex-direction:column;gap:.5rem;display:flex}.btn-text-danger{color:#c0392b;cursor:pointer;touch-action:manipulation;background:0 0;border:none;min-height:44px;padding:.5rem 0;font-family:inherit;font-size:.9rem;text-decoration:underline}.btn-text-danger:hover{color:#922b21}.landing-title{color:var(--accent);margin:0 0 .35rem;font-size:2.25rem;font-weight:700}.landing-tagline{color:var(--text-muted);margin:0;font-size:1rem}.btn-primary{color:#fff;background:var(--accent);cursor:pointer;touch-action:manipulation;border:none;border-radius:8px;min-width:44px;min-height:44px;padding:.75rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:background .2s}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-back{color:var(--text-muted);cursor:pointer;touch-action:manipulation;background:0 0;border:none;align-items:center;min-width:44px;min-height:44px;margin-top:1rem;padding:.5rem 0;font-family:inherit;font-size:.9rem;display:inline-flex}.btn-back:hover{color:var(--text)}.player-input{padding:1rem 0}.section-title{color:var(--text);margin:0 0 1rem;font-size:1.5rem;font-weight:600}.input-row{gap:.5rem;margin-bottom:1rem;display:flex}.input-wrapper{flex:1;position:relative}.player-input input[type=text]{border:1px solid var(--border);background:var(--surface);border-radius:8px;width:100%;min-height:44px;padding:.75rem .875rem;font-family:inherit;font-size:16px}.player-input input[type=text]:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg);outline:none}.btn-add{color:#fff;background:var(--accent);cursor:pointer;touch-action:manipulation;border:none;border-radius:8px;flex-shrink:0;width:48px;min-width:48px;height:48px;min-height:48px;font-size:1.5rem;font-weight:300;line-height:1}.btn-add:hover{background:var(--accent-hover)}.suggestions{background:var(--surface);border:1px solid var(--border);z-index:10;border-radius:8px;max-height:160px;margin:0;padding:.25rem 0;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0000001a}.suggestion-btn{text-align:left;cursor:pointer;touch-action:manipulation;background:0 0;border:none;width:100%;min-height:44px;padding:.75rem .875rem;font-family:inherit;font-size:.95rem;display:block}.suggestion-btn:hover{background:var(--accent-bg)}.chips{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.chip{background:var(--accent-bg);color:var(--text);border-radius:6px;align-items:center;gap:.25rem;padding:.4rem .5rem;font-size:.9rem;display:inline-flex}.chip-remove{min-width:44px;min-height:44px;color:var(--text-muted);cursor:pointer;touch-action:manipulation;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;margin:-.25rem;padding:.5rem;font-size:1.2rem;line-height:1;display:inline-flex}.chip-remove:hover{color:var(--text);background:#00000014}.checkbox-row{cursor:pointer;touch-action:manipulation;align-items:center;gap:.75rem;min-height:44px;margin-bottom:1rem;padding:.5rem 0;font-size:.95rem;display:flex}.checkbox-row input{width:1.25rem;min-width:1.25rem;height:1.25rem;min-height:1.25rem;accent-color:var(--accent);cursor:pointer}.warning{color:var(--text-muted);margin:0 0 1rem;font-size:.9rem}.error{color:#c0392b;margin:0 0 1rem;font-size:.9rem}.btn-generate{width:100%;margin-top:.5rem}.session-dashboard{padding:1rem 0}.session-header{margin-bottom:1.5rem}.session-header-brand{margin-bottom:0}.session-header-top{flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.session-header-text{flex-direction:column;flex:1;align-items:flex-start;gap:.2rem;min-width:0;display:flex}.session-header-actions{flex-shrink:0;align-items:center;display:flex}.session-brand-title{letter-spacing:-.02em;color:var(--accent);margin:0;font-size:1.85rem;font-weight:800;line-height:1.12}.session-meta-line{color:var(--text-muted);margin:0;font-size:.875rem;line-height:1.3}.session-round-line{color:var(--text-muted);margin:0;font-size:.8rem;line-height:1.3}.session-header-top .section-title{flex-shrink:0;margin:0}.btn-export{min-height:44px;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent);cursor:pointer;white-space:nowrap;touch-action:manipulation;border-radius:6px;padding:.5rem .75rem;font-family:inherit;font-size:.85rem;font-weight:600}.btn-export:hover:not(:disabled){background:var(--accent);color:#fff}.btn-export:disabled{opacity:.5;cursor:not-allowed}.progress-bar{background:var(--border);border-radius:4px;height:8px;margin-top:.5rem;overflow:hidden}.progress-fill{background:var(--accent);height:100%;transition:width .3s}.session-dashboard .card{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:1rem;padding:1rem}.current-match-tap{width:100%;font:inherit;color:inherit;text-align:left;border:1px solid var(--border);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:8px;flex-direction:column;align-items:stretch;gap:.5rem;margin:0 0 .75rem;padding:.75rem 1rem .85rem;display:flex}.current-match-tap:hover{background:var(--accent-bg)}.current-match-tap:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.current-match-tap .match-card{padding:.15rem 0 0}.current-match-tap-hint{color:var(--text-muted);margin:0;padding-top:.15rem;font-size:.8rem;line-height:1.35;display:block}.current-match-picker{border-top:1px solid var(--border);margin-bottom:1rem;padding:.75rem 0}.picker-row{margin-bottom:.65rem}.picker-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem;font-size:.75rem;font-weight:600;display:block}.picker-select{border:1px solid var(--border);background:var(--surface);width:100%;min-height:44px;color:var(--text);touch-action:manipulation;border-radius:8px;padding:.5rem .6rem;font-family:inherit;font-size:16px}.picker-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg);outline:none}.session-dashboard h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;font-size:.9rem;font-weight:600}.matchup{margin:.25rem 0;font-size:1rem}.matchup.muted{color:var(--text-muted);font-size:.95rem}.score-placeholder{color:var(--text-muted);margin:.5rem 0 0;font-size:.9rem}.upcoming,.completed{margin-bottom:1rem}.session-dashboard .muted{color:var(--text-muted);font-size:.9rem}.match-card{padding:.5rem 0}.match-card.compact{padding:.25rem 0}.match-game-index{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.2rem;font-size:.75rem;font-weight:600}.match-card.compact .match-game-index{margin-bottom:.15rem}.match-teams{flex-wrap:wrap;align-items:center;gap:.35rem;font-size:1rem;display:flex}.match-teams .vs{color:var(--text-muted);margin:0 .2rem;font-size:.9rem}.match-teams .team{font-weight:500}.match-card.winner-a .team-a,.match-card.winner-b .team-b{color:var(--accent);font-weight:600}.match-score{color:var(--text-muted);gap:.5rem;margin-top:.35rem;font-size:.95rem;display:flex}.match-card.compact .match-score{margin-top:.2rem;font-size:.9rem}.set-score{font-variant-numeric:tabular-nums}.score-entry{border-top:1px solid var(--border);margin-top:1rem;padding-top:1rem}.score-row{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.score-row input{border:1px solid var(--border);text-align:center;touch-action:manipulation;border-radius:6px;width:4rem;min-height:44px;padding:.6rem .5rem;font-family:inherit;font-size:16px}.score-row input:focus{border-color:var(--accent);outline:none}.score-sep{color:var(--text-muted);font-weight:500}.set-label{color:var(--text-muted);margin-left:.25rem;font-size:.85rem}.score-entry-actions{align-items:stretch;gap:.5rem;margin-top:.75rem;display:flex}.score-entry-actions .btn-save,.score-entry-actions .btn-secondary{flex:1;min-height:44px}.score-entry-actions .btn-save-wide{flex:none;width:100%}.btn-secondary{color:var(--text);background:var(--surface);border:1px solid var(--border);cursor:pointer;touch-action:manipulation;border-radius:8px;padding:.75rem 1rem;font-family:inherit;font-size:1rem;font-weight:600}.btn-secondary:hover{background:var(--bg)}.btn-secondary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-save{min-height:44px}.completed-row{border-bottom:1px solid var(--border);margin-bottom:.75rem;padding-bottom:.75rem}.completed-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.completed-row.is-editing{background:var(--accent-bg);border-bottom:none;border-radius:8px;margin-left:-.5rem;margin-right:-.5rem;padding-top:.5rem;padding-left:.5rem;padding-right:.5rem}.completed-row-trigger{width:100%;min-height:48px;font:inherit;color:inherit;text-align:left;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:8px;align-items:center;gap:.5rem;margin:0;padding:.35rem .35rem .35rem .15rem;display:flex}.completed-row-trigger:hover{background:#0000000a}.completed-row-trigger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.completed-row-main{flex:1;min-width:0}.completed-row-main .match-card.compact{padding-top:0;padding-bottom:0}.completed-row-icon{width:2.25rem;height:2.25rem;color:var(--text-muted);opacity:.85;flex-shrink:0;justify-content:center;align-items:center;display:flex}.completed-row-trigger:hover .completed-row-icon{color:var(--accent);opacity:1}.edit-pencil-svg{width:1.125rem;height:1.125rem}.completed .score-entry{border-top:1px solid var(--border);margin-top:.75rem;padding-top:.75rem}.standings{border-top:1px solid var(--border);margin-top:1.5rem;margin-bottom:1rem;padding-top:1rem}.standings-table{border-collapse:collapse;width:100%;font-size:.95rem}.standings-table th,.standings-table td{text-align:left;padding:.4rem .5rem}.standings-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.standings-table td:first-child,.standings-table th:first-child{text-align:center;width:2rem}.standings-table td:nth-child(n+3),.standings-table th:nth-child(n+3){text-align:center;width:2.5rem}.standings-table tbody tr:nth-child(2n){background:var(--accent-bg)}@media (width<=380px){.session-header-top{flex-direction:column;align-items:stretch;gap:.5rem}.session-header-top .section-title{text-align:center}.btn-export{width:100%}}@media (height<=500px){.setup-hero{padding:1rem}.landing-title{font-size:2rem}}
