:root{--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--font-display:"Outfit", sans-serif;--bg-main:#090b0e;--bg-card:#11161da6;--bg-card-hover:#161d26cc;--border-color:#ffffff0d;--border-glow:#22c55e26;--color-primary:#22c55e;--color-primary-hover:#4ade80;--color-primary-glow:#22c55e40;--color-danger:#ef4444;--color-danger-hover:#f87171;--color-danger-glow:#ef444433;--color-warning:#f59e0b;--color-info:#3b82f6;--text-white:#fff;--text-muted:#94a3b8;--text-dim:#64748b;--shadow-lg:0 10px 30px -10px #000000b3;--shadow-neon:0 0 20px #22c55e33;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1)}body.light-mode{--bg-main:#f3f4f6;--bg-card:#fffc;--bg-card-hover:#fffffff2;--border-color:#00000014;--border-glow:#22c55e33;--color-primary:#15803d;--color-primary-hover:#166534;--color-primary-glow:#22c55e26;--color-danger:#dc2626;--color-danger-hover:#991b1b;--text-white:#111827;--text-muted:#4b5563;--text-dim:#9ca3af;--shadow-lg:0 10px 25px -5px #0000000d, 0 8px 10px -6px #0000000d;--shadow-neon:0 0 15px #22c55e1a;background-image:radial-gradient(circle at 10% 20%,#22c55e05 0%,#0000 40%),radial-gradient(circle at 90% 80%,#3b82f605 0%,#0000 40%)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-white);font-family:var(--font-sans);background-image:radial-gradient(circle at 10% 20%,#22c55e08 0%,#0000 40%),radial-gradient(circle at 90% 80%,#3b82f608 0%,#0000 40%);background-attachment:fixed;min-height:100vh;overflow-x:hidden}.app-container{min-height:100vh;display:flex}.sidebar{border-right:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10;background:#0b0f14e6;flex-direction:column;width:280px;height:100vh;padding:2rem 1.5rem;transition:width .3s cubic-bezier(.4,0,.2,1),padding .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed}.sidebar.collapsed{width:80px;padding:2rem .75rem}.sidebar.collapsed .logo-text,.sidebar.collapsed .admin-info,.sidebar.collapsed .quick-access-card p,.sidebar.collapsed .quick-access-card div span:last-child,.sidebar.collapsed .menu-item-btn span:last-child,.sidebar.collapsed .btn-sidebar-logout .logout-text{display:none!important}.sidebar.collapsed .logo-container{justify-content:center;padding-left:0}.sidebar.collapsed .menu-item-btn{justify-content:center;gap:0;padding:1rem 0}.sidebar.collapsed .sidebar-footer{justify-content:center;padding-left:0;padding-right:0}.sidebar.collapsed .btn-sidebar-logout{border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;padding:0;font-size:1.1rem;display:flex}.sidebar.collapsed .theme-toggle-btn{border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;display:flex;padding:0!important}.sidebar.collapsed .quick-access-card{justify-content:center;align-items:center;display:flex;margin:15px 4px!important;padding:8px!important}.sidebar.collapsed .quick-access-card div{margin-bottom:0!important}.logo-container{align-items:center;gap:.75rem;margin-bottom:3rem;padding-left:.5rem;display:flex}.logo-icon{filter:drop-shadow(0 0 8px var(--color-primary));font-size:2rem}.logo-text{font-family:var(--font-display);letter-spacing:2px;background:linear-gradient(135deg, var(--text-white) 30%, var(--color-primary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.5rem;font-weight:800}.sidebar-menu{flex-direction:column;gap:.5rem;list-style:none;display:flex}.menu-item-btn{width:100%;color:var(--text-muted);cursor:pointer;transition:var(--transition-smooth);text-align:left;background:0 0;border:none;border-radius:12px;align-items:center;gap:1rem;padding:1rem 1.25rem;font-size:.95rem;font-weight:500;display:flex}.menu-item-btn:hover{color:var(--text-white);background:#ffffff08}.menu-item-btn.active{background:var(--color-primary-glow);color:var(--color-primary);border:1px solid var(--border-glow);box-shadow:var(--shadow-neon)}.menu-icon{font-size:1.2rem}.sidebar-footer{border-top:1px solid var(--border-color);align-items:center;gap:.75rem;margin-top:auto;padding-top:2rem;display:flex}.admin-avatar{background:var(--color-primary);color:#000;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-size:1rem;font-weight:700;display:flex}.admin-info h4{font-size:.9rem;font-weight:600}.admin-info p{color:var(--text-muted);font-size:.75rem}body.light-mode{color:#1f2937}body.light-mode .menu-item-btn.active{color:#15803d;background:#22c55e1f;border-color:#22c55e4d}body.light-mode .quick-access-card{border:1px solid #15803d26!important}body.light-mode .date-input{color:#111827;background:#fff;border:1px solid #00000026}body.light-mode .activity-item{background:#fff!important;border-color:#0000000d!important}body.light-mode .table-card{box-shadow:0 4px 20px #00000005}body.light-mode .stat-card{box-shadow:0 4px 15px #00000005}.main-content{flex:1;min-height:100vh;margin-left:280px;padding:2.5rem 3rem;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.main-content.collapsed{margin-left:80px}.content-header{justify-content:space-between;align-items:center;margin-bottom:2.5rem;display:flex}.header-title h1{font-family:var(--font-display);letter-spacing:-.5px;font-size:2.2rem;font-weight:800}.header-title p{color:var(--text-muted);margin-top:.25rem;font-size:.95rem}.header-actions{align-items:center;gap:1rem;display:flex}.btn-primary{background:var(--color-primary);color:#0b0f19;cursor:pointer;transition:var(--transition-smooth);border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;display:flex}.btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 0 15px #22c55e66}.btn-secondary{color:var(--text-white);border:1px solid var(--border-color);cursor:pointer;transition:var(--transition-smooth);background:#ffffff0d;border-radius:10px;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500}.btn-secondary:hover{background:#ffffff1a}.analytics-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2.5rem;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:var(--transition-smooth);border-radius:16px;flex-direction:column;justify-content:space-between;height:130px;padding:1.5rem;display:flex}.stat-card:hover{background:var(--bg-card-hover);box-shadow:var(--shadow-lg);border-color:#ffffff1a;transform:translateY(-2px)}.stat-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;font-size:.85rem;font-weight:500;display:flex}.stat-icon{opacity:.8;font-size:1.5rem}.stat-body{justify-content:space-between;align-items:baseline;margin-top:1rem;display:flex}.stat-number{font-family:var(--font-display);font-size:2rem;font-weight:700}.stat-change{border-radius:6px;padding:.25rem .5rem;font-size:.8rem;font-weight:600}.stat-change.positive{color:var(--color-primary);background:#22c55e1a}.stat-change.neutral{color:var(--text-muted);background:#94a3b81a}.court-matrix-card{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;margin-bottom:2.5rem;padding:2rem}.matrix-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.matrix-legend{gap:1.5rem;font-size:.85rem;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:.5rem;display:flex}.legend-color{border-radius:3px;width:12px;height:12px}.legend-color.available{border:1px solid var(--border-color);background:#ffffff08}.legend-color.booked{background:var(--color-primary-glow);border:1px solid var(--color-primary)}.legend-color.blocked{border:1px solid var(--color-danger);background:#ef444426}.date-selector-row{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.date-input{border:1px solid var(--border-color);color:var(--text-white);background:#11151d;border-radius:8px;outline:none;padding:.6rem 1rem;font-family:inherit;font-size:.9rem}.matrix-grid-scroll{padding-bottom:1rem;overflow-x:auto}.modern-scheduler{border-collapse:separate;border-spacing:12px;width:100%;min-width:900px}.modern-scheduler th{text-align:left;color:var(--text-muted);border-bottom:2px solid var(--border-color);padding:.75rem .5rem;font-size:.9rem;font-weight:600}.modern-scheduler th:first-child{text-align:center;width:95px}.modern-scheduler td{border-bottom:none;padding:0}.scheduler-court-header{border:1px solid var(--border-color);background:#ffffff05;border-radius:8px;align-items:center;gap:10px;padding:.5rem .75rem;display:flex}.scheduler-court-header .court-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.court-name-wrap{flex-direction:column;display:flex}.court-name-wrap .court-name{color:var(--text-white);font-size:.9rem;font-weight:700;line-height:1.2}.court-name-wrap .court-surface{color:var(--text-dim);margin-top:2px;font-size:.7rem}.scheduler-time-cell{text-align:center}.scheduler-time-cell .time-label{font-family:var(--font-display);color:var(--text-white);border:1px solid var(--border-color);text-align:center;background:#ffffff0a;border-radius:8px;min-width:75px;padding:6px 12px;font-size:1.05rem;font-weight:700;display:inline-block}.scheduler-slot-cell{min-height:108px;transition:var(--transition-smooth);cursor:pointer;border:1px solid #0000;border-radius:12px;flex-direction:column;justify-content:center;padding:10px 12px;display:flex}.scheduler-slot-cell.available{background:#ffffff03;border:1px dashed #ffffff0f}.scheduler-slot-cell.available:hover{border-color:var(--color-primary);background:#22c55e0d;box-shadow:0 0 10px #22c55e1a}.scheduler-slot-cell.available .empty-card{height:100%;color:var(--text-dim);justify-content:center;align-items:center;gap:8px;font-size:.85rem;font-weight:600;display:flex}.scheduler-slot-cell.available:hover .empty-card{color:var(--color-primary-hover)}.scheduler-slot-cell.available .plus-icon{font-size:1.1rem;transition:transform .2s}.scheduler-slot-cell.available:hover .plus-icon{transform:rotate(90deg)}.scheduler-card{flex-direction:column;gap:3px;width:100%;display:flex}.scheduler-slot-cell.booked.singles{color:#93c5fd;background:#3b82f626;border:1px solid #3b82f680}.scheduler-slot-cell.booked.singles:hover{background:#3b82f640;box-shadow:0 0 15px #3b82f633}.scheduler-slot-cell.booked.doubles{color:#d8b4fe;background:#a855f726;border:1px solid #a855f780}.scheduler-slot-cell.booked.doubles:hover{background:#a855f740;box-shadow:0 0 15px #a855f733}.scheduler-slot-cell.booked.training{color:#a7f3d0;background:#10b98126;border:1px solid #10b98180}.scheduler-slot-cell.booked.training:hover{background:#10b98140;box-shadow:0 0 15px #10b98133}.scheduler-slot-cell.booked.lesson{color:#fecdd3;background:#f43f5e26;border:1px solid #f43f5e80}.scheduler-slot-cell.booked.lesson:hover{background:#f43f5e40;box-shadow:0 0 15px #f43f5e33}.scheduler-slot-cell.booked.course{color:#c5f2f7;background:#06b6d426;border:1px solid #06b6d480}.scheduler-slot-cell.booked.course:hover{background:#06b6d440;box-shadow:0 0 15px #06b6d433}.scheduler-slot-cell.booked.custom{color:#fde68a;background:#f59e0b26;border:1px solid #f59e0b80}.scheduler-slot-cell.booked.custom:hover{background:#f59e0b40;box-shadow:0 0 15px #f59e0b33}.scheduler-slot-cell.booked.league_match{color:#fed7aa;background:#fb923c26;border:1px solid #fb923c80}.scheduler-slot-cell.booked.league_match:hover{background:#fb923c40;box-shadow:0 0 15px #fb923c33}.scheduler-slot-cell.booked.member_match{color:#93c5fd;background:#3b82f626;border:1px solid #3b82f680}.scheduler-slot-cell.booked.member_match:hover{background:#3b82f640;box-shadow:0 0 15px #3b82f633}.scheduler-slot-cell.pending{color:#fde047;background:#eab3081f;border:1px solid #eab30880}.scheduler-slot-cell.pending:hover{background:#eab30833;box-shadow:0 0 15px #eab30833}.scheduler-slot-cell.blocked{color:#cbd5e1;background:#94a3b80f;border:1px solid #94a3b84d}.scheduler-slot-cell.blocked:hover{background:#94a3b81f}.scheduler-card .card-time{opacity:.6;font-size:.65rem;font-weight:500}.scheduler-card .card-title{font-size:.85rem;font-weight:700;line-height:1.2}.scheduler-card .card-meta{opacity:.7;text-transform:uppercase;letter-spacing:.5px;font-size:.65rem;font-weight:600}.scheduler-card .card-players{color:#fff;text-overflow:ellipsis;white-space:nowrap;margin-top:4px;font-size:.75rem;font-weight:600;overflow:hidden}.scheduler-card .card-player2{opacity:.85;white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;font-weight:600;line-height:1.2;overflow:hidden}.scheduler-card .card-league{opacity:.75;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:.62rem;font-weight:700;overflow:hidden}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:#11161f;border:1px solid #ffffff1a;border-radius:20px;width:500px;max-width:90%;padding:2rem;animation:.3s ease-out modalFadeIn;box-shadow:0 20px 40px #000c}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-card h3{font-family:var(--font-display);margin-bottom:1.5rem;font-size:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-muted);margin-bottom:.5rem;font-size:.85rem;font-weight:500;display:block}.form-control{border:1px solid var(--border-color);width:100%;color:var(--text-white);transition:var(--transition-smooth);background:#090c10;border-radius:8px;outline:none;padding:.75rem 1rem;font-family:inherit;font-size:.95rem}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 10px #22c55e26}.modal-actions{justify-content:flex-end;gap:1rem;margin-top:2rem;display:flex}.dashboard-grid{grid-template-columns:1.7fr 1fr;gap:2rem;margin-bottom:2.5rem;display:grid}.dashboard-card-title{font-family:var(--font-display);margin-bottom:1.5rem;font-size:1.25rem;font-weight:700}.table-card{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;margin-bottom:2.5rem;padding:2rem}.custom-table-container{overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%}.custom-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);padding:1rem;font-size:.85rem;font-weight:600}.custom-table td{border-bottom:1px solid var(--border-color);padding:1rem;font-size:.95rem}.custom-table tr:hover td{background:#ffffff03}.player-cell{align-items:center;gap:.75rem;display:flex}.player-img-placeholder{width:36px;height:36px;color:var(--color-primary);background:#1b222c;border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.badge{border-radius:6px;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-green{color:var(--color-primary-hover);background:#22c55e26}.badge-danger{color:var(--color-danger-hover);background:#ef444426}.badge-warning{color:#fbbf24;background:#f59e0b26}.action-buttons{gap:.5rem;display:flex}.btn-icon{color:var(--text-muted);cursor:pointer;width:32px;height:32px;transition:var(--transition-smooth);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.btn-icon:hover{color:var(--text-white);background:#ffffff0d}.btn-icon.delete:hover{background:var(--color-danger-glow);color:var(--color-danger)}.search-bar-row{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.search-input-wrapper{flex:1;max-width:400px;position:relative}.search-input{border:1px solid var(--border-color);width:100%;color:var(--text-white);background:#11151d;border-radius:8px;outline:none;padding:.6rem 1rem;font-size:.9rem}.activity-card{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;height:100%;padding:2rem}.activity-list{flex-direction:column;gap:1.25rem;max-height:480px;padding-right:.5rem;display:flex;overflow-y:auto}.activity-item{border-bottom:1px solid var(--border-color);gap:1rem;padding-bottom:1rem;display:flex}.activity-item:last-child{border-bottom:none;padding-bottom:0}.activity-icon-wrap{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.activity-icon-wrap.result{color:var(--color-primary);background:#22c55e1a}.activity-icon-wrap.announcement{color:var(--color-warning);background:#f59e0b1a}.activity-icon-wrap.ranking{color:var(--color-info);background:#3b82f61a}.activity-info h5{margin-bottom:.15rem;font-size:.9rem;font-weight:600}.activity-info p{color:var(--text-muted);font-size:.8rem;line-height:1.4}.activity-time{color:var(--text-dim);margin-top:.25rem;font-size:.7rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#0000001a}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:100vh;display:flex}.spinner{border:3px solid #ffffff0d;border-top-color:var(--color-primary);width:50px;height:50px;box-shadow:var(--shadow-neon);border-radius:50%;animation:1s ease-in-out infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-family:var(--font-display);color:var(--text-muted);letter-spacing:1px;font-size:1.2rem}@media (width<=1200px){.analytics-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}}@media (width<=768px){.app-container{flex-direction:column}.sidebar{width:100%;height:auto;padding:1.5rem;position:relative}.main-content{margin-left:0;padding:1.5rem}}.court-subtab-row{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.subtab-pill{border:1.5px solid var(--border-color);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:24px;align-items:center;gap:6px;padding:.5rem 1.2rem;font-size:.85rem;font-weight:500;transition:all .18s;display:flex}.subtab-pill:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-glow)}.subtab-pill.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600}.pill-badge{color:inherit;background:#ffffff40;border-radius:10px;padding:1px 7px;font-size:.75rem;font-weight:700}.subtab-pill.active .pill-badge{background:#0003}.court-map-section{margin-bottom:2rem}.court-map-header{color:var(--text-white);background:#22c55e0f;border:1px solid #22c55e26;border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:.95rem;font-weight:600;display:flex}.map-header-hint{color:var(--text-dim);font-size:.78rem;font-weight:400}.court-map-wrapper{width:100%;position:relative}.court-map-canvas{border:1px solid var(--border-color);background:#0d1117;border-radius:0 0 16px 16px;width:100%;min-height:500px;position:relative;overflow:hidden}.court-map-grid{pointer-events:none;position:absolute;inset:0}.court-map-empty{color:var(--text-dim);flex-direction:column;justify-content:center;align-items:center;gap:1rem;font-size:1.1rem;display:flex;position:absolute;inset:0}.court-map-node{cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);-webkit-user-select:none;user-select:none;background:#0d1117eb;border:2px solid #22c55e;border-radius:14px;width:148px;transition:all .2s;position:absolute;overflow:hidden}.court-map-node:hover{transform:translateY(-2px)scale(1.02)}.court-map-node.selected{z-index:10;transform:translateY(-3px)scale(1.04)}.court-map-node.inactive{opacity:.45;filter:grayscale(.7)}.court-node-color-bar{width:100%;height:4px}.court-node-body{padding:10px 12px}.court-node-name{color:var(--text-white);white-space:nowrap;text-overflow:ellipsis;margin-bottom:6px;font-size:.85rem;font-weight:700;overflow:hidden}.court-node-meta{flex-wrap:wrap;gap:6px;margin-bottom:6px;display:flex}.court-type-badge{border-radius:10px;padding:2px 8px;font-size:.68rem;font-weight:600}.court-rate-badge{color:var(--text-dim);margin-left:auto;font-size:.68rem}.court-node-status{color:var(--text-dim);align-items:center;gap:5px;display:flex}.node-status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.node-status-dot.online{background:#22c55e;box-shadow:0 0 4px #22c55e}.node-status-dot.offline{background:#ef4444}.node-booking-count{color:#22c55e;background:#22c55e26;border-radius:8px;margin-left:auto;padding:1px 6px;font-size:.68rem;font-weight:600}.court-detail-panel{z-index:20;background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:16px;width:280px;animation:.2s slideInRight;position:absolute;top:1rem;right:1rem;overflow:hidden;box-shadow:0 8px 32px #0006}@keyframes slideInRight{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.court-detail-header{border-bottom:1px solid var(--border-color);border-left:4px solid #22c55e;align-items:flex-start;gap:10px;padding:1.2rem;display:flex}.court-detail-color{border-radius:50%;flex-shrink:0;width:12px;height:12px;margin-top:5px}.court-detail-header h3{color:var(--text-white);margin:0 0 2px;font-size:1rem}.close-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;margin-left:auto;padding:2px 6px;font-size:1.1rem}.close-btn:hover{color:var(--text-white);background:#ffffff14}.court-detail-body{flex-direction:column;gap:.6rem;padding:1rem;display:flex}.court-detail-row{color:var(--text-muted);justify-content:space-between;align-items:center;font-size:.88rem;display:flex}.court-detail-row strong{color:var(--text-white)}.text-success{color:#22c55e!important}.text-danger{color:#ef4444!important}.court-detail-desc{color:var(--text-dim);background:#ffffff08;border-radius:8px;padding:8px 10px;font-size:.82rem;line-height:1.5}.court-features-list{flex-wrap:wrap;gap:6px;display:flex}.feature-chip{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e33;border-radius:12px;padding:3px 10px;font-size:.75rem}.court-detail-stats{grid-template-columns:repeat(3,1fr);gap:8px;margin:.25rem 0;display:grid}.cstat-mini{text-align:center;background:#ffffff0a;border-radius:10px;padding:8px}.cstat-mini span{color:var(--text-white);font-size:1.2rem;font-weight:700;display:block}.cstat-mini label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:.65rem}.court-detail-actions{gap:8px;margin-top:.25rem;display:flex}.court-list-section{margin-bottom:2rem}.court-cards-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;display:grid}.court-list-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:18px;transition:all .2s;overflow:hidden}.court-list-card:hover{border-color:#22c55e4d;transform:translateY(-2px);box-shadow:0 8px 32px #0000004d}.court-card-top{padding:1.25rem;position:relative}.court-card-accent{border-radius:0;width:4px;position:absolute;top:0;bottom:0;left:0}.court-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;padding-left:.5rem;display:flex}.court-card-name{color:var(--text-white);margin:0 0 4px;font-size:1.05rem;font-weight:700}.court-card-tags{flex-wrap:wrap;gap:6px;display:flex}.tag-type,.tag-surface{color:var(--text-dim);background:#ffffff0f;border-radius:10px;padding:2px 8px;font-size:.72rem;font-weight:500}.court-status-pill{border-radius:12px;flex-shrink:0;padding:3px 10px;font-size:.72rem;font-weight:600}.court-status-pill.active{color:#22c55e;background:#22c55e26;border:1px solid #22c55e40}.court-status-pill.inactive{color:#ef4444;background:#ef44441f;border:1px solid #ef444433}.court-card-stats{flex-wrap:wrap;gap:1rem;padding-left:.5rem;display:flex}.cstat{color:var(--text-muted);align-items:center;gap:5px;font-size:.82rem;display:flex}.court-card-features{border-top:1px solid var(--border-color);flex-wrap:wrap;gap:6px;padding:.75rem 1.25rem;display:flex}.feature-chip-sm{color:#22c55e;background:#22c55e14;border:1px solid #22c55e26;border-radius:10px;padding:2px 8px;font-size:.7rem}.court-card-desc{color:var(--text-dim);border-top:1px solid var(--border-color);margin:0;padding:.5rem 1.25rem;font-size:.82rem;line-height:1.5}.court-card-actions{border-top:1px solid var(--border-color);gap:.5rem;padding:.75rem 1.25rem;display:flex}.requests-section{margin-bottom:2rem}.requests-list{flex-direction:column;gap:.75rem;margin-top:1rem;display:flex}.request-item{background:#eab3080a;border:1.5px solid #eab30840;border-radius:14px;align-items:flex-start;gap:1rem;padding:1rem 1.25rem;transition:all .15s;display:flex}.request-item.confirmed{background:#ffffff05;border-color:#ffffff0f}.request-avatar{color:#eab308;background:#eab30833;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:700;display:flex}.request-info{flex:1;min-width:0}.request-name{color:var(--text-white);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;font-size:.95rem;font-weight:600;display:flex}.request-details{color:var(--text-muted);flex-wrap:wrap;gap:1rem;margin-bottom:4px;font-size:.82rem;display:flex}.request-note{color:var(--text-dim);font-size:.82rem;font-style:italic}.request-actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.response-note-input{border:1px solid var(--border-color);color:var(--text-white);background:#ffffff0d;border-radius:8px;width:180px;padding:5px 10px;font-family:inherit;font-size:.8rem}.btn-approve{color:#22c55e;cursor:pointer;white-space:nowrap;background:#22c55e26;border:1.5px solid #22c55e4d;border-radius:10px;padding:6px 14px;font-size:.82rem;font-weight:600;transition:all .15s}.btn-approve:hover{background:#22c55e47}.btn-reject{color:#ef4444;cursor:pointer;white-space:nowrap;background:#ef44441f;border:1.5px solid #ef444440;border-radius:10px;padding:6px 14px;font-size:.82rem;font-weight:600;transition:all .15s}.btn-reject:hover{background:#ef444438}.mini-badge{border-radius:10px;padding:2px 8px;font-size:.72rem;font-weight:600}.mini-badge.confirmed{color:#22c55e;background:#22c55e26}.mini-badge.rejected{color:#ef4444;background:#ef44441f}.btn-danger-sm{color:#ef4444;cursor:pointer;white-space:nowrap;background:#ef44441f;border:1.5px solid #ef444433;border-radius:10px;padding:6px 12px;font-size:.82rem;transition:all .15s}.btn-danger-sm:hover{background:#ef444438}.empty-state{color:var(--text-dim);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 2rem;font-size:1rem;display:flex}.modal-wide{max-height:90vh;overflow-y:auto}.settings-grid{grid-template-columns:1fr 1fr;align-items:start;gap:1.5rem;display:grid}@media (width<=1000px){.settings-grid{grid-template-columns:1fr}}.settings-card{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:1.75rem}.settings-card-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.settings-card-header h3{color:var(--text-white);margin:0 0 .3rem;font-size:1.05rem;font-weight:700}.settings-card-header p{color:var(--text-dim);margin:0;font-size:.82rem}.settings-slot-count{text-align:center;background:#22c55e1a;border:1.5px solid #22c55e33;border-radius:12px;flex-shrink:0;min-width:56px;padding:.6rem 1rem}.settings-slot-count span{color:var(--color-primary);font-size:1.5rem;font-weight:800;line-height:1;display:block}.settings-slot-count label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:.68rem}.slots-list{flex-direction:column;gap:.5rem;max-height:360px;margin-bottom:1.5rem;padding-right:4px;display:flex;overflow-y:auto}.slot-item{border:1px solid var(--border-color);background:#ffffff08;border-radius:10px;align-items:center;gap:.75rem;padding:.65rem 1rem;transition:all .15s;display:flex}.slot-item:hover{background:#22c55e0a;border-color:#22c55e33}.slot-edit-inputs-inline{flex:1;align-items:center;gap:.5rem;display:flex}.inline-time-input{border:1px solid var(--border-color)!important;color:var(--text-white)!important;background:#ffffff0d!important;border-radius:6px!important;width:75px!important;height:28px!important;padding:2px 6px!important;font-size:.85rem!important}.inline-save-btn,.inline-cancel-btn{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;font-size:1rem;transition:opacity .15s;display:flex}.inline-save-btn{color:#22c55e}.inline-cancel-btn{color:#ef4444}.inline-save-btn:hover,.inline-cancel-btn:hover{opacity:.8}.slot-edit-icon{opacity:0;cursor:pointer;margin-left:.5rem;font-size:.8rem;transition:opacity .15s}.slot-item:hover .slot-edit-icon{opacity:.6}.slot-item:hover .slot-edit-icon:hover{opacity:1}.slot-index{width:22px;height:22px;color:var(--color-primary);background:#22c55e1f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex}.slot-time{color:var(--text-white);font-size:.95rem;font-weight:600;font-family:var(--font-mono,monospace);flex:1}.slot-duration{color:var(--text-dim);background:#ffffff0d;border-radius:8px;padding:2px 8px;font-size:.72rem}.slot-delete-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:.85rem;transition:all .15s;display:flex}.slot-delete-btn:hover{color:#ef4444;background:#ef444426}.slots-empty{text-align:center;color:var(--text-dim);border:1.5px dashed var(--border-color);border-radius:10px;padding:2rem;font-size:.9rem}.slot-add-row{border-top:1px solid var(--border-color);margin-bottom:1.25rem;padding-top:1.25rem}.slot-add-inputs{flex-wrap:wrap;align-items:flex-end;gap:.75rem;display:flex}.slot-input-group{flex-direction:column;gap:4px;display:flex}.slot-input-group label{color:var(--text-dim);font-size:.75rem;font-weight:500}.slot-time-input{width:120px!important;padding:.45rem .75rem!important;font-size:.9rem!important}.slot-dash{color:var(--text-dim);padding-bottom:6px;font-size:1.2rem}.slot-preview{color:var(--text-muted);background:#22c55e0f;border:1px solid #22c55e26;border-radius:8px;margin-top:.75rem;padding:.5rem .75rem;font-size:.85rem}.settings-save-row{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.settings-saved-badge{color:var(--color-primary);font-size:.85rem;font-weight:600;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.settings-info-box{color:var(--text-muted);background:#6366f114;border:1px solid #6366f133;border-radius:10px;padding:1rem;font-size:.85rem;line-height:1.6}.settings-info-box code{color:#a5b4fc;background:#ffffff14;border-radius:4px;padding:1px 6px;font-size:.82rem}.slot-preview-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.6rem;display:grid}.slot-preview-chip{border:1px solid var(--border-color);color:var(--text-muted);background:#ffffff0a;border-radius:10px;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.82rem;transition:all .15s;display:flex}.slot-preview-chip:hover{color:var(--text-white);background:#22c55e0a;border-color:#22c55e33}.slot-preview-num{width:18px;height:18px;color:var(--color-primary);background:#22c55e26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.65rem;font-weight:700;display:flex}.portal-container{color:#fff;background:radial-gradient(circle,#0e1224 0%,#070913 100%);justify-content:center;align-items:center;min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;display:flex;position:relative;overflow:hidden}.portal-bg-overlay{opacity:.8;z-index:1;background-image:radial-gradient(#a855f714 1px,#0000 1px),radial-gradient(#22c55e0d 1px,#0000 1px);background-position:0 0,20px 20px;background-size:40px 40px;position:absolute;inset:0}.portal-card-wrapper{z-index:2;text-align:center;width:90%;max-width:900px;position:relative}.portal-header{margin-bottom:3rem;animation:.6s ease-out fadeInDown}.portal-logo-icon{filter:drop-shadow(0 0 15px #22c55e4d);margin-bottom:.5rem;font-size:3.5rem;animation:3s ease-in-out infinite float;display:inline-block}.portal-title{letter-spacing:.15em;background:linear-gradient(135deg,#fff 40%,#a855f7 70%,#22c55e 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-size:3rem;font-weight:800}.portal-subtitle{color:var(--text-dim);margin-top:.5rem;font-size:1.1rem}.portal-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-top:1rem;animation:.6s ease-out .2s both fadeInUp;display:grid}.portal-option-card{cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff05;border:1px solid #ffffff0d;border-radius:24px;flex-direction:column;align-items:center;padding:3rem 2.5rem;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;position:relative;overflow:hidden}.portal-option-card:before{content:"";background:radial-gradient(800px circle at var(--x,0px) var(--y,0px), #ffffff0f, transparent 40%);z-index:1;opacity:0;transition:opacity .5s;position:absolute;inset:0}.portal-option-card:hover:before{opacity:1}.portal-option-card:hover{background:#ffffff0a;transform:translateY(-8px)}.portal-option-card.club:hover{border-color:#22c55e4d;box-shadow:0 10px 40px #22c55e1a}.portal-option-card.saas:hover{border-color:#a855f74d;box-shadow:0 10px 40px #a855f71a}.portal-option-icon{margin-bottom:1.5rem;font-size:3.5rem;transition:transform .3s}.portal-option-card:hover .portal-option-icon{transform:scale(1.1)rotate(5deg)}.portal-option-title{margin:0 0 1rem;font-size:1.6rem;font-weight:700}.portal-option-desc{color:var(--text-dim);flex-grow:1;margin:0 0 2rem;font-size:.95rem;line-height:1.6}.portal-option-btn{color:#fff;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:12px;width:100%;padding:.75rem 2rem;font-weight:600;transition:all .3s}.portal-option-card.club:hover .portal-option-btn{background:var(--color-primary);border-color:var(--color-primary);color:#0b0f19;box-shadow:0 0 15px #22c55e66}.portal-option-card.saas:hover .portal-option-btn{color:#fff;background:#a855f7;border-color:#a855f7;box-shadow:0 0 15px #a855f766}.login-page{justify-content:center;align-items:center;width:100vw;min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;display:flex;position:relative;overflow:hidden}.login-page.club-theme{background:radial-gradient(circle,#0a1122 0%,#05070f 100%)}.login-page.saas-theme{background:radial-gradient(circle,#0f0a1d 0%,#06040b 100%)}.login-bg-overlay{opacity:.4;z-index:1;background-size:20px 20px;position:absolute;inset:0}.login-page.club-theme .login-bg-overlay{background-image:radial-gradient(#22c55e0a 1px,#0000 1px)}.login-page.saas-theme .login-bg-overlay{background-image:radial-gradient(#a855f70d 1px,#0000 1px)}.login-card{z-index:2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff03;border:1px solid #ffffff0d;border-radius:28px;width:100%;max-width:440px;padding:3rem 2.5rem;animation:.5s cubic-bezier(.16,1,.3,1) scaleUp;position:relative;box-shadow:0 20px 50px #00000080}.login-page.club-theme .login-card{border-color:#22c55e26;box-shadow:0 0 40px #22c55e08,0 20px 50px #00000080}.login-page.saas-theme .login-card{border-color:#a855f726;box-shadow:0 0 40px #a855f708,0 20px 50px #00000080}.login-header{text-align:center;margin-bottom:2rem}.login-logo{margin-bottom:1rem;font-size:3rem}.login-page.club-theme .login-logo{filter:drop-shadow(0 0 10px #22c55e66)}.login-page.saas-theme .login-logo{filter:drop-shadow(0 0 10px #a855f766)}.login-header h2{color:#fff;margin:0;font-size:1.8rem;font-weight:700}.login-header p{color:var(--text-dim);margin:.5rem 0 0;font-size:.95rem}.login-error-msg{color:#ef4444;text-align:center;background:#ef44441a;border:1px solid #ef444433;border-radius:12px;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.85rem;font-weight:500;animation:.4s shake}.login-form{flex-direction:column;gap:1.25rem;display:flex}.login-form .form-group{text-align:left;flex-direction:column;gap:.5rem;display:flex}.login-form label{color:var(--text-muted);font-size:.85rem;font-weight:600}.login-form .form-control{color:#fff;background:#00000040;border:1px solid #ffffff14;border-radius:12px;padding:.85rem 1rem;font-size:.95rem;transition:all .3s}.login-form .form-control:focus{background:#0006;border-color:#fff3;outline:none}.login-page.club-theme .login-form .form-control:focus{border-color:var(--color-primary);box-shadow:0 0 10px #22c55e26}.login-page.saas-theme .login-form .form-control:focus{border-color:#a855f7;box-shadow:0 0 10px #a855f726}.btn-login{color:#fff;cursor:pointer;border:none;border-radius:12px;margin-top:.5rem;padding:.9rem;font-size:1rem;font-weight:700;transition:all .3s}.login-page.club-theme .btn-login{background:var(--color-primary);color:#0b0f19;box-shadow:0 4px 15px #22c55e33}.login-page.club-theme .btn-login:hover{background:#1cb050;box-shadow:0 4px 20px #22c55e59}.login-page.saas-theme .btn-login{color:#fff;background:#a855f7;box-shadow:0 4px 15px #a855f733}.login-page.saas-theme .btn-login:hover{background:#9333ea;box-shadow:0 4px 20px #a855f759}.login-footer{text-align:center;border-top:1px solid #ffffff0d;margin-top:2rem;padding-top:1.5rem}.btn-back-to-portal{color:var(--text-dim);cursor:pointer;background:0 0;border:none;font-size:.85rem;font-weight:500;transition:color .2s}.btn-back-to-portal:hover{color:#fff}.btn-sidebar-logout{color:#f87171;cursor:pointer;letter-spacing:.2px;background:#ef444426;border:1px solid #ef44444d;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:.5rem;padding:.65rem;font-size:.88rem;font-weight:600;transition:all .2s;display:flex}.btn-sidebar-logout:hover{color:#fff;background:#ef4444;border-color:#ef4444;box-shadow:0 0 12px #ef44444d}body.light-mode{color:#1f2937;background-color:#f1f5f9;background-image:radial-gradient(circle at 10% 20%,#22c55e0a 0%,#0000 40%),radial-gradient(circle at 90% 80%,#3b82f60a 0%,#0000 40%)}body.light-mode .main-content{background:0 0}body.light-mode .sidebar{background:#fff;border-right:1px solid #0000001a;box-shadow:4px 0 24px #0000000f}body.light-mode .logo-text{background:linear-gradient(135deg,#1f2937 30%,#15803d 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text}body.light-mode .sidebar-footer{border-top-color:#00000014}body.light-mode .menu-item-btn{color:#374151}body.light-mode .menu-item-btn:hover{color:#111827;background:#0000000a}body.light-mode .menu-item-btn.active{color:#15803d;background:#22c55e1a;border-color:#22c55e40;box-shadow:0 0 12px #22c55e14}body.light-mode .menu-item-btn[title]{color:#374151;background:#00000008;border-color:#00000014}body.light-mode .btn-sidebar-logout{color:#dc2626;background:#dc26260d;border-color:#dc262626}body.light-mode .btn-sidebar-logout:hover{color:#fff;background:#dc2626}body.light-mode .admin-info h4{color:#111827}body.light-mode .admin-info p{color:#6b7280}body.light-mode .admin-avatar{color:#0b0f19}body.light-mode .stat-card,body.light-mode .table-card,body.light-mode .activity-card,body.light-mode .court-matrix-card,body.light-mode .court-detail-panel{background:#fff;border-color:#00000014;box-shadow:0 2px 12px #0000000f}body.light-mode .stat-card:hover{border-color:#0000001f;box-shadow:0 8px 24px #0000001a}body.light-mode .stat-header{color:#6b7280}body.light-mode .stat-number,body.light-mode .dashboard-card-title{color:#111827}body.light-mode .custom-table th{color:#6b7280;border-bottom-color:#00000014}body.light-mode .custom-table td{color:#374151;border-bottom-color:#0000000f}body.light-mode .custom-table tr:hover td{background:#00000005}body.light-mode .player-img-placeholder{color:#15803d;background:#f0fdf4}body.light-mode .badge-green{color:#15803d;background:#22c55e1f}body.light-mode .badge-danger{color:#dc2626;background:#dc26261a}body.light-mode .badge-warning{color:#b45309;background:#f59e0b1f}body.light-mode .btn-secondary{color:#374151;background:#0000000a;border-color:#0000001f}body.light-mode .btn-secondary:hover{color:#111827;background:#00000014}body.light-mode .btn-icon{color:#6b7280}body.light-mode .btn-icon:hover{color:#374151;background:#0000000f}body.light-mode .btn-icon.delete:hover{color:#dc2626;background:#dc262614}body.light-mode .form-control{color:#111827;background:#fff;border-color:#00000026}body.light-mode .form-control:focus{border-color:#15803d;box-shadow:0 0 0 3px #22c55e1a}body.light-mode .form-control::placeholder{color:#9ca3af}body.light-mode .form-group label{color:#4b5563}body.light-mode .date-input{color:#111827;background:#fff;border-color:#00000026}body.light-mode .search-input{color:#111827;background:#fff;border-color:#0000001f}body.light-mode .search-input::placeholder{color:#9ca3af}body.light-mode .modal-overlay{background:#0006}body.light-mode .modal-card{background:#fff;border-color:#0000001a;box-shadow:0 20px 60px #00000026}body.light-mode .modal-card h3{color:#111827}body.light-mode .modal-card p,body.light-mode .modal-card span{color:#374151}body.light-mode .activity-item{border-bottom-color:#0000000f}body.light-mode .activity-info h5{color:#111827}body.light-mode .activity-info p{color:#6b7280}body.light-mode .activity-time{color:#9ca3af}body.light-mode .header-title h1{color:#111827}body.light-mode .header-title p{color:#6b7280}body.light-mode .court-matrix-card{background:#fff}body.light-mode .modern-scheduler th{color:#6b7280;border-bottom-color:#00000014}body.light-mode .scheduler-court-header{background:#00000008;border-color:#00000014}body.light-mode .court-name-wrap .court-name{color:#111827}body.light-mode .court-name-wrap .court-surface{color:#64748b}body.light-mode .scheduler-time-cell .time-label{color:#374151;background:#0000000a;border-color:#00000014}body.light-mode .scheduler-slot-cell.available{background:#00000004;border-color:#0000001f}body.light-mode .scheduler-slot-cell.available .empty-card{color:#4b5563}body.light-mode .scheduler-slot-cell.blocked{color:#64748b;background:#64748b0f;border-color:#64748b33}body.light-mode .scheduler-slot-cell.booked.singles,body.light-mode .scheduler-slot-cell.booked.member_match{color:#1e40af!important;background:#3b82f614!important;border-color:#3b82f666!important}body.light-mode .scheduler-slot-cell.booked.doubles{color:#6b21a8!important;background:#a855f714!important;border-color:#a855f766!important}body.light-mode .scheduler-slot-cell.booked.training{color:#065f46!important;background:#10b98114!important;border-color:#10b98166!important}body.light-mode .scheduler-slot-cell.booked.lesson{color:#9f1239!important;background:#f43f5e14!important;border-color:#f43f5e66!important}body.light-mode .scheduler-slot-cell.booked.course{color:#075985!important;background:#06b6d414!important;border-color:#06b6d466!important}body.light-mode .scheduler-slot-cell.booked.custom{color:#92400e!important;background:#f59e0b14!important;border-color:#f59e0b66!important}body.light-mode .scheduler-slot-cell.booked.league_match{color:#b45309!important;background:#fb923c1a!important;border-color:#fb923c66!important}body.light-mode .scheduler-slot-cell.pending{color:#854d0e!important;background:#eab30814!important;border-color:#eab30880!important}body.light-mode .scheduler-card .card-players{color:#111827}body.light-mode .legend-item{color:#6b7280}body.light-mode .legend-color.available{background:#0000000a;border-color:#0000001f}body.light-mode .court-map-canvas{background:#f8fafc;border-color:#00000014}body.light-mode .court-map-node{background:#fffffff7;box-shadow:0 2px 12px #0000001a}body.light-mode .court-node-name{color:#111827}body.light-mode .court-node-status{color:#6b7280}body.light-mode .court-map-header{color:#111827;background:#22c55e0d;border-color:#22c55e26}body.light-mode .map-header-hint,body.light-mode .court-map-empty{color:#9ca3af}body.light-mode .court-detail-header h3{color:#111827}body.light-mode .court-detail-row{color:#6b7280}body.light-mode .court-detail-row strong{color:#111827}body.light-mode .court-detail-desc{color:#6b7280;background:#00000008}body.light-mode .close-btn{color:#9ca3af}body.light-mode .close-btn:hover{color:#374151;background:#0000000f}body.light-mode .cstat-mini{background:#0000000a}body.light-mode .cstat-mini span{color:#111827}body.light-mode .subtab-pill{color:#6b7280;background:#fff;border-color:#0000001f}body.light-mode .subtab-pill:hover{color:#15803d;background:#22c55e0f;border-color:#15803d}body.light-mode .subtab-pill.active{color:#fff;background:#15803d;border-color:#15803d}body.light-mode .quick-access-card{background:#22c55e0d!important;border:1px solid #22c55e33!important}body.light-mode .quick-access-card p{color:#374151!important}body.light-mode .quick-access-card div span:last-child{color:#15803d!important}body.light-mode .content-header{border-bottom-color:#0000000f}body.light-mode ::-webkit-scrollbar-track{background:#0000000a}body.light-mode ::-webkit-scrollbar-thumb{background:#00000026}body.light-mode ::-webkit-scrollbar-thumb:hover{background:#00000040}body.light-mode select.form-control,body.light-mode select{color:#111827;background:#fff;border-color:#00000026}body.light-mode p,body.light-mode span,body.light-mode label,body.light-mode li{color:inherit}body.light-mode h1,body.light-mode h2,body.light-mode h3,body.light-mode h4,body.light-mode h5,body.light-mode h6{color:#111827}body.light-mode [style*="background: rgba(168, 85, 247"]{background:#a855f714!important}body.light-mode .loading-text{color:#6b7280}body.light-mode .text-muted,body.light-mode [class*=muted]{color:#6b7280!important}body.light-mode .text-dim,body.light-mode [class*=dim]{color:#9ca3af!important}body.light-mode .login-page{background:#f1f5f9}body.light-mode .login-card{background:#fff;border-color:#00000014;box-shadow:0 20px 60px #0000001a}body.light-mode .login-header h2{color:#111827}body.light-mode .login-header p{color:#6b7280}body.light-mode .login-form .form-control{color:#111827;background:#f9fafb;border-color:#0000001f}body.light-mode .login-form .form-control:focus{background:#fff;border-color:#15803d}body.light-mode .login-form label{color:#4b5563}body.light-mode .btn-back-to-portal{color:#9ca3af}body.light-mode .btn-back-to-portal:hover{color:#374151}body.light-mode .login-footer{border-top-color:#0000000f}body.light-mode button[title="Karanlık Moda Geç"],body.light-mode button[title="Aydınlık Moda Geç"]{color:#374151!important;background:#0000000a!important;border-color:#0000001a!important}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleUp{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.theme-toggle-btn{color:#cbd5e1;cursor:pointer;letter-spacing:.2px;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.65rem;font-size:.88rem;font-weight:600;transition:all .2s;display:flex}.theme-toggle-btn:hover{color:#fff;background:#ffffff1a;border-color:#fff3}body.light-mode .theme-toggle-btn{color:#374151;background:#0000000a;border:1px solid #0000001a}body.light-mode .theme-toggle-btn:hover{color:#111827;background:#00000014;border-color:#00000026}.bulk-floating-bar{-webkit-backdrop-filter:blur(16px)saturate(180%);z-index:90;background:#11161fd9;border:1px solid #6366f159;border-radius:16px;width:90%;max-width:800px;padding:1rem 1.5rem;animation:.3s cubic-bezier(.4,0,.2,1) slideUp;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 10px 30px #00000080,0 0 20px #6366f126}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,100px)}to{opacity:1;transform:translate(-50%)}}.bulk-floating-content{justify-content:space-between;align-items:center;gap:1.5rem;display:flex}.bulk-floating-info{flex-direction:column;flex:1;gap:.5rem;display:flex;overflow:hidden}.bulk-floating-count{color:#a5b4fc;text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:700}.bulk-floating-chips{flex-wrap:wrap;gap:.5rem;max-height:80px;padding-right:4px;display:flex;overflow-y:auto}.bulk-floating-chips::-webkit-scrollbar{width:4px;height:4px}.bulk-floating-chips::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.bulk-chip{color:#e0e7ff;background:#6366f11f;border:1px solid #6366f14d;border-radius:8px;align-items:center;gap:6px;padding:.25rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.bulk-chip-remove{color:#a5b4fc;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:.9rem;font-weight:700;line-height:1;transition:color .15s;display:flex}.bulk-chip-remove:hover{color:#ef4444}.bulk-floating-actions{align-items:center;gap:.75rem;display:flex}.btn-primary-sm{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:8px;padding:.5rem 1.25rem;font-size:.8rem;font-weight:700;transition:all .2s}.btn-primary-sm:hover{background:#4f46e5;box-shadow:0 0 12px #6366f166}.btn-secondary-sm{color:#cbd5e1;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;padding:.5rem 1rem;font-size:.8rem;font-weight:600;transition:all .2s}.btn-secondary-sm:hover{color:#fff;background:#ffffff1a}body.light-mode .bulk-floating-bar{background:#ffffffe6;border:1px solid #6366f166;box-shadow:0 10px 30px #0000001a,0 0 20px #6366f126}body.light-mode .bulk-floating-count{color:#4f46e5}body.light-mode .bulk-chip{color:#312e81;background:#6366f114;border-color:#6366f140}body.light-mode .bulk-chip-remove{color:#6366f1}body.light-mode .btn-secondary-sm{color:#4b5563;background:#f3f4f6;border-color:#e5e7eb}body.light-mode .btn-secondary-sm:hover{color:#1f2937;background:#e5e7eb}.backup-alert-box{color:#ef4444;background:#ef44440d;border:1px solid #ef444433;border-radius:8px;align-items:flex-start;gap:.75rem;margin-bottom:1.5rem;padding:1rem;font-size:.88rem;display:flex}.backup-alert-icon{font-size:1.25rem;line-height:1}.backup-alert-text h4{margin-bottom:.25rem;font-weight:700}.backup-alert-text p{color:var(--text-muted)}body.light-mode .backup-alert-text p{color:#6b7280}.backup-table-card{margin-top:1rem}.backup-actions-container{gap:.5rem;display:flex}.rules-modal-container{border-top:1px solid var(--border-color);min-height:500px;max-height:70vh;margin-top:1rem;display:flex}.rules-modal-sidebar{border-right:1px solid var(--border-color);flex-direction:column;gap:.35rem;width:220px;padding:1rem 1rem 1rem 0;display:flex;overflow-y:auto}.rules-sidebar-btn{color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.6rem;padding:.75rem 1rem;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.rules-sidebar-btn:hover{color:var(--text-white);background:#ffffff0d}body.light-mode .rules-sidebar-btn:hover{color:#1f2937;background:#00000008}.rules-sidebar-btn.active{color:#c084fc;background:#a855f71f;box-shadow:inset 3px 0 #a855f7}body.light-mode .rules-sidebar-btn.active{color:#7e22ce;background:#a855f714;box-shadow:inset 3px 0 #a855f7}.rules-modal-content{flex:1;padding:1rem 0 1rem 1.5rem;overflow-y:auto}.rules-group-card{border:1px solid var(--border-color);background:#ffffff05;border-radius:10px;margin-bottom:1.5rem;padding:1.5rem}body.light-mode .rules-group-card{background:#fff}.rules-group-title{color:var(--text-white);align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:1.05rem;font-weight:700;display:flex}body.light-mode .rules-group-title{color:#1f2937}.rules-group-subtitle{color:var(--text-muted);margin-bottom:1.25rem;font-size:.82rem}.rules-form-grid{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.rules-form-grid-full{grid-template-columns:1fr;gap:1.25rem;display:grid}.rule-toggle-control{border:1px solid var(--border-color);background:#ffffff08;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}body.light-mode .rule-toggle-control{background:#f9fafb}.rule-toggle-label{flex-direction:column;gap:.2rem;display:flex}.rule-toggle-label span{color:var(--text-white);font-size:.85rem;font-weight:600}body.light-mode .rule-toggle-label span{color:#374151}.rule-toggle-label small{color:var(--text-muted);font-size:.76rem}.switch{width:44px;height:22px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#ffffff1a;border-radius:22px;transition:all .2s;position:absolute;inset:0}body.light-mode .slider{background-color:#d1d5db}.slider:before{content:"";background-color:#fff;border-radius:50%;width:16px;height:16px;transition:all .2s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:#a855f7}input:checked+.slider:before{transform:translate(22px)}.range-rule-row{border:1px solid var(--border-color);background:#ffffff05;border-radius:6px;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.5rem;display:flex}body.light-mode .range-rule-row{background:#f9fafb}.btn-remove-range{color:#ef4444;cursor:pointer;background:#ef44441a;border:1px solid #ef444433;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-weight:700;display:flex}.btn-remove-range:hover{color:#fff;background:#ef4444}.btn-add-range{color:#c084fc;cursor:pointer;text-align:center;background:#a855f70d;border:1px dashed #a855f74d;border-radius:6px;width:100%;margin-top:.5rem;padding:.5rem;font-size:.82rem;font-weight:600;transition:all .2s}.btn-add-range:hover{color:#fff;background:#a855f71a;border-color:#a855f7}body.light-mode .btn-add-range{color:#7e22ce;border-color:#a855f766}body.light-mode .btn-add-range:hover{color:#6b21a8;background:#a855f70d}.password-prompt-box{border:1px solid var(--border-color);background:#ffffff05;border-radius:8px;margin-top:1rem;padding:1rem}body.light-mode .password-prompt-box{background:#f9fafb}.lrd-overlay{z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#050514d9;justify-content:center;align-items:center;padding:1rem;animation:.25s ease-out lrd-fadeIn;display:flex;position:fixed;inset:0}@keyframes lrd-fadeIn{0%{opacity:0}to{opacity:1}}.lrd-container{background:#10102af7;border:1px solid #a855f733;border-radius:20px;flex-direction:column;width:100%;max-width:960px;max-height:92vh;animation:.3s ease-out lrd-slideUp;display:flex;overflow:hidden;box-shadow:0 0 60px #a855f714,0 25px 80px #00000080}@keyframes lrd-slideUp{0%{opacity:0;transform:translateY(30px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.lrd-header{border-bottom:1px solid #ffffff0f;flex-shrink:0;justify-content:space-between;align-items:center;padding:1.5rem 2rem 1rem;display:flex}.lrd-header-info h2{color:#e2e8f0;align-items:center;gap:.5rem;margin:0 0 .25rem;font-size:1.3rem;font-weight:700;display:flex}.lrd-header-info p{color:#94a3b8;margin:0;font-size:.85rem}.lrd-close-btn{color:#94a3b8;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:all .2s;display:flex}.lrd-close-btn:hover{color:#ef4444;background:#ef444426;border-color:#ef44444d;transform:scale(1.05)}.lrd-tabs{scrollbar-width:none;border-bottom:1px solid #ffffff0f;flex-shrink:0;gap:.25rem;padding:.75rem 2rem 0;display:flex;overflow-x:auto}.lrd-tabs::-webkit-scrollbar{display:none}.lrd-tab{color:#64748b;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:.6rem 1rem;font-size:.82rem;font-weight:600;transition:all .25s;position:relative}.lrd-tab:hover{color:#94a3b8;background:#ffffff05}.lrd-tab.active{color:#d8b4fe;border-bottom-color:#a855f7}.lrd-content{scrollbar-width:thin;scrollbar-color:#a855f74d transparent;flex:1;padding:1.5rem 2rem;overflow-y:auto}.lrd-content::-webkit-scrollbar{width:6px}.lrd-content::-webkit-scrollbar-track{background:0 0}.lrd-content::-webkit-scrollbar-thumb{background:#a855f74d;border-radius:3px}.lrd-section-title{color:#e2e8f0;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1rem;font-weight:700;display:flex}.lrd-section-desc{color:#64748b;margin:-.5rem 0 1.25rem;font-size:.82rem}.lrd-card{background:#ffffff06;border:1px solid #ffffff0f;border-radius:14px;margin-bottom:1rem;padding:1.25rem;transition:border-color .3s,box-shadow .3s}.lrd-card:hover{border-color:#a855f726;box-shadow:0 0 20px #a855f70a}.lrd-card-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.lrd-card-title{color:#cbd5e1;margin:0;font-size:.9rem;font-weight:600}.lrd-form-group{margin-bottom:1rem}.lrd-label{color:#94a3b8;letter-spacing:.02em;margin-bottom:.4rem;font-size:.8rem;font-weight:600;display:block}.lrd-input,.lrd-select{color:#e2e8f0;box-sizing:border-box;background:#0000004d;border:1px solid #ffffff1a;border-radius:10px;width:100%;padding:.6rem .85rem;font-family:inherit;font-size:.88rem;transition:all .25s}.lrd-input:focus,.lrd-select:focus{border-color:#a855f780;outline:none;box-shadow:0 0 0 3px #a855f71a}.lrd-input::placeholder{color:#475569}.lrd-input-row{align-items:flex-end;gap:.75rem;display:flex}.lrd-input-row .lrd-form-group{flex:1}.lrd-toggle-row{background:#ffffff05;border:1px solid #ffffff0f;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:.6rem;padding:.85rem 1rem;transition:all .2s;display:flex}.lrd-toggle-row:hover{background:#ffffff0a}.lrd-toggle-label{color:#cbd5e1;font-size:.88rem;font-weight:600}.lrd-toggle-desc{color:#64748b;margin-top:.15rem;font-size:.78rem}.lrd-switch{flex-shrink:0;width:48px;height:26px;position:relative}.lrd-switch input{opacity:0;width:0;height:0}.lrd-switch-slider{cursor:pointer;background:#ffffff1a;border-radius:13px;transition:all .3s;position:absolute;inset:0}.lrd-switch-slider:before{content:"";background:#64748b;border-radius:50%;width:20px;height:20px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;bottom:3px;left:3px}.lrd-switch input:checked+.lrd-switch-slider{background:#a855f74d;box-shadow:0 0 12px #a855f733}.lrd-switch input:checked+.lrd-switch-slider:before{background:#a855f7;transform:translate(22px)}.lrd-radio-group{flex-direction:column;gap:.5rem;display:flex}.lrd-radio-option{cursor:pointer;background:#ffffff05;border:1px solid #ffffff0f;border-radius:12px;align-items:center;gap:.75rem;padding:.85rem 1rem;transition:all .2s;display:flex}.lrd-radio-option:hover{background:#ffffff0a;border-color:#a855f726}.lrd-radio-option.selected{background:#a855f70f;border-color:#a855f74d}.lrd-radio-dot{border:2px solid #fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:all .2s;display:flex}.lrd-radio-option.selected .lrd-radio-dot{border-color:#a855f7}.lrd-radio-dot:after{content:"";background:0 0;border-radius:50%;width:8px;height:8px;transition:all .2s}.lrd-radio-option.selected .lrd-radio-dot:after{background:#a855f7}.lrd-radio-text strong{color:#cbd5e1;margin-bottom:.1rem;font-size:.88rem;display:block}.lrd-radio-text span{color:#64748b;font-size:.78rem}.lrd-rule-block{background:#ffffff06;border:1px solid #ffffff14;border-radius:14px;margin-bottom:.75rem;padding:1rem 1.25rem;transition:all .25s;animation:.3s ease-out lrd-ruleIn;position:relative}@keyframes lrd-ruleIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.lrd-rule-block:hover{border-color:#a855f733}.lrd-rule-header{justify-content:space-between;align-items:center;margin-bottom:.85rem;display:flex}.lrd-rule-number{color:#a855f7;background:#a855f71a;border-radius:6px;padding:.2rem .6rem;font-size:.75rem;font-weight:700}.lrd-rule-actions{gap:.35rem;display:flex}.lrd-rule-action-btn{color:#64748b;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;transition:all .2s;display:flex}.lrd-rule-action-btn:hover{color:#e2e8f0;background:#ffffff14}.lrd-rule-action-btn.danger:hover{color:#ef4444;background:#ef444426;border-color:#ef44444d}.lrd-rule-fields{grid-template-columns:1fr 1fr 1fr;gap:.75rem;display:grid}.lrd-btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:.4rem;padding:.6rem 1.2rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.lrd-btn:active{transform:scale(.97)}.lrd-btn-primary{color:#fff;background:linear-gradient(135deg,#a855f7,#7c3aed);box-shadow:0 4px 15px #a855f74d}.lrd-btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 25px #a855f766}.lrd-btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.lrd-btn-secondary{color:#94a3b8;background:#ffffff0d;border:1px solid #ffffff1a}.lrd-btn-secondary:hover{color:#e2e8f0;background:#ffffff14}.lrd-btn-danger{color:#ef4444;background:#ef44441a;border:1px solid #ef444433}.lrd-btn-danger:hover{background:#ef444433}.lrd-btn-success{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e33}.lrd-btn-add{color:#a855f7;cursor:pointer;background:0 0;border:2px dashed #a855f733;border-radius:12px;width:100%;padding:.75rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s}.lrd-btn-add:hover{background:#a855f70d;border-color:#a855f766}.lrd-footer{border-top:1px solid #ffffff0f;flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 2rem 1.25rem;display:flex}.lrd-footer-left,.lrd-footer-right{gap:.5rem;display:flex}.lrd-toast{z-index:10001;border-radius:12px;align-items:center;gap:.5rem;padding:.85rem 1.5rem;font-size:.88rem;font-weight:600;animation:.3s ease-out lrd-toastIn;display:flex;position:fixed;top:2rem;right:2rem;box-shadow:0 10px 40px #0006}@keyframes lrd-toastIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.lrd-toast.success{color:#22c55e;background:#10102af2;border:1px solid #22c55e4d}.lrd-toast.error{color:#ef4444;background:#10102af2;border:1px solid #ef44444d}.lrd-loading{color:#94a3b8;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.lrd-spinner{border:3px solid #a855f726;border-top-color:#a855f7;border-radius:50%;width:36px;height:36px;animation:.8s linear infinite lrd-spin}@keyframes lrd-spin{to{transform:rotate(360deg)}}.lrd-points-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.lrd-point-item{background:#0003;border:1px solid #ffffff0f;border-radius:10px;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.lrd-point-label{color:#94a3b8;flex:1;font-size:.82rem;font-weight:600}.lrd-point-input{color:#e2e8f0;text-align:center;background:#0000004d;border:1px solid #ffffff1a;border-radius:8px;width:70px;padding:.4rem .6rem;font-family:inherit;font-size:.88rem}.lrd-point-input:focus{border-color:#a855f780;outline:none}.lrd-input-hint{color:#475569;margin-top:.3rem;font-size:.72rem;line-height:1.3;display:block}.lrd-divider{background:#ffffff0f;height:1px;margin:1.5rem 0}@media (width<=768px){.lrd-container{border-radius:0;max-width:100%;max-height:100vh}.lrd-header,.lrd-content,.lrd-footer,.lrd-tabs{padding-left:1rem;padding-right:1rem}.lrd-rule-fields,.lrd-points-grid{grid-template-columns:1fr}.lrd-input-row{flex-direction:column;gap:0}.lrd-footer{flex-direction:column;gap:.75rem}.lrd-footer-left,.lrd-footer-right{justify-content:center;width:100%}}
