*{box-sizing:border-box}body{margin:0;background:#f2f1f5;color:#333}.App{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}header{background:#046a3a;border-bottom:2px solid #035a30;padding:20px 0;margin-bottom:0;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:100}.user-name{position:absolute;top:10px;right:20px;font-size:12px;color:#f2f1f5;font-weight:500}.header-content{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}header h1{color:#f2f1f5;margin:0;font-size:28px;display:flex;align-items:center}nav{display:flex;gap:20px;align-items:center}.nav-link{color:#f2f1f5;text-decoration:none;font-weight:600;padding:8px 12px;border-radius:4px;transition:all .2s ease}.nav-link:hover{background:#f2f1f533;color:#fff}.nav-link.admin-link{background:#f2f1f533;color:#f2f1f5;border:1px solid rgba(242,241,245,.4)}.nav-link.admin-link:hover{background:#f2f1f54d;color:#fff;border-color:#f2f1f599}.logout-btn{background:none;border:none;cursor:pointer;padding:8px 12px;border-radius:4px;transition:all .2s ease;color:#f99;font-weight:600}.logout-btn:hover{background:#f993;color:#fff}main{max-width:1200px;margin:0 auto;padding:0 20px;min-height:60vh}.dashboard{text-align:center;padding:60px 20px}.dashboard h2{font-size:32px;margin-bottom:16px;color:#333}.dashboard p{font-size:18px;color:#666;margin-bottom:32px}@media (max-width: 768px){header{padding:12px 0;margin-bottom:20px}.header-content{flex-direction:column;gap:12px}header h1{font-size:20px}nav{width:100%;flex-wrap:wrap;justify-content:center;gap:8px}.nav-link{padding:6px 10px;font-size:13px}.user-name{font-size:11px;top:8px;right:16px}.logout-btn{padding:6px 10px;font-size:13px}.dashboard h2{font-size:24px}.dashboard p{font-size:16px}}@media (max-width: 480px){header{padding:10px 0;margin-bottom:15px}.header-content{padding:0 10px;gap:10px}header h1{font-size:18px}nav{gap:6px}.nav-link{padding:5px 8px;font-size:12px}.user-name{font-size:10px;top:6px;right:10px}.logout-btn{padding:5px 8px;font-size:12px}main{padding:0 10px}}.btn{padding:10px 16px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn-primary{background:#3d2273;color:#fff}.btn-primary:hover:not(:disabled){background:#7b65a2;box-shadow:0 2px 8px #3d22734d}.btn-primary:active:not(:disabled){background:#2a1651}.btn-secondary{background:#6ba68a;color:#fff}.btn-secondary:hover:not(:disabled){background:#559272;box-shadow:0 2px 8px #6ba68a4d}.btn-secondary:active:not(:disabled){background:#467d61}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333;box-shadow:0 2px 8px #dc35454d}.btn-danger:active:not(:disabled){background:#bd2130}.btn-success{background:#046a3a;color:#fff;border:2px solid #035a30}.btn-success:hover:not(:disabled){background:#035a30;box-shadow:0 2px 8px #046a3a4d}.btn-success:active:not(:disabled){background:#024423}.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{padding:12px 24px;font-size:16px}.btn-icon-only{padding:4px 8px;font-size:18px;line-height:1;min-width:28px;width:28px;height:28px;border-radius:4px}@media (max-width: 480px){.btn{padding:8px 12px;font-size:12px}.btn-sm{padding:4px 8px;font-size:11px}.btn-lg{padding:10px 16px;font-size:14px}}.courts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;margin-top:24px}.court-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;transition:all .3s ease}.court-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.court-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;border-bottom:2px solid #f5f5f5;padding-bottom:12px}.court-header h3{margin:0;font-size:18px;color:#333}.surface-info{display:flex;align-items:center;gap:6px}.surface-label{font-size:12px;font-weight:600;color:#666}.surface-badge{background:#046a3a;color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;text-transform:uppercase;font-weight:600}.court-info{margin-bottom:20px}.info-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px}.info-row .label{color:#666;font-weight:600}.info-row .value{color:#333}.court-actions{display:flex;gap:8px}.court-actions button{flex:1}@media (max-width: 768px){.courts-grid{grid-template-columns:1fr}.court-header{align-items:center}.surface-info{gap:4px}.surface-label{font-size:11px}.surface-badge{font-size:11px;padding:3px 10px}}.court-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.court-form{background:#fff;border-radius:8px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0003}.form-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.form-header h3{margin:0;font-size:20px;color:#333}.close-btn{background:none;border:none;font-size:28px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.close-btn:hover{background:#f5f5f5;color:#333}.form-group{margin-bottom:20px}.form-group input,.form-group select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;transition:all .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3d2273;box-shadow:0 0 0 3px #3d22731a}.form-group input.input-error{border-color:#dc3545}.form-group input.input-error:focus{box-shadow:0 0 0 3px #dc35451a}.error-text{display:block;color:#dc3545;font-size:12px;margin-top:4px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;gap:12px;margin-top:28px;padding-top:20px;border-top:1px solid #e0e0e0}.form-actions button{flex:1}@media (max-width: 480px){.court-form{max-width:100%}.form-row{grid-template-columns:1fr}}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.5rem;color:#333}.close-btn{background:none;border:none;font-size:28px;cursor:pointer;color:#666;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.close-btn:hover{background-color:#f0f0f0}form{padding:20px}.form-group label{display:block;margin-bottom:6px;font-weight:600;color:#333;font-size:.95rem}.form-group input{width:100%;padding:10px 12px;border:1px solid #d0d0d0;border-radius:4px;font-size:1rem;font-family:inherit;transition:border-color .2s}.form-group select{width:100%;padding:10px 12px;border:1px solid #d0d0d0;border-radius:4px;font-size:1rem;font-family:inherit;background-color:#fff;color:#333;cursor:pointer;transition:border-color .2s}.form-group select:focus{outline:none;border-color:#3d2273;box-shadow:0 0 0 3px #3d22731a}.form-group select:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.user-info{width:100%;padding:10px 12px;background-color:#f5f5f5;border:1px solid #d0d0d0;border-radius:4px;font-size:1rem;color:#333;font-weight:500}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:4px;margin-bottom:16px;font-size:.95rem;border-left:4px solid #c33}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:16px;border-top:1px solid #e0e0e0}.form-actions button{padding:10px 20px}@media (max-width: 600px){.modal-content{width:95%}.form-row{grid-template-columns:1fr}}.empty-state{text-align:center;padding:40px 20px;color:#999;font-size:.825rem}.reservations-list{display:flex;flex-direction:column;gap:12px}.reservation-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:12px;transition:box-shadow .2s,border-color .2s}.reservation-card:hover{box-shadow:0 2px 8px #0000001a;border-color:#d0d0d0}.reservation-card.status-cancelled{opacity:.6;background-color:#f9f9f9}.reservation-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;gap:12px}.reservation-times{flex:1}.time-range{display:block;font-weight:600;color:#333;font-size:.675rem}.status-badge{padding:6px 12px;border-radius:20px;font-size:.6375rem;font-weight:600;white-space:nowrap}.badge-success{background-color:#e8f5e9;color:#2e7d32}.badge-warning{background-color:#fff3e0;color:#e65100}.badge-danger{background-color:#ffebee;color:#c62828}.badge-default{background-color:#f5f5f5;color:#666}.reservation-details{margin-bottom:10px;padding:8px 0;border-top:1px solid #f0f0f0;border-bottom:1px solid #f0f0f0}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:.6375rem}.detail-row .label{color:#666;font-weight:500}.detail-row .value{color:#333;font-weight:600}.reservation-actions{display:flex;justify-content:flex-end;gap:8px}.reservation-actions .btn{padding:8px 16px;font-size:.675rem}@media (max-width: 600px){.reservation-card{padding:12px;border-radius:6px}.reservation-header{flex-direction:column;gap:8px}.time-range{font-size:.7125rem}.status-badge{width:100%;text-align:center;padding:5px 8px;font-size:.6rem}.reservation-details{padding:10px 0;margin-bottom:10px}.detail-row{flex-direction:column;align-items:flex-start;gap:3px;padding:4px 0;font-size:.675rem}.detail-row .label{font-size:.6375rem}.detail-row .value{font-size:.675rem}.reservation-actions{flex-wrap:wrap;gap:6px;justify-content:flex-start}.reservation-actions .btn{padding:6px 12px;font-size:.6rem;flex:1;min-width:80px}}@media (max-width: 380px){.empty-state{padding:20px 10px;font-size:.7125rem}.reservation-card{padding:10px}.time-range{font-size:.675rem}.status-badge{font-size:.5625rem;padding:4px 6px}.detail-row{font-size:.6375rem}.reservation-actions .btn{padding:5px 10px;font-size:.5625rem;min-width:70px}}.calendar-container{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000000d}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e0e0e0}.calendar-header h3{margin:0;font-size:18px;color:#333;min-width:150px;text-align:center}.calendar-nav-btn{background:none;border:1px solid #d0d0d0;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:16px;color:#333;transition:all .2s}.calendar-nav-btn:hover{background:#f5f5f5;border-color:#999}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:8px}.weekday{text-align:center;font-weight:600;color:#666;font-size:12px;padding:8px 0;text-transform:uppercase}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:20px}.calendar-day{aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;border-radius:4px;font-size:14px;font-weight:600;background:#f9f9f9;border:1px solid #e0e0e0;color:#999}.calendar-day.has-day{cursor:pointer;transition:all .2s}.calendar-day.has-day:hover{filter:brightness(1.1);transform:scale(1.05)}.calendar-day.selected{box-shadow:0 0 0 3px #3d22734d}.calendar-legend{display:flex;gap:24px;justify-content:center;padding-top:16px;border-top:1px solid #e0e0e0}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#666}.legend-color{width:16px;height:16px;border-radius:3px;border:1px solid #999}.calendar-reservations{margin-top:24px;padding-top:24px;border-top:1px solid #e0e0e0}.calendar-reservations h4{margin:0 0 16px;font-size:16px;color:#333}.calendar-reservations .empty-state{text-align:center;padding:40px 20px;color:#999;font-size:14px}@media (max-width: 600px){.calendar-container{padding:16px}.calendar-header h3{min-width:120px;font-size:16px}.calendar-weekdays{gap:4px}.weekday{font-size:10px}.calendar-days{gap:4px}.calendar-day{font-size:12px}.legend-item{font-size:11px}.legend-color{width:14px;height:14px}}.courts-page{padding:20px}.date-section-header{margin-bottom:16px}.date-section-header h3{margin:0;font-size:18px;color:#333;font-weight:600}.section-divider{height:2px;background:#e0e0e0;margin:24px 0;border-radius:1px}.court-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px}.court-section-header h3{margin:0;font-size:18px;color:#333;font-weight:600;flex:1}.court-section-header .btn{white-space:nowrap}.courts-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}.courts-header h2{margin:0 0 8px}.court-location{margin:0;font-size:14px;color:#666;font-weight:400}.reservations-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:24px;margin-top:24px}.reservations-section h3{margin-top:0;margin-bottom:16px;font-size:20px;color:#333}.reservations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:12px}.reservations-header h3{margin:0;flex:1}.reservations-header .btn{white-space:nowrap}@media (max-width: 768px){.courts-page{padding:16px}.date-section-header h3,.court-section-header h3{font-size:16px}.court-section-header,.courts-header{flex-direction:column;align-items:flex-start}}@media (max-width: 480px){.courts-page{padding:12px}.date-section-header h3,.court-section-header h3{font-size:14px}.section-divider{margin:16px 0}}.auth-page{display:flex;align-items:flex-start;justify-content:center;min-height:100vh;background:#f2f1f5;padding:40px 20px 20px}.auth-container{width:100%;max-width:420px;padding:40px 20px;background:#046a3a;border-radius:16px;display:flex;flex-direction:column;align-items:center}.auth-container h1{text-align:center;color:#f2f1f5;margin-bottom:30px;font-size:28px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.auth-box{background:#f2f1f5;border-radius:12px;padding:40px;box-shadow:0 10px 40px #00000026;width:100%}.auth-box h2{margin:0 0 24px;font-size:24px;color:#333;text-align:center}form{margin-bottom:24px}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:14px}.form-group input{width:100%;padding:12px;border:1px solid #d0d0d0;border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#3d2273;box-shadow:0 0 0 3px #3d22731a}.form-group input:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:4px;margin-bottom:20px;font-size:14px;border-left:4px solid #c33}.success-message{background-color:#efe;color:#3c3;padding:12px;border-radius:4px;margin-bottom:20px;font-size:14px;border-left:4px solid #3c3}.btn-block{width:100%;padding:12px;font-size:16px;font-weight:600;margin-top:8px}.auth-footer{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid #e0e0e0}.auth-footer p{margin:0;color:#666;font-size:14px}.auth-footer a{color:#3d2273;text-decoration:none;font-weight:600;transition:color .2s}.auth-footer a:hover{color:#7b65a2}@media (max-width: 480px){.auth-container{padding:10px}.auth-box{padding:24px}.auth-container h1{font-size:24px;margin-bottom:20px}.form-row{grid-template-columns:1fr}}.dashboard-page{padding:20px}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;gap:24px}.header-text h2{margin:0 0 8px;font-size:28px;color:#333}.header-text p{margin:0;color:#666;font-size:16px}.user-stats{display:flex;gap:16px}.stat-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:16px 24px;text-align:center;box-shadow:0 2px 4px #0000000d}.stat-number{font-size:32px;font-weight:700;color:#3d2273;margin-bottom:4px}.stat-label{font-size:12px;color:#666;text-transform:uppercase;font-weight:600}.error-message{background-color:#fee;color:#c33;padding:12px 16px;border-radius:4px;margin-bottom:20px;border-left:4px solid #c33}.filter-section{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}.filter-label{font-weight:600;color:#333}.filter-btn{padding:8px 16px;border:1px solid #d0d0d0;background:#fff;border-radius:4px;cursor:pointer;font-weight:600;color:#333;transition:all .2s}.filter-btn:hover{border-color:#999;background:#f5f5f5}.filter-btn.active{background:#3d2273;color:#fff;border-color:#3d2273}.loading{text-align:center;padding:40px 20px;color:#666;font-size:16px}.empty-state{text-align:center;padding:60px 20px;color:#999}.empty-state p{font-size:16px;margin:0}.reservations-section{margin-bottom:32px}.section-title{font-size:20px;color:#333;margin-bottom:16px;margin-top:0;padding-bottom:12px;border-bottom:2px solid #3D2273}@media (max-width: 768px){.dashboard-page{padding:16px}.dashboard-header{flex-direction:column;margin-bottom:24px}.header-text h2{font-size:24px}.user-stats{width:100%;gap:12px}.stat-card{flex:1;padding:12px 16px}.stat-number{font-size:24px}.filter-section{gap:8px}.filter-btn{padding:6px 12px;font-size:12px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 16px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:20px;color:#333}.close-btn{background:none;border:none;font-size:28px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#333}form{padding:24px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:600;color:#333;font-size:.9rem}.form-group select,.form-group input[type=text],.form-group input[type=date],.form-group input[type=time]{width:100%;padding:10px 12px;border:1px solid #d0d0d0;border-radius:4px;font-size:1rem;font-family:inherit;background-color:#fff;color:#333;transition:border-color .2s}.form-group select:focus,.form-group input:focus{outline:none;border-color:#3d2273;box-shadow:0 0 0 3px #3d22731a}.form-group select:disabled,.form-group input:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.autocomplete-container{position:relative;width:100%}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:#fff;border:1px solid #d0d0d0;border-top:none;border-radius:0 0 4px 4px;list-style:none;margin:0;padding:0;z-index:1001;box-shadow:0 4px 6px #0000001a}.autocomplete-dropdown li{padding:10px 12px;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #f0f0f0;font-size:.9rem}.autocomplete-dropdown li:hover{background-color:#f5f5f5}.autocomplete-dropdown li:last-child{border-bottom:none}.autocomplete-empty{padding:10px 12px;color:#999;font-size:.9rem;text-align:center}.loading-inline{padding:10px 12px;color:#999;font-size:.9rem}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:4px;margin-bottom:16px;font-size:.9rem}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.btn{padding:10px 20px;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-primary{background-color:#3d2273;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2d1a54}.btn-secondary{background-color:#e0e0e0;color:#333}.btn-secondary:hover:not(:disabled){background-color:#d0d0d0}.btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.modal-content{width:95%}.form-row{grid-template-columns:1fr}}.admin-dashboard{max-width:1200px;margin:0 auto;padding:24px}.admin-dashboard h1{font-size:28px;margin-bottom:24px;color:#333}.admin-sections{display:grid;grid-template-columns:1fr;gap:32px;margin-top:24px}.admin-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #f0f0f0}.section-header h2{font-size:20px;margin:0;color:#333}.badge{display:inline-flex;align-items:center;justify-content:center;background-color:#ff6b6b;color:#fff;padding:6px 12px;border-radius:20px;font-weight:600;font-size:14px;min-width:32px}.users-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.user-card{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px;padding:16px;display:flex;flex-direction:column;gap:12px}.user-info{flex:1}.user-card h3{margin:0 0 8px;font-size:16px;color:#333}.user-card .email{margin:4px 0;color:#666;font-size:14px;word-break:break-all}.user-card .phone{margin:4px 0;color:#666;font-size:14px}.user-card .created-at{margin:8px 0 0;color:#999;font-size:12px}.user-actions{display:flex;gap:8px;padding-top:8px;border-top:1px solid #e0e0e0}.user-actions .btn{flex:1}.empty-state,.loading{text-align:center;padding:32px;color:#999;font-size:14px}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse;font-size:14px}.users-table thead{background-color:#f5f5f5;border-bottom:2px solid #e0e0e0}.users-table th{padding:12px 16px;text-align:left;font-weight:600;color:#333;white-space:nowrap}.users-table tbody tr{border-bottom:1px solid #e0e0e0;transition:background-color .2s}.users-table tbody tr:hover{background-color:#f9f9f9}.users-table td{padding:12px 16px;color:#666}.users-table th:nth-child(5),.users-table th:nth-child(6),.users-table td:nth-child(5),.users-table td:nth-child(6){text-align:center}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:4px;font-weight:600;font-size:12px;white-space:nowrap}.status-approved{background-color:#d4edda;color:#155724}.status-pending{background-color:#fff3cd;color:#856404}.status-rejected{background-color:#f8d7da;color:#721c24}.status-admin{background-color:#e8e3f4;color:#3d2273}.view-toggle{display:flex;gap:12px}.toggle-btn{padding:10px 20px;border:2px solid #e0e0e0;background:#fff;color:#666;border-radius:6px;cursor:pointer;font-weight:600;font-size:14px;transition:all .2s}.toggle-btn:hover{border-color:#7b65a2;color:#7b65a2}.toggle-btn.active{background:#3d2273;color:#fff;border-color:#3d2273}.reservations-table-container{overflow-x:auto}.reservations-table{width:100%;border-collapse:collapse;font-size:14px}.reservations-table thead{background-color:#f5f5f5;border-bottom:2px solid #e0e0e0}.reservations-table th{padding:12px 16px;text-align:left;font-weight:600;color:#333;white-space:nowrap}.reservations-table tbody tr{border-bottom:1px solid #e0e0e0;transition:background-color .2s}.reservations-table tbody tr:hover{background-color:#f9f9f9}.reservations-table td{padding:12px 16px;color:#666}@media (max-width: 768px){.admin-dashboard{padding:16px}.admin-dashboard h1{font-size:22px}.admin-sections{gap:20px}.admin-section{padding:16px}.section-header{align-items:flex-start;gap:8px}.section-header .view-toggle{flex-direction:column;width:100%}.section-header h2{font-size:18px}.view-toggle{width:100%;flex-direction:column}.toggle-btn{width:100%;padding:10px 16px}.users-list{grid-template-columns:1fr;gap:12px}.user-card{padding:12px}.user-actions{flex-direction:column}.user-actions .btn{width:100%;font-size:12px;padding:8px 12px}.users-table{font-size:12px}.users-table th,.users-table td{padding:8px 12px}.users-table th{font-size:11px}.reservations-table{font-size:12px}.reservations-table th,.reservations-table td{padding:8px 12px}.reservations-table th{font-size:11px}}@media (max-width: 480px){.admin-dashboard{padding:12px}.admin-dashboard h1{font-size:20px;margin-bottom:16px}.admin-sections{gap:16px}.admin-section{padding:12px;border-radius:6px}.section-header{margin-bottom:16px;padding-bottom:12px;gap:6px}.section-header h2{font-size:16px}.badge{padding:4px 8px;font-size:12px;min-width:28px}.users-list{gap:10px}.user-card{padding:10px;gap:8px}.user-card h3{font-size:14px;margin-bottom:6px}.user-card .email,.user-card .phone{font-size:13px}.user-card .created-at{font-size:11px}.user-actions{flex-direction:column;gap:6px;padding-top:6px}.user-actions .btn{padding:6px 10px;font-size:11px}.empty-state,.loading{padding:20px;font-size:13px}.users-table{font-size:10px}.users-table th{padding:4px 5px;font-size:9px}.users-table td{padding:4px 5px;font-size:10px}.users-table th,.users-table td{font-size:8px;padding:3px 2px}.users-table th:nth-child(3),.users-table th:nth-child(4),.users-table td:nth-child(3),.users-table td:nth-child(4){display:none}.status-badge{padding:2px 4px;font-size:9px}.view-toggle{flex-direction:column}.toggle-btn{width:100%;padding:8px 12px;font-size:12px}.reservations-table{font-size:10px}.reservations-table th{padding:4px 5px;font-size:9px}.reservations-table td{padding:4px 5px;font-size:10px}}@media (max-width: 360px){.users-table{font-size:9px}.users-table th{padding:3px 4px;font-size:8px}.users-table td{padding:3px 4px;font-size:9px}.status-badge{padding:2px 3px;font-size:8px}.admin-section{padding:8px}.section-header h2{font-size:14px}.user-card h3{font-size:12px}.user-card .email,.user-card .phone{font-size:11px}}.date-card{flex:1;min-width:100px;padding:0 14px;border:2px solid;border-radius:12px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;display:flex;align-items:center;justify-content:center;height:100%;white-space:nowrap;box-sizing:border-box}.date-card:hover{transform:translateY(-2px);filter:brightness(1.1)}@media (max-width: 768px){.date-selector-container{gap:4px;margin-bottom:16px;height:80px}.date-selector{gap:4px}.date-card{padding:0 10px;font-size:.7rem;min-width:80px}.date-nav-btn{padding:6px 8px;min-width:40px;height:80px;max-height:48px;align-self:center;font-size:1rem}}@media (max-width: 480px){.date-selector-container{gap:2px;margin-bottom:12px;height:72px}.date-selector{gap:2px}.date-card{padding:0 8px;font-size:.65rem;min-width:75px}.date-nav-btn{padding:4px 6px;min-width:36px;height:72px;max-height:48px;align-self:center;font-size:.9rem}}.reservations-by-date-page{max-width:1200px;margin:0 auto;padding:24px}.reservations-by-date-page h1{font-size:20px;margin-bottom:24px;color:#333;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.error-message{background-color:#ffebee;color:#c62828;padding:12px 16px;border-radius:4px;margin-bottom:16px;border-left:4px solid #c62828}.loading{text-align:center;padding:60px 20px;color:#999;font-size:16px}.empty-state{text-align:center;padding:60px 20px;color:#999;font-size:16px;background:#f9f9f9;border-radius:8px;border:1px dashed #e0e0e0}.court-section{margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid #e0e0e0}.court-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.court-section h2{font-size:20px;margin-bottom:20px;color:#333;font-weight:600}@media (max-width: 768px){.reservations-by-date-page{padding:16px}.reservations-by-date-page h1{font-size:18px;margin-bottom:16px}.court-section{margin-bottom:24px;padding-bottom:16px}.court-section h2{font-size:18px;margin-bottom:16px}}@media (max-width: 480px){.reservations-by-date-page{padding:12px}.reservations-by-date-page h1{font-size:16px;margin-bottom:12px}.court-section{margin-bottom:16px;padding-bottom:12px}.court-section h2{font-size:16px}.loading,.empty-state{padding:40px 16px;font-size:14px}}.calendar-page{padding:24px;max-width:1400px;margin:0 auto}.calendar-page h1{margin:0 0 24px;font-size:28px;color:#333}.calendar-page .error-message{background-color:#ffebee;color:#c62828;padding:12px 16px;border-radius:4px;margin-bottom:24px;border-left:4px solid #c62828}.calendar-page .loading{text-align:center;padding:40px 20px;color:#666;font-size:16px}.date-selector-container{display:flex;align-items:center;gap:8px;margin-bottom:24px;height:88px;box-sizing:border-box}.date-selector{display:flex;gap:8px;flex:1;height:100%;box-sizing:border-box}.date-card{flex:1;min-width:100px;padding:0 14px;border:2px solid #7B65A2;border-radius:12px;background-color:#fff;color:#333;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;display:flex;align-items:center;justify-content:center;height:100%;white-space:nowrap;box-sizing:border-box}.date-nav-btn{background:transparent;border:2px solid #e0e0e0;border-radius:4px;padding:8px 10px;cursor:pointer;font-size:1.2rem;color:#333;transition:all .2s;min-width:44px;height:88px;max-height:48px;display:flex;align-items:center;justify-content:center;align-self:center;box-sizing:border-box}.date-nav-btn:hover{border-color:#7b65a2;color:#7b65a2;background-color:#f9f9f9}.date-card:hover{border-color:#7b65a2;background-color:#f9f9f9;transform:translateY(-2px)}.date-card.selected{background-color:#3d2273;color:#fff;border-color:#3d2273}.availability-grid-container{overflow-x:auto;border:1px solid #e0e0e0;border-radius:8px;margin-top:24px}.availability-grid{display:grid;gap:0;padding:0;background:#fff;width:100%}.grid-row{display:contents}.grid-cell{padding:12px;font-size:.9rem;display:flex;align-items:center;justify-content:center;min-height:50px}.header-row .grid-cell{background-color:transparent;font-weight:600;color:#333}.time-header{border-right:none}.court-header{font-size:.95rem;text-align:center}.time-cell{background-color:transparent;font-weight:500;color:#555;border-right:none;font-size:.85rem}.status-cell{text-align:center;transition:all .2s;cursor:pointer;margin:4px;border-radius:8px;position:relative}.status-cell.status-available{background-color:#e8f5e9;border:2px solid #046A3A}.status-cell.status-available:hover{background-color:#d4edda;transform:scale(1.05)}.status-cell.status-pending{background-color:#fff9e6;border:2px solid #f0ad4e}.status-cell.status-pending:hover{background-color:#ffe8b3}.status-cell.status-confirmed{background-color:#ffebee;border:2px solid #c62828}.status-cell.status-confirmed:hover{background-color:#ffcdd2}.book-btn{background-color:transparent;color:#046a3a;border:none;padding:6px 12px;border-radius:4px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.85rem}.book-btn:hover{background-color:#046a3a1a;transform:scale(1.05)}.book-btn:active{transform:scale(.98)}.status-label{font-weight:600;font-size:.85rem}.status-cell.status-pending .status-label{color:#f0ad4e}.status-cell.status-confirmed .status-label{color:#c62828}@media (max-width: 1200px){.grid-cell{padding:8px;min-height:42px;font-size:.75rem}.court-header{font-size:.8rem}.time-cell{font-size:.7rem}.book-btn{padding:3px 6px;font-size:.7rem}.date-card{padding:0 12px;font-size:.75rem;min-width:95px;height:100%}}@media (max-width: 768px){.calendar-page{padding:10px}.calendar-page h1{font-size:22px;margin-bottom:12px}.date-selector-container{gap:4px;margin-bottom:16px;height:80px}.date-selector{gap:4px}.date-card{padding:0 10px;font-size:.7rem;min-width:80px;height:100%}.date-nav-btn{padding:6px 8px;min-width:40px;height:80px;max-height:48px;align-self:center;font-size:1rem}.availability-grid{grid-template-columns:42px repeat(4,1fr)}.grid-cell{padding:6px;min-height:38px;font-size:.7rem}.book-btn{padding:2px 4px;font-size:.65rem}.court-header{font-size:.75rem}.time-cell{font-size:.65rem}.date-card{padding:0 8px;font-size:.65rem;min-width:90px}}@media (max-width: 480px){.calendar-page{padding:8px}.calendar-page h1{font-size:18px;margin-bottom:8px}.date-selector-container{gap:2px;margin-bottom:12px;height:72px}.date-selector{gap:2px}.date-card{padding:0 8px;font-size:.65rem;min-width:75px;height:100%}.date-nav-btn{padding:4px 6px;min-width:36px;height:72px;max-height:48px;align-self:center;font-size:.9rem}.availability-grid{grid-template-columns:38px repeat(4,1fr)}.grid-cell{padding:4px;min-height:32px;font-size:.65rem}.time-cell{font-size:.6rem}.court-header{font-size:.65rem}.book-btn{padding:1px 3px;font-size:.6rem}.status-label{font-size:.6rem}.date-card{padding:0 6px;font-size:.6rem;min-width:70px;height:100%}}.reservation-action-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);padding:20px}.action-container{width:100%;max-width:500px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;overflow:hidden}.action-content{padding:60px 40px;text-align:center}.action-content h1{font-size:28px;margin:20px 0;color:#333}.action-content p{font-size:16px;color:#666;margin-bottom:30px;line-height:1.5}.spinner{width:50px;height:50px;margin:0 auto 20px;border:4px solid #f3f3f3;border-top:4px solid #3D2273;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.action-content.success{background:linear-gradient(135deg,#f0f9ff,#f5f5f5)}.action-content.success h1{color:#046a3a}.success-icon{width:80px;height:80px;margin:0 auto;background:#046a3a;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700}.action-content.error{background:linear-gradient(135deg,#fff5f5,#f5f5f5)}.action-content.error h1{color:#c62828}.error-icon{width:80px;height:80px;margin:0 auto;background:#c62828;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700}.action-links{margin-top:30px;display:flex;gap:12px;justify-content:center}.action-links .btn{padding:12px 32px;font-size:16px;text-decoration:none;border-radius:6px;transition:all .2s;display:inline-block}.action-links .btn-primary{background:#046a3a;color:#fff;border:2px solid #046A3A}.action-links .btn-primary:hover{background:#035a30;border-color:#035a30;transform:translateY(-2px);box-shadow:0 4px 12px #046a3a4d}@media (max-width: 480px){.action-container{border-radius:8px}.action-content{padding:40px 20px}.action-content h1{font-size:22px}.action-content p{font-size:14px}.success-icon,.error-icon{width:60px;height:60px;font-size:36px}.action-links{flex-direction:column}.action-links .btn{width:100%}}:root{color:#ffffffde;background-color:#242424}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
