:root{--primary: #276B2F;--primary-dark: #1B5221;--primary-light: #3A8C3A;--primary-bg: #EDF7EE;--primary-mid: #4CAF52;--danger: #E53935;--success: #2E7D32;--warning: #F59E0B;--text: #111827;--text-secondary: #374151;--text-muted: #6B7280;--text-faint: #9CA3AF;--bg: #F4F6F9;--card: #FFFFFF;--border: #E5E9EF;--border-light: #F0F3F7;--shadow-xs: 0 1px 3px rgba(0,0,0,.06);--shadow-sm: 0 2px 8px rgba(0,0,0,.07);--shadow-md: 0 4px 16px rgba(0,0,0,.09);--shadow-lg: 0 8px 32px rgba(0,0,0,.12);--radius-xs: 6px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 24px;--radius-full: 9999px;--header-height: 60px;--bottom-nav-height: 68px;--touch-min: 44px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none}button,input,select,textarea{font-family:inherit}.navbar{background:var(--primary);color:#fff;position:sticky;top:0;z-index:100;box-shadow:0 1px #ffffff14,0 4px 16px #0000002e}.navbar-inner{max-width:1200px;margin:0 auto;padding:0 20px;height:var(--header-height);display:flex;align-items:center;justify-content:space-between}.navbar-brand{color:#fff;font-size:1.15rem;font-weight:800;letter-spacing:-.02em;display:flex;align-items:center;gap:8px}.navbar-links{display:flex;align-items:center;gap:4px}.navbar-links a{color:#fffc;font-size:.875rem;font-weight:500;padding:8px 14px;border-radius:var(--radius-sm);transition:background .15s,color .15s}.navbar-links a:hover{background:#ffffff1f;color:#fff}.navbar-admin-link{background:#ffffff1a!important;color:#fff!important}.navbar-user{color:#ffffff8c;font-size:.8rem;padding:0 8px}.navbar-links button{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#ffffffd9;padding:8px 14px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s;min-height:var(--touch-min)}.navbar-links button:hover{background:#fff3;border-color:transparent}@media(max-width:768px){.navbar{position:fixed;top:0;left:0;right:0}.navbar-inner{height:56px;padding:0 16px}.navbar-links a:not(.navbar-admin-link){display:none}.navbar-user{display:none}}.bottom-nav{display:none}@media(max-width:768px){.bottom-nav{display:block;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);z-index:100;padding-bottom:env(safe-area-inset-bottom,0px)}.bottom-nav-content{display:flex;justify-content:space-around;height:var(--bottom-nav-height)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-faint);font-size:.68rem;font-weight:600;text-decoration:none;padding:8px 4px;transition:color .15s;letter-spacing:.01em}.bottom-nav-item svg{width:22px;height:22px}.bottom-nav-item.active{color:var(--primary)}.bottom-nav-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:2px;background:var(--primary);border-radius:0 0 2px 2px}}.container{max-width:1200px;margin:0 auto;padding:28px 20px}@media(max-width:768px){.container{padding:72px 16px 16px;padding-bottom:calc(var(--bottom-nav-height) + 16px)}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.auth-card{background:#fff;width:100%;max-width:400px;padding:44px 36px;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid var(--border-light)}.auth-card h1{text-align:center;color:var(--primary);font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin-bottom:6px}.auth-card h2{text-align:center;color:var(--text-muted);font-size:.9rem;font-weight:400;margin-bottom:32px;line-height:1.5}.auth-form{display:flex;flex-direction:column}.auth-form .form-group{margin-bottom:18px}.auth-form label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:7px;letter-spacing:.01em}.auth-form input{width:100%;padding:13px 15px;border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:.95rem;color:var(--text);background:#fff;transition:border-color .15s,box-shadow .15s;min-height:var(--touch-min)}.auth-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #276b2f1a}.auth-form input::placeholder{color:var(--text-faint)}.auth-form .btn-submit{width:100%;margin-top:8px;padding:14px;border:none;border-radius:var(--radius-md);background:var(--primary);color:#fff;font-size:.95rem;font-weight:700;letter-spacing:.01em;cursor:pointer;box-shadow:0 4px 12px #276b2f4d;transition:background .15s,box-shadow .15s,transform .1s;min-height:var(--touch-min)}.auth-form .btn-submit:hover{background:var(--primary-dark);box-shadow:0 6px 16px #276b2f59;border-color:transparent}.auth-form .btn-submit:active{transform:scale(.98)}.auth-form .btn-submit:disabled{opacity:.55;cursor:not-allowed}.auth-link{text-align:center;margin-top:24px;font-size:.875rem;color:var(--text-muted)}.auth-link a{color:var(--primary);font-weight:600}.error{color:var(--danger);font-size:.82rem;margin-top:6px;font-weight:500}@media(max-width:768px){.auth-container{align-items:flex-start;padding-top:48px}.auth-card{padding:32px 24px}}.home .page-header{margin-bottom:28px}.home .page-header h1{font-size:1.6rem;font-weight:800;color:var(--text);letter-spacing:-.03em}.home .page-header p{font-size:.9rem;color:var(--text-muted);margin-top:5px}.modality-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.modality-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 20px;text-align:left;cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s;box-shadow:var(--shadow-xs);position:relative;overflow:hidden}.modality-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary);opacity:0;transition:opacity .15s}.modality-card:hover{border-color:#c8ddb0;transform:translateY(-2px);box-shadow:var(--shadow-md)}.modality-card:hover:before{opacity:1}.modality-card:active{transform:scale(.99)}.modality-card h2{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:5px;letter-spacing:-.01em}.modality-card p{color:var(--text-muted);font-size:.83rem;margin-bottom:14px;line-height:1.5}.modality-card .court-count{display:inline-block;font-size:.75rem;color:var(--primary);font-weight:700;background:var(--primary-bg);padding:3px 10px;border-radius:var(--radius-full);letter-spacing:.01em}@media(max-width:768px){.modality-grid{grid-template-columns:1fr 1fr;gap:10px}.modality-card{padding:16px 14px}.home .page-header h1{font-size:1.4rem}}.bk-page{margin:-16px;padding-bottom:32px}@media(min-width:769px){.bk-page{margin:-28px}}.bk-header{display:flex;align-items:center;gap:10px;padding:14px 16px 10px}.bk-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;cursor:pointer;color:var(--text);padding:0;flex-shrink:0;border-radius:var(--radius-sm);transition:background .12s}.bk-back-btn:hover{background:#0000000d;border-color:transparent}.bk-header-title{font-size:1.05rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.bk-modality-scroll{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:2px 16px 6px}.bk-modality-scroll::-webkit-scrollbar{display:none}.bk-modality-tabs{display:flex;gap:8px;min-width:max-content}.bk-modality-tab{padding:9px 20px;border-radius:var(--radius-full);font-size:.8rem;font-weight:700;letter-spacing:.04em;cursor:pointer;white-space:nowrap;border:1.5px solid var(--border);background:#fff;color:var(--text-muted);transition:all .12s;min-height:40px}.bk-modality-tab:hover{border-color:var(--primary-light);color:var(--primary)}.bk-modality-tab.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px #276b2f4d}.bk-date-scroll{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:8px 16px 14px;border-bottom:1px solid var(--border-light)}.bk-date-scroll::-webkit-scrollbar{display:none}.bk-date-strip{display:flex;gap:7px;min-width:max-content}.bk-date-card{display:flex;flex-direction:column;align-items:center;justify-content:center;width:58px;padding:9px 4px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:#fff;cursor:pointer;transition:all .12s;gap:1px}.bk-date-card:hover{border-color:#b8d4a0}.bk-date-card.active{background:var(--primary);border-color:var(--primary);box-shadow:0 2px 10px #276b2f47}.bk-date-name{font-size:.67rem;font-weight:600;text-transform:capitalize;color:var(--text-muted);letter-spacing:.02em}.bk-date-num{font-size:1.35rem;font-weight:800;color:var(--text);line-height:1.1}.bk-date-month{font-size:.63rem;text-transform:capitalize;color:var(--text-muted)}.bk-date-card.active .bk-date-name,.bk-date-card.active .bk-date-num,.bk-date-card.active .bk-date-month{color:#fff}.bk-courts{display:flex;flex-direction:column;gap:12px;padding:14px 16px}.bk-court-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-xs);overflow:hidden}.bk-court-name{display:flex;align-items:center;gap:8px;padding:13px 15px 9px;font-size:.82rem;font-weight:700;color:var(--text);letter-spacing:.04em}.bk-court-name svg{color:var(--text-faint);flex-shrink:0}.bk-time-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:0 12px 13px}.bk-time-cell{position:relative;display:flex;align-items:center;justify-content:center;height:50px;border-radius:var(--radius-sm);cursor:pointer;border:1.5px solid var(--border-light);background:var(--bg);transition:all .12s}.bk-time-cell.avail{border-color:#c3dba8;background:#fff}.bk-time-cell.avail:hover{border-color:var(--primary);background:var(--primary-bg);box-shadow:0 2px 8px #276b2f24;transform:translateY(-1px)}.bk-time-cell.avail:active{transform:scale(.97)}.bk-time-cell.unavail{border-color:transparent;background:var(--bg);cursor:default}.bk-time-cell:disabled{cursor:default}.bk-avail-dot{position:absolute;top:5px;right:5px;width:5px;height:5px;border-radius:1px;background:var(--primary-light)}.bk-time-label{font-size:.875rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.bk-time-cell.unavail .bk-time-label{color:#c8cdd6;font-weight:400}.bk-no-slots{padding:8px 15px 13px;font-size:.83rem;color:var(--text-faint);font-style:italic}.bk-slots-loading{height:50px;margin:0 12px 13px;background:linear-gradient(90deg,#f0f2f5 25%,#e8eaed,#f0f2f5 75%);background-size:200% 100%;animation:shimmer 1.2s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{to{background-position:-200% 0}}.bk-modal-overlay{position:fixed;inset:0;background:#0006;z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(min-width:500px){.bk-modal-overlay{align-items:center}}.bk-modal{background:#fff;border-radius:22px 22px 0 0;width:100%;max-width:480px;box-shadow:0 -4px 32px #00000026;overflow:hidden;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@media(min-width:500px){.bk-modal{border-radius:22px;margin:16px;animation:fadeIn .15s ease}}.bk-modal-top{display:flex;align-items:center;justify-content:space-between;padding:22px 20px 8px}.bk-modal-court{font-size:1.05rem;font-weight:700;color:var(--text);margin:0;letter-spacing:-.01em}.bk-modal-close{width:30px;height:30px;border-radius:50%;background:var(--bg);border:none;cursor:pointer;font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:background .12s;font-weight:600}.bk-modal-close:hover{background:var(--border);border-color:transparent}.bk-modal-body{padding:8px 20px 10px;display:flex;flex-direction:column;gap:12px}.bk-modal-section-label{font-size:.78rem;color:var(--text-muted);margin:0;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.bk-option-card{position:relative;overflow:hidden;width:100%;padding:16px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:#fff;font-size:.95rem;font-weight:600;color:var(--text);cursor:pointer;text-align:center;transition:all .12s;display:flex;flex-direction:column;align-items:center;gap:3px}.bk-option-card small{font-size:.75rem;font-weight:500;color:var(--text-muted)}.bk-option-card:hover{border-color:var(--primary-light)}.bk-option-card.selected{background:var(--primary-bg);border-color:var(--primary)}.bk-option-card.selected:before{content:"";position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 32px 32px 0;border-color:transparent var(--primary) transparent transparent}.bk-option-card.selected:after{content:"✓";position:absolute;top:3px;right:5px;color:#fff;font-size:.62rem;font-weight:900}.bk-hours-row{display:flex;gap:10px}.bk-hours-row .bk-option-card{flex:1}.bk-modal-footer{padding:10px 20px 22px}.bk-modal-confirm{width:100%;padding:17px;border:none;border-radius:var(--radius-md);background:var(--primary);color:#fff;font-size:.95rem;font-weight:800;letter-spacing:.07em;cursor:pointer;transition:background .15s;min-height:54px}.bk-modal-confirm:hover{background:var(--primary-dark);border-color:transparent}.bk-modal-confirm:disabled{opacity:.55;cursor:not-allowed}.bk-confirmation-wrap{display:flex;align-items:center;justify-content:center;min-height:60vh}.booking-confirmation{max-width:420px;width:100%;margin:0 auto;background:#fff;border-radius:var(--radius-xl);padding:48px 32px;text-align:center;box-shadow:var(--shadow-lg);border:1px solid var(--border-light)}.confirmation-icon{font-size:2.8rem;color:var(--success);margin-bottom:14px}.booking-confirmation h2{font-size:1.35rem;font-weight:800;color:var(--text);margin-bottom:6px;letter-spacing:-.02em}.confirmation-time{font-size:1.1rem;font-weight:600;color:var(--primary);margin-bottom:12px!important}.booking-confirmation p{color:var(--text-muted);line-height:1.6;margin-bottom:24px;font-size:.9rem}.btn-pay-mp{display:inline-block;background:#009ee3;color:#fff;padding:14px 32px;border-radius:var(--radius-md);font-size:.95rem;font-weight:700;box-shadow:0 4px 14px #009ee34d;transition:all .15s}.btn-pay-mp:hover{background:#0083c3;color:#fff;transform:translateY(-1px)}.reservations .page-header{margin-bottom:24px}.reservations .page-header h1{font-size:1.5rem;font-weight:800;color:var(--text);letter-spacing:-.02em}.reservation-list{display:flex;flex-direction:column;gap:10px}.reservation-card{background:#fff;border-radius:var(--radius-lg);padding:18px 20px;display:flex;justify-content:space-between;align-items:flex-start;gap:16px;box-shadow:var(--shadow-xs);border:1px solid var(--border);transition:box-shadow .15s}.reservation-card:hover{box-shadow:var(--shadow-sm)}.reservation-info{display:flex;flex-direction:column;gap:3px}.reservation-info strong{font-size:.95rem;font-weight:700;color:var(--text)}.reservation-info span{color:var(--text-muted);font-size:.83rem}.reservation-status{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.status-badge{font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:var(--radius-full);background:#eef4ff;color:#3b6fd4;letter-spacing:.01em}.payment-badge{font-size:.72rem;padding:4px 10px;border-radius:var(--radius-full);background:var(--border-light);color:var(--text-muted);font-weight:500}.pay-btn{background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:7px 14px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.pay-btn:hover{background:var(--primary-dark);border-color:transparent}.status-confirmed .status-badge{background:#ecfdf5;color:#15803d}.status-cancelled .status-badge{background:#fff1f1;color:#c62828}@media(max-width:600px){.reservation-card{flex-direction:column}.reservation-status{align-items:flex-start;flex-direction:row;flex-wrap:wrap}}.al-layout{display:flex;height:100vh;overflow:hidden;background:var(--bg)}.al-sidebar{width:240px;flex-shrink:0;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0}.al-brand{display:flex;align-items:center;gap:10px;padding:22px 20px 18px;border-bottom:1px solid var(--border-light)}.al-brand-icon{width:32px;height:32px;border-radius:8px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:800}.al-brand span{font-size:.95rem;font-weight:700;color:var(--text)}.al-nav{display:flex;flex-direction:column;gap:2px;padding:14px 12px;flex:1}.al-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:background .12s,color .12s}.al-nav-item:hover{background:var(--bg);color:var(--text)}.al-nav-item.active{background:var(--primary);color:#fff}.al-nav-item.active svg{opacity:1}.al-nav-item svg{opacity:.7;flex-shrink:0}.al-bottom{border-top:1px solid var(--border-light);padding:12px;display:flex;flex-direction:column;gap:2px}.al-user{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm)}.al-user-avatar{width:30px;height:30px;border-radius:50%;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}.al-user-info{display:flex;flex-direction:column;min-width:0}.al-user-name{font-size:.8rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.al-user-role{font-size:.72rem;color:var(--text-muted)}.al-logout{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--text-muted);background:none;border:none;cursor:pointer;width:100%;text-align:left;transition:background .12s,color .12s}.al-logout:hover{background:#fff1f1;color:var(--danger)}.al-content{flex:1;overflow-y:auto;padding:32px 28px}@media(max-width:768px){.al-layout{flex-direction:column;height:100dvh}.al-sidebar{width:100%;flex-direction:row;align-items:center;border-right:none;border-bottom:1px solid var(--border);padding:0;height:auto}.al-brand{padding:12px 16px;border-bottom:none}.al-nav{flex-direction:row;padding:8px;flex:1;gap:2px}.al-nav-item span{display:none}.al-nav-item{padding:10px;justify-content:center}.al-bottom{flex-direction:row;border-top:none;padding:8px}.al-user-info,.al-user-name,.al-user-role,.al-logout span{display:none}.al-user{padding:10px}.al-logout{padding:10px;justify-content:center}.al-content{padding:16px}}.admin-page-title{font-size:1.4rem;font-weight:800;color:var(--text);margin-bottom:24px;letter-spacing:-.02em}.admin-card{background:#fff;border-radius:var(--radius-lg);padding:22px;margin-bottom:18px;box-shadow:var(--shadow-xs);border:1px solid var(--border)}.admin-card h2{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:16px}.admin-hint{font-size:.83rem;color:var(--text-muted);margin-bottom:16px;line-height:1.55}.admin-actions-bar{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.admin-filters{display:flex;gap:10px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.admin-filters select,.admin-filters input[type=date]{padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:.875rem;background:#fff;color:var(--text);min-height:var(--touch-min)}.admin-filters select:focus,.admin-filters input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #276b2f14}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:20px;border-top:3px solid;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:5px;border:1px solid var(--border);border-top-width:3px}.stat-value{font-size:2rem;font-weight:900;line-height:1;letter-spacing:-.03em}.stat-label{font-size:.78rem;color:var(--text-muted);font-weight:500;margin-top:2px}.form-row{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:16px}.form-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:160px}.form-group label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.form-group input,.form-group select{padding:11px 13px;border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:.9rem;color:var(--text);background:#fff;min-height:var(--touch-min);transition:border-color .15s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #276b2f14}.form-message{padding:10px 14px;border-radius:var(--radius-md);font-size:.875rem;margin-bottom:12px;font-weight:500}.form-message.success{background:#ecfdf5;color:#15803d;border:1px solid #BBF7D0}.form-message.error{background:#fff1f1;color:#c62828;border:1px solid #FECACA}.field-warning{font-size:.78rem;color:#b45309;background:#fffbeb;border:1px solid #FDE68A;padding:4px 8px;border-radius:6px;margin-top:4px;display:block}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--primary);color:#fff;border:none;padding:11px 22px;border-radius:var(--radius-md);font-size:.9rem;font-weight:700;cursor:pointer;box-shadow:0 2px 8px #276b2f40;transition:all .12s;min-height:var(--touch-min);letter-spacing:.01em}.btn-primary:hover{background:var(--primary-dark);box-shadow:0 4px 14px #276b2f4d;border-color:transparent}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#fff;color:var(--text-secondary);border:1.5px solid var(--border);padding:11px 22px;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .12s;min-height:var(--touch-min)}.btn-secondary:hover{background:var(--bg);border-color:#c8cdd6}.btn-clear{background:none;border:none;color:var(--danger);font-size:.875rem;cursor:pointer;padding:8px;min-height:var(--touch-min);font-weight:600}.btn-danger-sm{display:inline-flex;align-items:center;gap:4px;background:#fff1f1;color:var(--danger);border:1.5px solid #FECACA;padding:6px 12px;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .12s}.btn-danger-sm:hover{background:#ffe4e4;border-color:var(--danger)}.btn-danger-sm:disabled{opacity:.5;cursor:not-allowed}.btn-block{background:#fffbeb;color:#92400e;border:1.5px solid #FDE68A;padding:6px 12px;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .12s}.btn-block:hover{background:#fef3c7;border-color:#f59e0b}.btn-unblock{background:#ecfdf5;color:#15803d;border:1.5px solid #BBF7D0;padding:6px 12px;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .12s}.btn-unblock:hover{background:#d1fae5;border-color:#34d399}.slots-table{display:flex;flex-direction:column;gap:5px}.slot-row{display:flex;align-items:center;gap:12px;padding:10px 13px;border-radius:var(--radius-sm);background:var(--bg);flex-wrap:wrap;border:1px solid var(--border-light)}.slot-row.slot-reserved{background:#fffbeb;border-color:#fde68a}.slot-row.slot-blocked{background:#fff1f1;border-color:#fecaca}.slot-time{font-weight:700;min-width:110px;font-size:.875rem;font-variant-numeric:tabular-nums}.slot-price{color:var(--primary);font-weight:600;min-width:80px;font-size:.83rem}.slot-user{color:var(--primary);font-size:.83rem;flex:1}.slot-status-badge{font-size:.7rem;padding:3px 9px;border-radius:var(--radius-full);font-weight:600}.slot-status-badge.slot-available{background:#ecfdf5;color:#15803d}.slot-status-badge.slot-reserved{background:#fffbeb;color:#92400e}.slot-status-badge.slot-blocked{background:#fff1f1;color:#c62828}.admin-table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);border:1px solid var(--border)}.admin-table{width:100%;border-collapse:collapse;background:#fff;font-size:.875rem}.admin-table th{background:var(--bg);padding:12px 16px;text-align:left;font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-weight:700;border-bottom:1px solid var(--border)}.admin-table td{padding:13px 16px;border-bottom:1px solid var(--border-light);vertical-align:middle}.admin-table tbody tr:hover{background:#fafbfc}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tr.row-cancelled td{opacity:.45}.member-name{display:block;font-weight:600;color:var(--text);font-size:.875rem}.member-email,.court-name{display:block;font-size:.75rem;color:var(--text-muted);margin-top:1px}.badge-pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600}.badge-pending{background:#eef4ff;color:#3b6fd4}.badge-confirmed{background:#ecfdf5;color:#15803d}.badge-cancelled{background:#fff1f1;color:#c62828}.badge-pay-pending{background:#fffbeb;color:#92400e}.badge-pay-approved{background:#ecfdf5;color:#15803d}.badge-pay-rejected{background:#fff1f1;color:#c62828}.badge-pay-cancelled{background:var(--border-light);color:var(--text-muted)}.modality-header{margin-bottom:14px}.modality-header p{color:var(--text-muted);font-size:.83rem;margin-top:4px}.table-actions{text-align:right;white-space:nowrap;width:1%}.text-muted{color:var(--text-muted)}.btn-icon-danger{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--danger, #e53e3e);cursor:pointer;transition:background .15s}.btn-icon-danger:hover{background:#fff1f1}.btn-icon-danger:disabled{opacity:.4;cursor:not-allowed}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-muted);font-size:.9rem}.loading:before{content:"";width:32px;height:32px;border:2.5px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .75s linear infinite;margin-bottom:14px}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{color:var(--text-faint);font-size:.875rem;text-align:center;padding:36px}
