:root{--bg:#f4f7fb;--panel:#fff;--border:#e5eaf3;--text:#192132;--muted:#6b768f;--primary:#5b6cff;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444}
*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:linear-gradient(180deg,#f7f9fd 0%,#eef3f9 100%);color:var(--text)}
.wrap{max-width:1280px;margin:0 auto;padding:24px}.hero,.card{background:rgba(255,255,255,.92);border:1px solid var(--border);border-radius:24px;box-shadow:0 10px 30px rgba(36,45,77,.08)}
.hero{padding:22px;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:16px}.hero h1{margin:0 0 6px;font-size:34px}.hero p{margin:0;color:var(--muted)}
.hero__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.current-team{padding:12px 14px;border:1px solid var(--border);border-radius:16px;background:#f8fbff;font-weight:700}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:14px;border:1px solid var(--border);background:#fff;font-weight:800;cursor:pointer}.btn--small{padding:8px 10px;font-size:12px}
.card{padding:18px;margin-bottom:16px}.select-team h2,.my-bookings h2{margin:0 0 8px}.select-team p{margin:0 0 14px;color:var(--muted)}.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}
.team-pill{padding:16px;border-radius:18px;border:1px solid var(--border);background:#fff;cursor:pointer;text-align:left}.team-pill strong{display:block;font-size:22px}.team-pill span{display:block;margin-top:4px;color:var(--muted)}
.toolbar{display:flex;justify-content:flex-end;margin-bottom:12px}.date-switch select{padding:11px 12px;border-radius:14px;border:1px solid var(--border);background:#fff}.date-switch label{display:flex;align-items:center;gap:8px;font-weight:700}
.table-wrap{overflow:auto}.booking-table{width:100%;min-width:860px;border-collapse:separate;border-spacing:0}.booking-table th,.booking-table td{padding:12px;border-bottom:1px solid #edf1f7;border-right:1px solid #edf1f7;vertical-align:top}.booking-table th:last-child,.booking-table td:last-child{border-right:none}.booking-table th{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:#fafcff}.club-head{min-width:190px;background:#fbfcff}.club-head strong{display:block}.club-head small{display:block;margin-top:4px;color:var(--muted)}
.cell{border-radius:16px;padding:14px;text-align:center;background:#f5f7fb;font-weight:800}.cell--free{background:#eefbf3}.cell--partial{background:#fff7e8}.cell--full{background:#fff1f2}.cell--empty{color:#98a2b3}
.slot-form{display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:18px;background:#f7f9fc}.slot-form__top{font-weight:900;text-align:center}.slot-form input[type=number]{width:100%;padding:10px;border:1px solid var(--border);border-radius:12px}.slot-form.cell--free{background:#eefbf3}.slot-form.cell--partial{background:#fff7e8}.slot-form.cell--full{background:#fff1f2}.slot-note{text-align:center;color:var(--muted);font-size:12px}
.my-bookings ul{margin:0;padding-left:18px}.my-bookings li{margin-bottom:8px}.empty{padding:20px;text-align:center;color:var(--muted)}
@media (max-width:860px){.wrap{padding:16px}.hero{flex-direction:column}.hero h1{font-size:28px}}
