.toast-container{position:fixed;top:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:10px}.toast{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:var(--radius-md);min-width:300px;max-width:450px;box-shadow:var(--shadow-lg);cursor:pointer;animation:toastSlideIn .3s ease}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-icon{font-size:16px;font-weight:700}.toast-message{font-size:14px;flex:1}.toast-success{background:linear-gradient(135deg,#065f46,#047857);color:#fff}.toast-error{background:linear-gradient(135deg,#991b1b,#dc2626);color:#fff}.toast-warning{background:linear-gradient(135deg,#92400e,#d97706);color:#fff}.toast-info{background:linear-gradient(135deg,#1e40af,#2563eb);color:#fff}.toast:hover{transform:scale(1.02)}.app-layout{display:flex;flex-direction:column;height:100%}.topbar{display:flex;justify-content:space-between;align-items:center;padding:0 24px;height:64px;background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);flex-shrink:0;position:relative;z-index:20}@media (max-width: 768px){.topbar{height:56px;padding:0 12px}}.topbar-brand{display:flex;align-items:center;gap:12px}.menu-toggle{background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.menu-toggle:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.brand-icon{display:flex;align-items:center;justify-content:center}.brand-name{font-size:20px;font-weight:700;background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-top:2px}.theme-toggle{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);margin-left:8px;color:var(--color-text-secondary)}[data-theme=dark] .theme-toggle{color:var(--color-warning);background:#f59e0b26;border-color:#f59e0b4d}[data-theme=light] .theme-toggle{color:var(--color-primary);background:#6366f11a;border-color:#6366f133}.theme-toggle:hover{background:var(--color-border);transform:scale(1.05)}.topbar-user{display:flex;align-items:center;gap:16px}.user-info-desktop{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.user-role-wrapper{display:flex;align-items:center}.user-email{color:var(--color-text-secondary);font-size:14px}.user-role{font-size:11px;text-transform:uppercase}.mobile-user-toggle{display:none;background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;padding:8px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.mobile-user-toggle:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.user-menu-dropdown{display:none;position:absolute;top:60px;right:12px;width:200px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:12px;z-index:50;flex-direction:column;gap:12px}.topbar-user.mobile-open .user-menu-dropdown{display:flex}.user-info-mobile{display:flex;flex-direction:column;gap:4px;padding-bottom:12px;border-bottom:1px solid var(--color-border)}@media (max-width: 768px){.user-info-desktop,.topbar-user .btn-logout-desktop{display:none!important}.mobile-user-toggle{display:flex;align-items:center;justify-content:center}}.app-body{display:flex;flex:1;overflow:hidden;position:relative}.sidebar{width:240px;background:var(--color-bg-secondary);border-right:1px solid var(--color-border);padding:20px 0;flex-shrink:0;overflow-y:auto;transition:width .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.sidebar.closed{width:0;padding:20px 0;overflow:hidden;border-right:none}.sidebar-overlay{display:none;position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:25;opacity:0;transition:opacity var(--transition-normal);pointer-events:none}.sidebar-overlay.open{opacity:1;pointer-events:auto}@media (max-width: 768px){.sidebar{position:absolute;top:0;bottom:0;left:0;z-index:30;width:240px;transform:translate(-100%);border-right:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0);width:240px}.sidebar.closed{width:240px;transform:translate(-100%)}.sidebar-overlay{display:block}}.nav-list{list-style:none}.nav-link{display:flex;align-items:center;gap:12px;padding:12px 24px;color:var(--color-text-secondary);text-decoration:none;transition:all var(--transition-fast);font-size:14px;font-weight:500}.nav-link:hover{background:var(--color-bg-tertiary);color:var(--color-text);text-decoration:none}.nav-link.active{background:linear-gradient(90deg,rgba(99,102,241,.2),transparent);color:var(--color-primary-light);border-left:3px solid var(--color-primary)}.nav-icon{font-size:18px}.main-content{flex:1;padding:24px;overflow-y:auto}@media (max-width: 768px){.main-content{padding:12px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg) 0%,#1a1a2e 100%);padding:20px}.login-card{width:100%;max-width:420px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:32px}.login-icon{font-size:48px;display:block;margin-bottom:16px}.login-header h1{font-size:24px;font-weight:700;margin-bottom:8px;background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{color:var(--color-text-secondary);font-size:14px}.login-btn{width:100%;margin-top:8px;padding:12px}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-footer{margin-top:32px;padding-top:24px;border-top:1px solid var(--color-border);text-align:center;font-size:13px;color:var(--color-text-muted)}.login-footer code{display:block;margin-top:8px;padding:8px 12px;background:var(--color-bg);border-radius:var(--radius-md);font-family:monospace;color:var(--color-text-secondary)}[data-theme=light] .login-page{background:var(--color-bg)}.login-theme-toggle{position:absolute;top:20px;right:20px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 12px;font-size:16px;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;color:var(--color-text);box-shadow:var(--shadow-sm)}.login-theme-toggle:hover{background:var(--color-bg-tertiary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);max-height:90vh;overflow-y:auto;animation:modalSlideIn .2s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-sm{width:100%;max-width:400px}.modal-md{width:100%;max-width:560px}.modal-lg{width:100%;max-width:800px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-border)}.modal-title{font-size:18px;font-weight:600;color:var(--color-text)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--color-text-muted);font-size:24px;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-close:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid var(--color-border)}:root{--color-primary: #6366f1;--color-primary-dark: #4f46e5;--color-primary-light: #818cf8;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #3b82f6;--color-bg: #0f172a;--color-bg-secondary: #1e293b;--color-bg-tertiary: #334155;--color-text: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-border: #334155;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--transition-fast: .15s ease;--transition-normal: .25s ease}[data-theme=light]{--color-bg: #f8fafc;--color-bg-secondary: #ffffff;--color-bg-tertiary: #e2e8f0;--color-text: #1e293b;--color-text-secondary: #475569;--color-text-muted: #64748b;--color-border: #cbd5e1;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--color-primary-light);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}.container{max-width:1200px;margin:0 auto;padding:0 24px}@media (max-width: 768px){.container{padding:0 12px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-weight:500;font-size:14px;border:none;transition:all var(--transition-fast)}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff}.btn-primary:hover{background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-border)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-sm{padding:6px 12px;font-size:13px}.btn-icon{padding:8px;min-width:36px;min-height:36px}.shortcut-hint{font-size:11px;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:4px;padding:2px 6px;background-color:var(--color-bg-tertiary);-webkit-user-select:none;user-select:none}.input{width:100%;padding:10px 14px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:14px;transition:border-color var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-primary)}.input::placeholder{color:var(--color-text-muted)}.select{width:100%;padding:10px 14px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:14px;cursor:pointer}.select:focus{outline:none;border-color:var(--color-primary)}.label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:var(--color-text-secondary)}.form-group{margin-bottom:16px}.card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px}@media (max-width: 768px){.card{padding:16px}}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.card-title{font-size:18px;font-weight:600}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--color-border)}.table th{font-weight:600;color:var(--color-text-secondary);font-size:13px;text-transform:uppercase;letter-spacing:.5px}.table tr:hover{background:var(--color-bg-tertiary)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:500}@media (max-width: 768px){.table th,.table td{padding:8px;font-size:12px}.badge{padding:2px 8px;font-size:11px}}.badge-success{background:#10b98133;color:var(--color-success)}.badge-warning{background:#f59e0b33;color:var(--color-warning)}.badge-danger{background:#ef444433;color:var(--color-danger)}.badge-info{background:#3b82f633;color:var(--color-info)}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-4{gap:16px}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.sql-editor{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;min-height:200px;resize:vertical}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}@media (max-width: 768px){.page-header{margin-bottom:16px;flex-direction:column;align-items:flex-start;gap:12px}.page-title{font-size:20px}}.page-title{font-size:24px;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px}.stat-label{font-size:13px;color:var(--color-text-muted);margin-bottom:4px}.stat-value{font-size:28px;font-weight:700;color:var(--color-text)}.stat-value.success{color:var(--color-success)}.stat-value.danger{color:var(--color-danger)}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--color-text-muted)}.spinner{width:24px;height:24px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:60px 20px;color:var(--color-text-muted)}.empty-state h3{font-size:18px;margin-bottom:8px;color:var(--color-text-secondary)}.empty-state p{margin-bottom:20px}.dashboard-analytics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:16px}.dashboard-charts-layout{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.dashboard-charts-top{display:grid;grid-template-columns:2fr 1fr;gap:16px}.dashboard-charts-left{display:flex;flex-direction:column;gap:16px}.dash-stats-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dash-stat-minicard{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm)}.stat-icon-wrapper{background:#f3f4f6;width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:24px}.dash-chart-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.dash-chart-card.full-height{height:100%}.chart-header{margin-bottom:16px}.chart-title{font-size:16px;font-weight:600;color:var(--color-text);margin:0}.chart-subtitle{font-size:13px;color:var(--color-text-muted);margin-top:4px}.chart-footer-stats{display:flex;justify-content:space-between;margin-top:auto;padding-top:16px;border-top:1px solid var(--color-border)}.footer-stat{text-align:center}.f-label{font-size:12px;color:var(--color-text-muted)}.f-value{font-size:14px;font-weight:600;margin-top:4px}@media (max-width: 1024px){.dashboard-charts-top{grid-template-columns:1fr}}@media (max-width: 1200px){.dashboard-analytics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dashboard-analytics-grid,.grid-cols-2{grid-template-columns:1fr}}.card-content-scroll{overflow-x:auto;width:100%;-webkit-overflow-scrolling:touch;margin-bottom:20px;border-radius:var(--radius-lg);border:1px solid var(--color-border)}.card-content-scroll .table{border:none;margin-bottom:0;width:100%;border-collapse:collapse;min-width:600px}.card-content-scroll .table th,.card-content-scroll .table td{white-space:nowrap}@media (max-width: 768px){.card-content-scroll{margin:0 -16px 20px;width:calc(100% + 32px);border-radius:0;border-left:none;border-right:none}.card-content-scroll .table th:first-child,.card-content-scroll .table td:first-child{padding-left:16px}.card-content-scroll .table th:last-child,.card-content-scroll .table td:last-child{padding-right:16px}}.badge-sm{padding:2px 6px;font-size:10px}.dash-panel{display:flex;flex-direction:column;height:360px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.dash-panel-header{height:48px;display:flex;align-items:center;padding:0 18px;border-bottom:1px solid var(--color-border);flex-shrink:0}.dash-panel-title{font-size:16px;font-weight:600;color:var(--color-text);margin:0}.dash-panel-body{flex:1;padding:0 18px;overflow-x:auto;overflow-y:hidden}.dash-panel-footer{height:44px;display:flex;align-items:center;justify-content:flex-end;padding:0 18px;border-top:1px solid var(--color-border);background:var(--color-bg-tertiary);flex-shrink:0}.dash-table{width:100%;min-width:600px;border-collapse:collapse;table-layout:fixed}.dash-table th,.dash-table td{padding:0 4px;text-align:left;vertical-align:middle;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-table th{height:36px;font-size:12px;font-weight:600;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border)}.dash-table td{height:44px;font-size:13px;color:var(--color-text);border-bottom:1px solid var(--color-border-subtle)}.dash-table tr:last-child td{border-bottom:none}.dash-table .text-right{text-align:right}.dash-table .text-center{text-align:center}.dash-placeholder-row td{height:38px;padding:0;border-bottom:1px solid var(--color-border-subtle)}.dash-placeholder-row:last-child td{border-bottom:none}.dash-pagination{display:flex;align-items:center;gap:8px}.dash-pagination-btn{padding:4px 10px;font-size:12px;font-weight:500;background:var(--color-bg-tertiary);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast)}.dash-pagination-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-text)}.dash-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.dash-pagination-info{font-size:12px;color:var(--color-text-muted);min-width:80px;text-align:center}.dash-badge{display:inline-flex;align-items:center;justify-content:center;width:44px;height:20px;border-radius:var(--radius-full);font-size:10px;font-weight:600;line-height:1}.tooltip{position:relative;display:inline-flex}.tooltip:before{content:attr(data-tip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;padding:4px 8px;background-color:var(--color-bg-tertiary);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:11px;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;pointer-events:none;z-index:50;box-shadow:var(--shadow-sm)}.tooltip:hover:before{opacity:1;visibility:visible}.detail-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--color-border)}.detail-section{margin-bottom:24px}.detail-section-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);margin-bottom:12px}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.detail-item{background:var(--color-bg-tertiary);padding:12px;border-radius:var(--radius-md)}.detail-label{font-size:12px;color:var(--color-text-muted);margin-bottom:4px}.detail-value{font-size:14px;font-weight:500;color:var(--color-text);word-break:break-all}.action-container{display:flex;align-items:center;padding:4px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);gap:2px;width:fit-content;box-shadow:var(--shadow-sm);transition:border-color var(--transition-fast)}.action-container:hover{border-color:var(--color-primary-light)}.btn-action{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast);background:transparent;border:none;cursor:pointer;color:var(--color-text-secondary);position:relative;overflow:hidden}.btn-action:hover{background:var(--color-bg);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-action:active{transform:translateY(0)}.btn-action svg{width:16px;height:16px;stroke-width:2}.btn-action.view:hover{color:var(--color-info);background:#3b82f61a}.btn-action.edit:hover{color:var(--color-warning);background:#f59e0b1a}.btn-action.delete:hover{color:var(--color-danger);background:#ef44441a}
