@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary:#0a0f1e;--bg-secondary:#0f172a;--bg-surface:#1e293b;--bg-surface-hover:#263548;--bg-elevated:#283a50;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--text-inverse:#0f172a;--accent-primary:#38bdf8;--accent-primary-hover:#56ccf5;--accent-gradient:linear-gradient(135deg, #38bdf8 0%, #818cf8 100%);--accent-glow:0 0 20px #38bdf84d;--success:#4ade80;--success-bg:#4ade801f;--warning:#f59e0b;--warning-bg:#f59e0b1f;--danger:#ef4444;--danger-bg:#ef44441f;--info:#38bdf8;--info-bg:#38bdf81f;--chart-1:#38bdf8;--chart-2:#818cf8;--chart-3:#f472b6;--chart-4:#4ade80;--chart-5:#f59e0b;--chart-6:#a78bfa;--border-subtle:#94a3b81a;--border-default:#94a3b833;--border-accent:#38bdf84d;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--shadow-card:0 4px 24px #00000040;--shadow-lg:0 8px 32px #0006;--shadow-glow:0 0 32px #38bdf826;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}#root{min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(at 30% 40%,#38bdf80f 0%,#0000 60%),radial-gradient(at 70% 60%,#818cf80a 0%,#0000 60%);width:200%;height:200%;animation:20s ease-in-out infinite ambientFloat;position:absolute;top:-50%;left:-50%}@keyframes ambientFloat{0%,to{transform:translate(0)}50%{transform:translate(-2%,-1%)}}.login-card{background:var(--bg-surface);border-radius:var(--radius-xl);border:1px solid var(--border-subtle);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:40px;position:relative}.login-card h1{text-align:center;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:4px;font-size:1.75rem;font-weight:700}.login-card .subtitle{text-align:center;color:var(--text-secondary);margin-bottom:32px;font-size:.875rem}.form-group{margin-bottom:20px}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:.8125rem;font-weight:500;display:block}.form-group input{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:12px 16px;font-family:inherit;font-size:.9375rem}.form-group input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #38bdf826}.form-group input::placeholder{color:var(--text-muted)}.login-error{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-sm);border:1px solid #ef444433;margin-bottom:16px;padding:10px 14px;font-size:.8125rem}.btn-primary{background:var(--accent-gradient);border-radius:var(--radius-sm);width:100%;color:var(--text-inverse);cursor:pointer;transition:opacity var(--transition-fast), transform var(--transition-fast);border:none;padding:12px 24px;font-family:inherit;font-size:.9375rem;font-weight:600}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.dashboard-layout{background:var(--bg-primary);min-height:100vh}.dashboard-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;height:64px;padding:0 32px;display:flex;position:sticky;top:0}.header-brand{align-items:center;gap:12px;display:flex}.header-brand .logo-icon{background:var(--accent-gradient);border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-inverse);justify-content:center;align-items:center;font-size:1.125rem;font-weight:800;display:flex}.header-brand h2{color:var(--text-primary);font-size:1.125rem;font-weight:600}.header-brand span{color:var(--text-muted);font-size:.75rem}.header-actions{align-items:center;gap:16px;display:flex}.user-badge{background:var(--bg-surface);border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:8px;padding:6px 12px;font-size:.8125rem;display:flex}.user-badge .role-tag{background:var(--accent-gradient);color:var(--text-inverse);text-transform:uppercase;letter-spacing:.05em;border-radius:999px;padding:2px 8px;font-size:.6875rem;font-weight:600}.btn-ghost{border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:8px 16px;font-family:inherit;font-size:.8125rem}.btn-ghost:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-accent)}.dashboard-content{max-width:1400px;margin:0 auto;padding:24px 32px}.filter-bar{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:24px;display:flex}.filter-bar .date-group{align-items:center;gap:8px;display:flex}.filter-bar label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8125rem;font-weight:500}.filter-bar input[type=date]{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);transition:border-color var(--transition-fast);outline:none;padding:8px 12px;font-family:inherit;font-size:.875rem}.filter-bar input[type=date]:focus{border-color:var(--accent-primary)}.filter-bar input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.7)}.preset-buttons{gap:6px;margin-left:auto;display:flex}.btn-preset{background:var(--bg-surface);border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border-radius:999px;padding:6px 14px;font-family:inherit;font-size:.75rem;font-weight:500}.btn-preset:hover,.btn-preset.active{background:var(--accent-primary);color:var(--text-inverse);border-color:#0000}.btn-refresh{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--accent-primary);cursor:pointer;transition:all var(--transition-fast);padding:8px 16px;font-family:inherit;font-size:.8125rem;font-weight:500}.btn-refresh:hover{background:var(--bg-elevated)}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:28px;display:grid}.kpi-card{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:all var(--transition-normal);padding:20px 24px;position:relative;overflow:hidden}.kpi-card:before{content:"";background:var(--accent-gradient);opacity:0;height:3px;transition:opacity var(--transition-normal);position:absolute;top:0;left:0;right:0}.kpi-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.kpi-card:hover:before{opacity:1}.kpi-card .kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:.75rem;font-weight:500}.kpi-card .kpi-value{color:var(--text-primary);font-size:1.625rem;font-weight:700;line-height:1.2}.kpi-card .kpi-sub{color:var(--text-secondary);margin-top:6px;font-size:.75rem}.kpi-card.accent-success .kpi-value{color:var(--success)}.kpi-card.accent-warning .kpi-value{color:var(--warning)}.kpi-card.accent-danger .kpi-value{color:var(--danger)}.charts-grid{grid-template-columns:2fr 1fr;gap:20px;margin-bottom:28px;display:grid}.chart-card{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border-subtle);padding:24px}.chart-card h3{color:var(--text-primary);margin-bottom:20px;font-size:.9375rem;font-weight:600}.charts-row{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px;display:grid}.table-section{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border-subtle);margin-bottom:28px;overflow:hidden}.table-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.table-header h3{color:var(--text-primary);font-size:.9375rem;font-weight:600}.table-header .record-count{color:var(--text-muted);background:var(--bg-secondary);border-radius:999px;padding:4px 10px;font-size:.75rem}.transactions-table{border-collapse:collapse;width:100%}.transactions-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);padding:12px 16px;font-size:.6875rem;font-weight:600;position:sticky;top:0}.transactions-table td{color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);padding:12px 16px;font-size:.8125rem}.transactions-table tr:hover td{background:var(--bg-surface-hover);color:var(--text-primary)}.transactions-table .amount-cell{font-variant-numeric:tabular-nums;text-align:right;font-weight:600}.type-badge{letter-spacing:.02em;border-radius:999px;align-items:center;padding:3px 10px;font-size:.6875rem;font-weight:600;display:inline-flex}.type-badge.booking{background:var(--info-bg);color:var(--info)}.type-badge.academy{color:#818cf8;background:#818cf81f}.type-badge.membership{color:#f472b6;background:#f472b61f}.mode-badge{background:var(--bg-elevated);color:var(--text-secondary);border-radius:999px;padding:2px 8px;font-size:.6875rem;font-weight:500;display:inline-flex}.table-scroll{max-height:480px;overflow-y:auto}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-lg);width:90%;max-width:480px;padding:32px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-card h3{margin-bottom:8px;font-size:1.25rem;font-weight:600}.modal-card p{color:var(--text-secondary);margin-bottom:24px;font-size:.875rem}.modal-actions{justify-content:flex-end;gap:12px;display:flex}.btn-export{background:var(--accent-gradient);border-radius:var(--radius-sm);color:var(--text-inverse);cursor:pointer;transition:opacity var(--transition-fast);border:none;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:.875rem;font-weight:600;display:flex}.btn-export:hover:not(:disabled){opacity:.9}.btn-export:disabled{opacity:.5;cursor:not-allowed}.btn-cancel{border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:10px 20px;font-family:inherit;font-size:.875rem}.btn-cancel:hover{background:var(--bg-elevated);color:var(--text-primary)}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 0;display:flex}.spinner{border:3px solid var(--border-default);border-top-color:var(--accent-primary);border-radius:50%;width:40px;height:40px;animation:.75s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-muted);font-size:.875rem}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state .empty-icon{opacity:.3;margin-bottom:12px;font-size:3rem}@media (width<=1024px){.charts-grid,.charts-row{grid-template-columns:1fr}.dashboard-content{padding:20px}}@media (width<=768px){.dashboard-header{padding:0 16px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.filter-bar{flex-direction:column;align-items:stretch}.preset-buttons{flex-wrap:wrap;margin-left:0}.header-actions{gap:8px}.user-badge{display:none}}@media (width<=480px){.kpi-grid{grid-template-columns:1fr}.login-card{margin:16px;padding:24px}}
