@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";:root{--font-heading:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-body:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--bg-deep:#08090d;--bg-card:#11131cbf;--bg-sidebar:#0a0b12f2;--border-color:#ffffff14;--border-glow:#6366f126;--primary:#6366f1;--primary-glow:#6366f159;--secondary:#3b82f6;--accent:#a855f7;--success:#10b981;--success-glow:#10b98133;--warning:#f59e0b;--warning-glow:#f59e0b33;--danger:#ef4444;--danger-glow:#ef444433;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--sidebar-width:260px;--header-height:70px;--glass-blur:blur(16px);--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1);--shadow-neon:0 0 20px #6366f126}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;margin:0;padding:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}body{background-color:var(--bg-deep);color:var(--text-primary);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);letter-spacing:-.02em;font-weight:600}.auth-container{background:radial-gradient(circle at 10% 20%, #6366f126 0%, transparent 40%), radial-gradient(circle at 90% 80%, #a855f726 0%, transparent 40%), var(--bg-deep);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative}.auth-card{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);width:100%;max-width:440px;box-shadow:0 20px 40px #00000080, var(--shadow-neon);border-radius:20px;padding:40px;animation:.6s cubic-bezier(.16,1,.3,1) fadeInDown;position:relative}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{font-family:var(--font-heading);background:linear-gradient(135deg, var(--primary), var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:8px;font-size:28px;font-weight:800}.auth-subtitle{color:var(--text-secondary);font-size:14px}.form-group{margin-bottom:20px;position:relative}.form-label{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:500;display:block}.form-input-container{position:relative}.form-input{border:1px solid var(--border-color);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:var(--transition-smooth);background:#ffffff08;border-radius:10px;padding:12px 16px 12px 42px;font-size:14px}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);background:#ffffff0d;outline:none}.form-icon{color:var(--text-muted);width:18px;height:18px;transition:var(--transition-smooth);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.form-input:focus~.form-icon{color:var(--primary)}.btn{width:100%;font-family:var(--font-heading);cursor:pointer;transition:var(--transition-smooth);border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;box-shadow:0 4px 14px #6366f166}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f199}.btn-primary:active{transform:translateY(0)}.btn-secondary{border:1px solid var(--border-color);color:var(--text-primary);background:#ffffff0d}.btn-secondary:hover{border-color:var(--text-secondary);background:#ffffff1a}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{box-shadow:0 4px 12px var(--danger-glow);background:#dc2626}.auth-footer{text-align:center;margin-top:24px}.auth-footer a{color:var(--primary);transition:var(--transition-smooth);font-size:13px;font-weight:500;text-decoration:none}.auth-footer a:hover{color:var(--accent)}.dashboard-layout{background-color:var(--bg-deep);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);z-index:100;transition:var(--transition-smooth);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{height:var(--header-height);border-bottom:1px solid var(--border-color);align-items:center;padding:0 24px;display:flex}.sidebar-logo{font-family:var(--font-heading);background:linear-gradient(135deg, var(--primary), var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:22px;font-weight:800}.sidebar-nav{flex-direction:column;flex-grow:1;gap:8px;padding:24px 16px;display:flex}.sidebar-item{color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);border-radius:10px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:500;display:flex}.sidebar-item:hover{color:var(--text-primary);background:#ffffff0a}.sidebar-item.active{color:#fff;border-left:3px solid var(--primary);background:linear-gradient(135deg,#6366f126,#a855f726)}.sidebar-footer{border-top:1px solid var(--border-color);padding:16px}.main-content{margin-left:var(--sidebar-width);min-height:100vh;transition:var(--transition-smooth);flex-direction:column;flex-grow:1;display:flex}.header{height:var(--header-height);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--border-color);z-index:90;background:#08090db3;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.page-title{font-size:20px;font-weight:700}.header-actions{align-items:center;gap:16px;display:flex}.api-mode-badge{cursor:pointer;transition:var(--transition-smooth);border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;display:flex}.api-mode-badge.live{color:var(--success);background:#10b9811a;border:1px solid #10b98133}.api-mode-badge.mock{color:var(--warning);background:#f59e0b1a;border:1px solid #f59e0b33}.user-profile{align-items:center;gap:10px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;border:2px solid var(--border-color);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.user-info{flex-direction:column;display:flex}.profile-name{font-size:14px;font-weight:600}.profile-role{color:var(--text-secondary);font-size:11px}.page-container{flex-grow:1;padding:32px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:32px;display:grid}.stats-card{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);transition:var(--transition-smooth);border-radius:16px;flex-direction:column;gap:12px;padding:24px;display:flex;position:relative;overflow:hidden}.stats-card:before{content:"";background:linear-gradient(90deg, var(--primary), var(--accent));opacity:0;width:100%;height:4px;transition:var(--transition-smooth);position:absolute;top:0;left:0}.stats-card:hover{box-shadow:var(--shadow-neon);border-color:#ffffff26;transform:translateY(-4px)}.stats-card:hover:before{opacity:1}.stats-header{justify-content:space-between;align-items:center;display:flex}.stats-label{color:var(--text-secondary);font-size:14px;font-weight:500}.stats-icon-wrapper{color:var(--primary);background:#ffffff08;border-radius:10px;justify-content:center;align-items:center;padding:8px;display:flex}.stats-value{font-size:28px;font-weight:700;font-family:var(--font-heading)}.stats-change{align-items:center;gap:4px;font-size:12px;font-weight:600;display:flex}.stats-change.positive{color:var(--success)}.stats-change.negative{color:var(--danger)}.charts-grid{grid-template-columns:2fr 1fr;gap:24px;margin-bottom:32px;display:grid}@media (width<=1024px){.charts-grid{grid-template-columns:1fr}}.chart-card{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);border-radius:16px;padding:24px}.chart-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.chart-title{font-size:16px;font-weight:600}.chart-container{justify-content:space-between;align-items:flex-end;height:260px;padding-top:20px;display:flex;position:relative}.bar-chart-bar{flex-direction:column;flex-grow:1;align-items:center;gap:8px;display:flex}.bar-fill-wrapper{background:#ffffff08;border-radius:12px;width:24px;height:180px;position:relative;overflow:hidden}.bar-fill{background:linear-gradient(to top, var(--primary), var(--accent));border-radius:12px;width:100%;transition:height 1s ease-out;position:absolute;bottom:0;left:0}.bar-label{color:var(--text-secondary);font-size:11px}.bar-value{color:var(--text-primary);font-size:10px;font-weight:600}.donut-chart-wrapper{justify-content:center;align-items:center;height:180px;display:flex;position:relative}.donut-label-overlay{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute}.donut-label-value{font-family:var(--font-heading);font-size:24px;font-weight:700}.donut-label-text{color:var(--text-secondary);font-size:11px}.table-card{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);border-radius:16px;padding:24px;overflow:hidden}.table-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.table-search{border:1px solid var(--border-color);color:#fff;width:260px;transition:var(--transition-smooth);background:#ffffff08;border-radius:8px;padding:10px 16px 10px 36px;font-size:13px}.table-search:focus{border-color:var(--primary);outline:none;width:320px}.table-container{overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%}.custom-table th{border-bottom:1px solid var(--border-color);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;padding:16px;font-size:12px;font-weight:600}.custom-table td{border-bottom:1px solid var(--border-color);color:var(--text-primary);padding:16px;font-size:14px}.custom-table tbody tr{transition:var(--transition-smooth)}.custom-table tbody tr:hover{background:#ffffff05}.badge{border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-active{color:var(--success);background:#10b9811f}.badge-inactive{color:var(--danger);background:#ef44441f}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;width:100%;max-width:500px;padding:32px;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleUp;box-shadow:0 10px 30px #00000080}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:4px}.modal-footer{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.toast-container{z-index:1100;flex-direction:column;gap:12px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-left:4px solid var(--primary);color:#fff;background:#1e293b;border-radius:8px;align-items:center;gap:12px;min-width:280px;padding:16px 24px;animation:.3s slideInRight;display:flex;box-shadow:0 4px 12px #0000004d}.toast-success{border-color:var(--success)}.toast-error{border-color:var(--danger)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.main-content{margin-left:0}.header{padding:0 16px}.page-container{padding:16px}}
