*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue-dark: #0d3b6e;--blue: #1a56a0;--blue-light: #2979cc;--blue-bg: #e8f0fb;--page-bg: #000000;--orange: #e8640a;--orange-light: #ff8533;--surface: #ffffff;--surface-2: #f4f7fb;--text: #1a1a2e;--text-muted: #5a6580;--border: #d0daea;--red: #c0392b;--red-light: #e74c3c;--green: #1a7a4a;--green-bg: #e8f5ee;--green-dark: #145c37;--radius: 12px;--radius-sm: 8px;--shadow-card: 0 4px 20px rgba(13,59,110,.1)}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--page-bg);color:var(--text);min-height:100dvh;padding-bottom:2rem}header{background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue) 100%);color:#fff;padding:1.5rem 1.25rem 1.25rem;text-align:center;box-shadow:var(--shadow-card);max-width:560px;margin:1rem auto 0;border-radius:var(--radius)}.header-inner{position:relative;display:flex;align-items:center;justify-content:center}header h1{font-size:1.9rem;font-weight:800;letter-spacing:-.5px}.btn-help{position:absolute;right:0;background:#ffffff26;color:#fff;border:1.5px solid rgba(255,255,255,.35);border-radius:50%;width:2rem;height:2rem;font-size:1rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.btn-help:hover{background:#ffffff47;border-color:#fff9}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:500;padding:1rem}.modal-content{background:var(--surface);border-radius:var(--radius);max-width:480px;width:100%;max-height:82dvh;overflow-y:auto;box-shadow:0 8px 40px #00000059}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.25rem .9rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface)}.modal-header h2{font-size:1.05rem;font-weight:700;color:var(--blue-dark)}.modal-close{flex-shrink:0}.modal-body{padding:1rem 1.25rem 1.5rem}.help-list{display:flex;flex-direction:column;gap:.85rem}.help-list dt{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--blue-dark);margin-bottom:.2rem}.help-list dd{font-size:.9rem;line-height:1.55;color:var(--text);margin-left:0}.subtitle{margin-top:.3rem;font-size:.875rem;opacity:.8}.gym-bar{max-width:560px;margin:.5rem auto 0;background:var(--blue-dark);border-radius:var(--radius);box-shadow:var(--shadow-card)}.gym-bar-inner{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem}.gym-select{flex:1;min-width:0;padding:.45rem .6rem;font-size:.95rem;font-weight:600;font-family:inherit;background:#ffffff1f;color:#fff;border:1.5px solid rgba(255,255,255,.25);border-radius:var(--radius-sm);outline:none;cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.gym-select:focus{border-color:#fff9}.gym-name-input{flex:1;min-width:0;padding:.45rem .7rem;font-size:.95rem;font-family:inherit;background:#ffffff1f;color:#fff;border:1.5px solid rgba(255,255,255,.4);border-radius:var(--radius-sm);outline:none}.gym-name-input::placeholder{color:#ffffff80}.gym-name-input:focus{border-color:#fffc;background:#ffffff2e}.btn-sm{padding:.4rem .75rem;font-size:.82rem;white-space:nowrap}.gym-bar-inner .btn-ghost{background:#ffffff1f;color:#fff;border-color:#ffffff40}.gym-bar-inner .btn-ghost:hover{background:#ffffff38;border-color:#ffffff80}.gym-bar-inner .btn-primary{background:var(--orange)}.gym-bar-inner .btn-primary:hover{background:var(--orange-light)}.btn-danger-ghost{color:#ffb3b3!important;border-color:#ff64644d!important}.btn-danger-ghost:hover{background:#ff646426!important;border-color:#ff646499!important;color:#ffd0d0!important}main{max-width:560px;margin:0 auto;padding:1.25rem 1rem;display:flex;flex-direction:column;gap:1rem}.card{background:var(--surface);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-card)}.card h2{font-size:1.1rem;font-weight:700;color:var(--blue-dark);display:flex;align-items:center;gap:.5rem}.section-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.pool-quick-btns{display:flex;gap:.4rem;flex-shrink:0}.tonight-summary{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem}.tonight-summary strong{color:var(--green-dark)}.badge{background:var(--blue);color:#fff;font-size:.75rem;font-weight:700;border-radius:99px;padding:.1em .55em;min-width:1.4em;text-align:center}.add-player-row{display:flex;gap:.5rem;margin-top:.75rem}.add-player-row input{flex:1;padding:.7rem .9rem;font-size:1rem;border:2px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s;background:var(--surface-2);color:var(--text);min-width:0}.add-player-row input:focus{border-color:var(--blue-light);background:#fff}.player-list{list-style:none;display:flex;flex-direction:column;gap:.4rem;margin-bottom:.25rem}.player-item{display:flex;align-items:center;gap:.4rem;border-radius:var(--radius-sm);transition:background .1s}.btn-toggle{flex:1;display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);text-align:left;min-width:0;transition:background .15s,border-color .15s}.btn-toggle:hover{border-color:var(--blue-light)}.btn-toggle--in{background:var(--green-bg);border-color:#a5d6b7}.btn-toggle--in:hover{border-color:var(--green)}.toggle-dot{width:10px;height:10px;border-radius:50%;background:var(--border);flex-shrink:0;transition:background .15s}.btn-toggle--in .toggle-dot{background:var(--green)}.player-name{flex:1;font-size:.95rem;font-weight:500;word-break:break-word;color:var(--text)}.btn-toggle--in .player-name{color:var(--green-dark)}.presence-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);flex-shrink:0}.btn-toggle--in .presence-label{color:var(--green)}.empty-hint{font-size:.875rem;color:var(--text-muted);text-align:center;padding:.5rem 0}.courts-row{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-top:.75rem}.courts-count{font-size:2.5rem;font-weight:800;color:var(--blue-dark);min-width:2.5rem;text-align:center;line-height:1}.btn{cursor:pointer;border:none;border-radius:var(--radius-sm);font-weight:600;font-family:inherit;transition:background .15s,transform .1s,opacity .15s;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.96)}.btn-primary{background:var(--blue);color:#fff;padding:.7rem 1.1rem;font-size:.95rem;white-space:nowrap}.btn-primary:hover{background:var(--blue-light)}.btn-ghost{background:var(--surface-2);color:var(--blue);border:1.5px solid var(--border);padding:.3rem .7rem;font-size:.8rem}.btn-ghost:hover{background:var(--blue-bg);border-color:var(--blue-light)}.btn-remove{background:transparent;color:var(--text-muted);padding:.4rem .6rem;font-size:.85rem;border-radius:var(--radius-sm);flex-shrink:0}.btn-remove:hover{background:#fde8e8;color:var(--red-light)}.btn-stepper{background:var(--blue-bg);color:var(--blue-dark);border:2px solid var(--border);width:3rem;height:3rem;font-size:1.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.btn-stepper:hover{background:var(--blue);color:#fff;border-color:var(--blue)}.shuffle-container{display:flex;flex-direction:column;align-items:center;gap:.6rem}.btn-shuffle{background:linear-gradient(135deg,var(--orange) 0%,var(--orange-light) 100%);color:#fff;padding:1rem 3rem;font-size:1.25rem;border-radius:99px;box-shadow:0 4px 14px #e8640a66;width:100%;max-width:320px}.btn-shuffle:hover{box-shadow:0 6px 20px #e8640a80;filter:brightness(1.05)}.btn-disabled{background:#ccc!important;box-shadow:none!important;cursor:not-allowed}.warn{font-size:.825rem;color:#9a5700;background:#fff8e1;border:1px solid #ffe082;border-radius:var(--radius-sm);padding:.5rem .75rem;text-align:center;width:100%;max-width:320px}.courts-hint{font-size:.8rem;color:var(--text-muted);text-align:center;margin-top:.6rem}.results-heading{font-size:1.15rem;font-weight:700;color:var(--blue-dark);text-align:center;margin-bottom:.75rem}.courts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.court-card{background:var(--surface);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow-card);border-top:4px solid var(--blue)}.court-card.court-empty{border-top-color:var(--border);opacity:.6}.court-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--blue);margin-bottom:.6rem}.court-empty .court-label{color:var(--text-muted)}.court-players{list-style:none;display:flex;flex-direction:column;gap:.3rem}.court-players li{font-size:.95rem;font-weight:500;padding:.3rem .5rem;background:var(--green-bg);border-radius:6px;color:var(--green);word-break:break-word}.court-no-players{font-size:.85rem;color:var(--text-muted);font-style:italic}.court-names-list{list-style:none;display:flex;flex-direction:column;gap:.4rem;margin:.75rem 0 .5rem}.court-names-list li{display:flex;align-items:center;gap:.5rem}.court-num-label{font-size:.8rem;font-weight:700;color:var(--text-muted);min-width:1.1rem;text-align:right;flex-shrink:0}.court-name-input{flex:1;padding:.45rem .65rem;font-size:.9rem;font-weight:500;font-family:inherit;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text);outline:none;transition:border-color .15s}.court-name-input:focus{border-color:var(--blue-light);background:#fff}.court-pref-select{padding:.3rem .35rem;font-size:.78rem;font-weight:600;font-family:inherit;background:var(--surface-2);color:var(--blue-dark);border:1.5px solid var(--border);border-radius:var(--radius-sm);outline:none;cursor:pointer;flex-shrink:0;min-width:0;max-width:7rem}.court-pref-select:focus{border-color:var(--blue-light)}.draggable-item{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.draggable-item:active{cursor:grabbing}.drag-ghost{position:fixed;z-index:1000;pointer-events:none;background:var(--blue-dark);color:#fff;font-size:.9rem;font-weight:600;font-family:inherit;padding:.4rem .8rem;border-radius:99px;box-shadow:0 4px 16px #0000004d;white-space:nowrap;transform:translate(-50%,-50%);opacity:.92}.drop-zone{transition:outline .1s,background .1s}.drop-zone--active{outline:2.5px dashed var(--blue-light);outline-offset:3px;background:var(--blue-bg)!important}.court-empty-slot{display:none;margin-top:.4rem;padding:.35rem .5rem;border:2px dashed var(--border);border-radius:6px;font-size:.75rem;font-weight:600;color:var(--text-muted);text-align:center;pointer-events:none}body.is-dragging .court-empty-slot{display:block;pointer-events:auto}body.is-dragging .court-empty-slot.drop-zone--active{border-color:var(--blue-light);background:var(--blue-bg);color:var(--blue)}.bench--empty{display:none}body.is-dragging .bench--empty{display:block}body.is-dragging .bench--empty .bench-count{display:none}.bench-empty-hint{font-size:.85rem;color:var(--text-muted);font-style:italic;text-align:center;padding:.25rem 0}.teams{display:flex;flex-direction:column;gap:.3rem}.team{display:flex;flex-direction:column;gap:.25rem}.team-player{display:block;font-size:.95rem;font-weight:500;padding:.3rem .5rem;background:var(--blue-bg);border-radius:6px;color:var(--blue-dark);word-break:break-word}.team:last-child .team-player{background:#fce4ec;color:#880e4f}.team-player.is-server-inline{display:flex;flex-direction:column;align-items:flex-start;gap:.05rem}.vs{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);text-align:center;padding:.1rem 0}li.is-server{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;font-weight:600;color:var(--green-dark);background:var(--green-bg)!important}.server-tag{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--green);align-self:flex-end}.bench{margin-top:1rem;background:var(--surface);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow-card);border-top:4px solid #b0bec5}.bench-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}.bench-title{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.bench-count{font-size:.75rem;color:var(--text-muted)}.bench-players{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem}.bench-players li{font-size:.9rem;font-weight:500;padding:.3rem .65rem;background:#eceff1;border-radius:99px;color:#546e7a}.game-type{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;border-radius:99px;padding:.15em .6em;margin-bottom:.5rem}.game-type--singles{background:#e3f2fd;color:#1565c0}.game-type--cutthroat{background:#fce4ec;color:#c62828}.game-type--doubles{background:#e8f5e9;color:#2e7d32}.app-footer{text-align:center;padding:1.5rem 1rem 2rem}.btn-clear-data{background:none;border:none;font-size:.8rem;color:var(--text-muted);text-decoration:underline;cursor:pointer;padding:.25rem .5rem}.btn-clear-data:hover{color:var(--red-light)}@media (max-width: 380px){header h1{font-size:1.6rem}.btn-shuffle{font-size:1.1rem;padding:.9rem 2rem}.courts-grid{grid-template-columns:1fr 1fr}}@media (min-width: 560px){main{padding:1.5rem 1.25rem}}
