*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f0f4f8;color:#2c3e50;line-height:1.5}.app{min-height:100vh;max-width:1200px;margin:0 auto;padding:1.5rem}.site-header{text-align:center;padding:1.5rem 0 1rem}.site-title{font-size:1.75rem;font-weight:700;color:#2c3e50;letter-spacing:-.02em;margin-bottom:.25rem}.site-tagline{font-size:.8rem;color:#9aa5b4;font-weight:400}.filter-bar{background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:1rem 1.25rem;display:flex;flex-wrap:wrap;gap:1.25rem;align-items:flex-end;margin-bottom:1.25rem;box-shadow:0 1px 4px #0000000f}.filter-group{display:flex;flex-direction:column;gap:.4rem}.filter-label{font-size:.65rem;font-weight:600;letter-spacing:.08em;color:#9aa5b4;text-transform:uppercase}.date-nav{display:flex;align-items:center;gap:.35rem}.date-nav-btn{width:32px;height:32px;border:1px solid #d0d8e0;border-radius:6px;background:#fff;color:#2c3e50;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;line-height:1}.date-nav-btn:hover:not(:disabled){background:#f0f4f8;border-color:#b0bec5}.date-nav-btn:disabled{opacity:.35;cursor:not-allowed}.date-nav-btn:focus-visible,.filter-btn:focus-visible,.today-btn:focus-visible{outline:2px solid #3dba6e;outline-offset:2px}.date-pill-wrapper{position:relative;display:inline-flex}.date-pill{min-width:108px;text-align:center;height:32px;padding:0 .75rem;border:1px solid #d0d8e0;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:500;color:#2c3e50;background:#fff;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.date-pill:hover{background:#f0f4f8;border-color:#b0bec5}.date-input-hidden{position:absolute;opacity:0;pointer-events:none;width:0;height:0;top:100%;left:0}.today-btn{height:32px;padding:0 .9rem;background:#3dba6e;border:none;border-radius:6px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.today-btn:hover{background:#36a862}.filter-btns{display:flex;gap:.35rem}.filter-btn{height:32px;padding:0 .85rem;border:1px solid #d0d8e0;border-radius:6px;background:#fff;color:#5a6c7d;font-size:.875rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.35rem;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}.filter-btn:hover:not(.filter-btn--active){background:#f0f4f8;border-color:#b0bec5}.filter-btn--active{background:#3dba6e;border-color:#3dba6e;color:#fff}.filter-btn--disabled,.filter-btn:disabled{opacity:.38;cursor:not-allowed;pointer-events:none}.filter-btn-dot{width:7px;height:7px;border-radius:50%;background:#fff;flex-shrink:0}.time-window{display:flex;align-items:center;gap:.35rem}.time-select{height:32px;padding:0 1.6rem 0 .5rem;border:1px solid #d0d8e0;border-radius:6px;background:#fff;color:#2c3e50;font-size:.875rem;font-weight:500;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%239aa5b4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;transition:border-color .15s}.time-select:hover{border-color:#b0bec5}.time-select:focus{outline:2px solid #3dba6e;outline-offset:2px}.time-separator{color:#9aa5b4;font-size:.875rem;line-height:1}.clubs-rows{display:flex;flex-direction:column;gap:.75rem}.club-row{background:#fff;border:1px solid #e0e0e0;border-radius:10px;display:flex;align-items:center;min-height:64px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.club-row-label{width:190px;min-width:190px;padding:1rem 1.25rem;font-size:.9rem;font-weight:600;color:#2c3e50;border-right:1px solid #e8e8e8;line-height:1.3}.club-row-slots{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem;flex:1;align-items:center}.club-row-status{font-size:.875rem;color:#9aa5b4;padding:.25rem 0}.club-row-error{color:#e74c3c}.retry-btn{background:none;border:none;color:#4a90a4;cursor:pointer;font-size:1rem;padding:0 .25rem}.slot-button{padding:.45rem .75rem;background:#fff;border:1px solid #d0d8e0;border-radius:6px;color:#2c3e50;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;text-decoration:none;display:flex;align-items:center;gap:.35rem;white-space:nowrap}.slot-button:hover{background:#e6f7ed;border-color:#3dba6e;color:#2c3e50;transform:translateY(-1px)}.slot-button:active{transform:translateY(0)}.slot-time{font-weight:700;color:#2c3e50}.slot-duration{color:#9aa5b4;font-size:.8rem}.slot-court{color:#b0bec5;font-size:.75rem;font-weight:400;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slot-outdoor-badge{font-size:.65rem;color:#f39c12;letter-spacing:.04em;font-weight:600;flex-shrink:0}.empty-banner{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:.75rem;padding:.9rem 1.25rem;background:#fffbea;border:1px solid #f0d060;border-radius:10px;font-size:.875rem;color:#7a6000}.empty-banner-btn{background:#3dba6e;border:none;border-radius:6px;color:#fff;font-size:.875rem;font-weight:600;padding:.35rem .85rem;cursor:pointer;white-space:nowrap;transition:background .15s}.empty-banner-btn:hover{background:#36a862}.toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:#2c3e50;color:#fff;font-size:.875rem;padding:.65rem 1.25rem;border-radius:8px;box-shadow:0 4px 16px #0000002e;white-space:nowrap;z-index:1000;animation:toast-in .2s ease,toast-out .3s ease 1.9s forwards;pointer-events:none}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toast-out{0%{opacity:1}to{opacity:0}}.site-footer{margin-top:2rem;padding:1rem 0;border-top:1px solid #e0e0e0;text-align:center;font-size:.75rem;color:#9aa5b4}.site-footer a{color:#7fa8b8;text-decoration:none}.site-footer a:hover{text-decoration:underline}@media (max-width: 768px){.app{padding:.75rem}.filter-bar{gap:.9rem;padding:.9rem 1rem}.club-row{flex-direction:column;align-items:flex-start}.club-row-label{width:100%;min-width:unset;border-right:none;border-bottom:1px solid #e8e8e8;padding:.75rem 1rem}.club-row-slots{padding:.75rem 1rem}}
