:root{--primary:#001952;--primary-600:#0c2a72;--secondary:#2f55b0;--secondary-100:#e7ecf8;--accent:#35c2d6;--accent-600:#1ba6bc;--accent-ink:#001952;--bg:#f4f6fb;--surface:#fff;--text:#11203f;--muted:#5f6a82;--border:#e2e7f1;--success:#16a34a;--success-bg:#e8f7ee;--danger:#dc2626;--danger-bg:#fdeaea;--warn:#b45309;--warn-bg:#fdf3e3;--radius:14px;--radius-sm:10px;--shadow:0 10px 30px #0019521f;--shadow-sm:0 2px 8px #00195212;color:var(--text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100vh;margin:0}body{background:var(--bg);-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{color:var(--text);margin:0 0 .4em;line-height:1.2}h1{font-size:1.6rem}h2{font-size:1.25rem}.app-header{z-index:20;background:var(--surface);border-bottom:1px solid var(--border);border-top:3px solid var(--accent);justify-content:space-between;align-items:center;gap:1rem;padding:.7rem 1.25rem;display:flex;position:sticky;top:0}.brand{color:var(--primary);align-items:center;gap:.6rem;font-size:1.15rem;font-weight:800;display:flex}.brand img{object-fit:cover;border-radius:8px;width:32px;height:32px}.header-nav{align-items:center;gap:.5rem;display:flex}.header-user{color:var(--muted);align-items:center;gap:.3rem;font-size:.85rem;text-decoration:none;display:inline-flex}.header-user-icon{display:none}.container{max-width:1040px;margin:0 auto;padding:1.5rem 1.25rem 3rem}.page-title{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1.25rem}.card+.card{margin-top:1rem}.play-courts{flex-direction:column;gap:.6rem;display:flex}.play-court{border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;background:#fff;padding:.6rem}.play-roster{flex-wrap:wrap;gap:.4rem;display:flex}.play-chip{border:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:.35rem;padding:.25rem .6rem;font-size:.85rem;display:inline-flex}.play-chip.on{background:var(--secondary-100);border-color:var(--secondary)}.play-chip.sel{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.play-chip input{width:auto;margin:0}.play-pair{flex-wrap:wrap;justify-content:center;gap:.35rem;margin:.15rem 0;display:flex}.play-pair .play-chip:not(.sel){background:#fff;font-weight:500}.play-srow{text-align:left;justify-content:space-between;align-items:center;gap:.6rem;padding:.25rem .1rem;display:flex}.play-srow .play-team{font-size:.9rem;line-height:1.15}.play-srow.win .play-team{color:var(--accent-600);font-weight:800}.play-score{text-align:center;border:2px solid var(--accent);background:#fff;flex:none;width:58px;padding:.45rem .3rem;font-size:1.05rem;font-weight:800}.play-score::placeholder{color:var(--accent);opacity:.6;font-weight:600}.play-rank-toggle{border:1px solid var(--border);border-radius:999px;display:inline-flex;overflow:hidden}.play-rank-toggle button{text-align:center;min-width:3.2rem;color:var(--text);cursor:pointer;background:#fff;border:none;padding:.3rem .7rem;font-size:.8rem;font-weight:600}.play-rank-toggle button.on{background:var(--primary);color:#fff}.table.play-rank th,.table.play-rank td{padding:.4rem .5rem}.table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.table th.sortable:hover{color:var(--secondary)}.rule-sep{border:0;border-top:3px solid var(--border);border-radius:3px;width:50%;margin:.6rem auto 1.2rem}.menu-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.menu-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);color:var(--text);padding:1.4rem;text-decoration:none;transition:transform .12s,box-shadow .12s;display:block}.menu-card:hover{box-shadow:var(--shadow);text-decoration:none;transform:translateY(-2px)}.menu-card .emoji{font-size:1.6rem}.menu-card h3{margin:.6rem 0 .2rem}.menu-card p{color:var(--muted);margin:0;font-size:.9rem}.menu-card.admin{border-color:var(--secondary);background:var(--secondary-100)}.btn{font:inherit;border-radius:var(--radius-sm);background:var(--primary);color:#fff;cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.45rem;padding:.6rem 1.05rem;font-weight:600;transition:background .12s,opacity .12s;display:inline-flex}.btn:hover{background:var(--primary-600)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.secondary{background:var(--secondary-100);color:var(--primary)}.btn.secondary:hover{background:#e1e0fb}.btn.ghost{border-color:var(--border);color:var(--text);background:0 0}.btn.ghost:hover{background:var(--bg)}.btn.danger{background:var(--danger)}.btn.danger:hover{opacity:.9}.btn.sm{padding:.4rem .7rem;font-size:.85rem}.btn.block{width:100%}.field{margin-bottom:1rem}.field label{color:var(--text);margin-bottom:.35rem;font-size:.85rem;font-weight:600;display:block}input,select,textarea{width:100%;font:inherit;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:#fff;padding:.6rem .7rem}input:focus,select:focus,textarea:focus{border-color:var(--secondary);box-shadow:0 0 0 3px var(--secondary-100);outline:none}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.auth-wrap{place-items:center;min-height:100vh;padding:1.5rem;display:grid}.auth-card{background:var(--surface);border-radius:var(--radius);width:100%;max-width:420px;box-shadow:var(--shadow);padding:2rem}.auth-card .brand{justify-content:center;margin-bottom:1.25rem}.alert{border-radius:var(--radius-sm);margin-bottom:1rem;padding:.7rem .9rem;font-size:.9rem}.alert.error{background:var(--danger-bg);color:var(--danger)}.alert.success{background:var(--success-bg);color:var(--success)}.alert.warn{background:var(--warn-bg);color:var(--warn)}.alert.info{background:var(--secondary-100);color:var(--primary)}.badge{text-transform:uppercase;letter-spacing:.02em;border-radius:999px;align-items:center;gap:.3rem;padding:.2rem .55rem;font-size:.72rem;font-weight:700;display:inline-flex}.badge.green{background:var(--success-bg);color:var(--success)}.badge.red{background:var(--danger-bg);color:var(--danger)}.badge.gray{color:var(--muted);background:#eef0f6}.badge.blue{background:var(--secondary-100);color:var(--primary)}.badge.amber{background:var(--warn-bg);color:var(--warn)}.calendar{-webkit-user-select:none;user-select:none}.calendar-head{justify-content:space-between;align-items:center;margin-bottom:.8rem;display:flex}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.calendar-dow{text-align:center;color:var(--muted);text-transform:uppercase;padding-bottom:4px;font-size:.72rem;font-weight:700}.calendar-day{aspect-ratio:1;border:1px solid var(--border);border-radius:var(--radius-sm);font:inherit;color:var(--text);cursor:pointer;background:#fff;flex-direction:column;justify-content:center;align-items:center;gap:3px;font-weight:600;transition:border-color .1s,background .1s;display:flex}.calendar-day:hover{border-color:var(--secondary)}.calendar-day.muted{color:#c2c6d6;background:var(--bg);cursor:default}.calendar-day.selected{background:var(--primary);border-color:var(--primary);color:#fff}.calendar-day.today{border-color:var(--secondary)}.calendar-day .dot{background:var(--secondary);border-radius:999px;width:6px;height:6px}.calendar-day.selected .dot{background:#fff}.slot-list{flex-direction:column;gap:.7rem;display:flex}.slot-row{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:#fff;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1rem;transition:border-color .1s,box-shadow .1s;display:flex}.slot-row:hover{border-color:var(--secondary);box-shadow:var(--shadow-sm)}.slot-time{font-size:1.05rem;font-weight:700}.slot-meta{color:var(--muted);font-size:.85rem}.table{border-collapse:collapse;width:100%;font-size:.9rem}.table th,.table td{text-align:left;border-bottom:1px solid var(--border);vertical-align:middle;padding:.6rem .7rem}.table th{color:var(--muted);text-transform:uppercase;letter-spacing:.03em;font-size:.78rem}.table tr:last-child td{border-bottom:none}.table-wrap{overflow-x:auto}.row{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.spread{justify-content:space-between;align-items:center;gap:1rem;display:flex}.muted{color:var(--muted)}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;display:grid}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1.1rem 1.25rem}.stat .value{color:var(--primary);font-size:1.8rem;font-weight:800}.stat .label{color:var(--muted);font-size:.85rem}.center-screen{min-height:60vh;color:var(--muted);place-items:center;display:grid}.modal-backdrop{z-index:50;background:#1a1c2b73;place-items:center;padding:1.5rem;display:grid;position:fixed;top:0;bottom:0;left:0;right:0}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:440px;padding:1.5rem}.week-nav{flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:.6rem;margin-bottom:.9rem;display:flex}.week-nav>.btn{white-space:nowrap;flex:none}.week-nav strong{color:var(--text)}.week-wrap{padding-bottom:.5rem;overflow-x:auto}.week-grid{grid-template-columns:repeat(7,minmax(150px,1fr));gap:.6rem;min-width:760px;display:grid}.week-matrix{min-width:680px}.week-headrow,.week-band-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:.4rem;display:grid}.week-band{margin-top:1.1rem}.week-band-label{text-transform:uppercase;letter-spacing:.04em;color:var(--secondary);background:var(--secondary-100);border-radius:8px;align-items:baseline;gap:.5rem;margin-bottom:.6rem;padding:.4rem .7rem;font-size:.74rem;font-weight:800;display:flex}.week-band-label .week-period-range{margin-top:0;display:inline}.week-band-grid{align-items:start}.week-band-cell{flex-direction:column;gap:.5rem;display:flex}.day-carousel{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;scrollbar-width:none;gap:.6rem;display:flex;overflow-x:auto}.day-carousel::-webkit-scrollbar{display:none}.day-stack{flex-direction:column;gap:1rem;display:flex}.day-stack .day-panel{border-left:4px solid var(--accent);flex:none;padding-left:.75rem}.day-panel .week-slot.ws-past{opacity:.45}.day-panel{scroll-snap-align:start;flex-direction:column;flex:0 0 100%;gap:.6rem;min-width:0;display:flex}.day-panel .week-col-head{text-align:left;background:0 0;border:none;border-radius:0;padding:0 0 .35rem}.day-panel .week-col-head .dnum{text-transform:capitalize;font-size:1.05rem;font-weight:800}.day-panel .week-col-head.is-today{background:0 0}.day-panel .week-col-head.is-today .dnum{color:var(--accent-600)}.week-col{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:.5rem;padding:.5rem;display:flex}.week-col-head{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.35rem .2rem}.week-col-head.is-today{background:var(--accent);border-color:var(--accent-600)}.week-col-head .dow{text-transform:uppercase;letter-spacing:.03em;color:var(--muted);font-size:.72rem;font-weight:700}.week-col-head .dnum{color:var(--text);font-size:1.1rem;font-weight:800}.week-col-head.is-today .dow,.week-col-head.is-today .dnum{color:var(--accent-ink)}.week-period-group{flex-direction:column;gap:.5rem;display:flex}.week-period-group+.week-period-group{border-top:1px dashed var(--border);margin-top:.9rem;padding-top:.9rem}.week-period{text-transform:uppercase;letter-spacing:.04em;color:var(--secondary);background:var(--secondary-100);text-align:center;border-radius:6px;padding:4px 6px;font-size:.68rem;font-weight:800}.week-period-range{letter-spacing:0;text-transform:none;opacity:.85;margin-top:1px;font-size:.62rem;font-weight:600;display:block}.week-slot{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.55rem .6rem;font-size:.82rem}.week-slot .ws-time{font-weight:700}.week-slot .ws-gym{color:var(--muted);margin:.1rem 0}.week-slot .ws-count{font-weight:600}.week-slot .ws-dupr{margin-top:.3rem}.week-slot .ws-action{margin-top:.45rem}.week-slot .btn.block{padding:.4rem .5rem;font-size:.78rem}.week-empty{color:var(--muted);text-align:center;padding:.6rem .2rem;font-size:.8rem}.week-full{color:var(--danger);margin-top:.45rem;font-size:.8rem;font-weight:700;display:inline-block}.player-list{flex-direction:column;gap:.25rem;margin:0;padding-left:1.4rem;display:flex}.player-list li{font-size:.92rem}.hero-banner{object-fit:cover;width:100%;height:220px;display:block}.hero-banner.placeholder{background:var(--secondary-100);height:160px;color:var(--secondary);letter-spacing:.02em;border-bottom:1px solid var(--border);justify-content:center;align-items:center;font-weight:700;display:flex}@media (max-width:640px){.hero-banner{height:130px}.hero-banner.placeholder{height:100px;font-size:.9rem}}.global-banner{background:var(--warn-bg);color:var(--warn);text-align:center;border-bottom:1px solid #f3e2c4;padding:.5rem 1rem;font-size:.85rem}@media (max-width:640px){.form-row{grid-template-columns:1fr}.calendar-day{font-size:.85rem}.slot-row{flex-direction:column;align-items:stretch}.slot-actions{flex-direction:column}.slot-actions .btn{width:100%}.app-header{flex-wrap:wrap;gap:.5rem;padding:.55rem .8rem}.brand{white-space:nowrap;font-size:1.05rem}.header-nav{flex-wrap:nowrap;justify-content:space-between;gap:.3rem;width:100%;overflow-x:auto}.header-nav .btn.sm{white-space:nowrap;padding:.35rem .45rem;font-size:.78rem}.header-user-name{display:none}.header-user-icon{align-items:center;display:inline-flex}.container{padding:1rem .9rem 2.5rem}.card{padding:1rem}.week-nav{flex-wrap:nowrap;gap:.4rem}.week-nav .btn.sm{white-space:nowrap;padding:.4rem .55rem}}
