@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--primary:#1e40af;--primary-hover:#1d4ed8;--primary-light:#eff6ff;--primary-gradient:linear-gradient(135deg, #1e40af, #6366f1);--accent:#6366f1;--success:#059669;--success-light:#ecfdf5;--warning:#d97706;--warning-light:#fffbeb;--danger:#dc2626;--danger-light:#fef2f2;--info:#0891b2;--info-light:#ecfeff;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--sidebar-width:270px;--topbar-height:64px;--shadow-sm:0 1px 2px 0 #0000000a;--shadow:0 1px 3px 0 #0000000f, 0 1px 2px -1px #0000000f;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-xl:20px;--transition-fast:all .15s cubic-bezier(.4, 0, .2, 1);--transition:all .2s cubic-bezier(.4, 0, .2, 1);--transition-slow:all .3s 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;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-family);color:var(--gray-800);background-color:#f8fafc;line-height:1.6}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.app-layout{min-height:100vh;display:flex}.app-sidebar{width:var(--sidebar-width);border-right:1px solid var(--gray-200);z-index:100;background:#fff;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--gray-200);flex-shrink:0;align-items:center;gap:12px;height:64px;padding:0 20px;display:flex}.sidebar-logo-icon{background:var(--primary-gradient);border-radius:var(--radius);color:#fff;letter-spacing:-.02em;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:14px;font-weight:800;display:flex}.sidebar-logo-text{flex-direction:column;display:flex}.sidebar-logo-title{color:var(--gray-900);letter-spacing:-.01em;font-size:15px;font-weight:700;line-height:1.2}.sidebar-logo-subtitle{color:var(--gray-400);font-size:11px;font-weight:400;line-height:1.2}.sidebar-close-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--gray-400);transition:var(--transition-fast);justify-content:center;align-items:center;margin-left:auto;display:none}.sidebar-close-btn:hover{background:var(--gray-100);color:var(--gray-600)}.sidebar-nav{flex:1;padding:8px 12px;overflow-y:auto}.sidebar-section-label{text-transform:uppercase;letter-spacing:1px;color:var(--gray-400);margin-top:20px;margin-bottom:6px;padding:0 10px;font-size:10px;font-weight:600}.sidebar-section-label:first-child{margin-top:8px}.sidebar-nav-item{height:40px;color:var(--gray-600);transition:var(--transition-fast);border-radius:12px;align-items:center;gap:10px;margin-bottom:2px;padding:0 10px;font-size:14px;font-weight:500;display:flex;position:relative}.sidebar-nav-item:hover{background:var(--gray-50);color:var(--gray-800)}.sidebar-nav-item.active{background:var(--primary-light);color:var(--primary);font-weight:600}.sidebar-nav-item.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;left:-12px;transform:translateY(-50%)}.sidebar-nav-icon{opacity:.7;flex-shrink:0;width:20px;height:20px}.sidebar-nav-item.active .sidebar-nav-icon{opacity:1;color:var(--primary)}.sidebar-nav-badge{background:var(--danger);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;margin-left:auto;padding:0 6px;font-size:11px;font-weight:600;display:flex}.sidebar-user{border-top:1px solid var(--gray-200);flex-shrink:0;align-items:center;gap:12px;padding:16px 20px;display:flex}.sidebar-user-avatar{background:var(--primary-gradient);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:var(--gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-logout{color:var(--gray-400);cursor:pointer;transition:var(--transition-fast);font-size:12px}.sidebar-user-logout:hover{color:var(--danger)}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;background:#0f172a66;animation:.2s ease-out fadeIn;display:none;position:fixed;inset:0}.sidebar-overlay.visible{display:block}.app-main{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.app-content{min-height:calc(100vh - var(--topbar-height));flex:1;padding:24px 32px}.app-topbar{height:var(--topbar-height);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--gray-200);z-index:50;background:#ffffffd9;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-title{color:var(--gray-900);letter-spacing:-.01em;font-size:18px;font-weight:700}.topbar-actions{align-items:center;gap:6px;display:flex}.topbar-icon-btn{width:38px;height:38px;color:var(--gray-500);transition:var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.topbar-icon-btn:hover{background:var(--gray-100);color:var(--gray-700)}.topbar-bell-badge{background:var(--danger);color:#fff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;animation:2s ease-in-out infinite pulse;display:flex;position:absolute;top:4px;right:4px}.topbar-divider{background:var(--gray-200);width:1px;height:24px;margin:0 6px}.topbar-user{border-radius:var(--radius);transition:var(--transition-fast);cursor:pointer;align-items:center;gap:10px;padding:6px 10px;display:flex}.topbar-user:hover{background:var(--gray-50)}.topbar-avatar{background:var(--primary-gradient);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:flex}.topbar-username{color:var(--gray-700);font-size:14px;font-weight:500}.topbar-logout{border-radius:var(--radius);width:36px;height:36px;color:var(--gray-400);transition:var(--transition-fast);justify-content:center;align-items:center;display:flex}.topbar-logout:hover{background:var(--danger-light);color:var(--danger)}.mobile-menu-btn{border-radius:var(--radius);width:38px;height:38px;color:var(--gray-600);transition:var(--transition-fast);justify-content:center;align-items:center;display:none}.mobile-menu-btn:hover{background:var(--gray-100)}.card{border:1px solid var(--gray-200);border-radius:var(--radius-lg);transition:var(--transition);background:#fff;padding:24px}.card:hover{box-shadow:var(--shadow-lg)}.card-title{color:var(--gray-900);margin-bottom:16px;font-size:15px;font-weight:600}.card-glass{-webkit-backdrop-filter:blur(12px);background:#fffc;border:1px solid #ffffff4d}.stat-card{border:1px solid var(--gray-200);border-radius:var(--radius-lg);transition:var(--transition);background:#fff;align-items:flex-start;gap:16px;padding:24px;display:flex}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.stat-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-content{flex:1;min-width:0}.stat-value{color:var(--gray-900);letter-spacing:-.02em;font-size:28px;font-weight:800;line-height:1.1}.stat-label{color:var(--gray-500);margin-top:4px;font-size:13px}.stat-change{border-radius:20px;align-items:center;gap:4px;margin-top:6px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-flex}.stat-change.positive{color:var(--success);background:var(--success-light)}.stat-change.negative{color:var(--danger);background:var(--danger-light)}.table-container{border-radius:var(--radius-lg);border:1px solid var(--gray-200);background:#fff;overflow-x:auto}.table-wrapper{overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);background:var(--gray-50);border-bottom:2px solid var(--gray-200);white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:600}.table td{color:var(--gray-700);border-bottom:1px solid #f1f5f9;padding:14px 16px;font-size:14px}.table tbody tr{transition:var(--transition-fast)}.table tbody tr:hover td{background:#f8fafc}.table tbody tr:last-child td{border-bottom:none}.table-clickable tbody tr{cursor:pointer}.table-empty{text-align:center;color:var(--gray-400);padding:48px 16px;font-size:14px}.skeleton{background:linear-gradient(90deg, var(--gray-100) 25%, var(--gray-200) 50%, var(--gray-100) 75%);background-size:200% 100%;border-radius:4px;height:16px;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.btn{border-radius:var(--radius);transition:var(--transition);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;line-height:1;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none!important;transform:none!important}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 14px #1e40af40}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #1e40af59}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #1e40af4d}.btn-secondary{border:1px solid var(--gray-200);color:var(--gray-700);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{color:var(--gray-600);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--gray-800)}.btn-sm{padding:7px 14px;font-size:13px}.btn-md{padding:10px 20px;font-size:14px}.btn-lg{padding:12px 28px;font-size:15px}.btn-icon{border-radius:50%;width:36px;height:36px;padding:0}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}.btn-secondary .btn-spinner{border-color:#0000001f;border-top-color:var(--gray-600)}.form-group{margin-bottom:20px}.form-label{color:var(--gray-700);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-input,.form-select{border:1.5px solid var(--gray-200);border-radius:var(--radius);width:100%;color:var(--gray-900);transition:var(--transition);background:#fff;outline:none;padding:10px 14px;font-size:14px}.form-input::placeholder{color:var(--gray-400)}.form-input:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1e40af1a}.form-input.error,.form-select.error{border-color:var(--danger)}.form-input.error:focus,.form-select.error:focus{box-shadow:0 0 0 3px #dc26261a}.form-error{color:var(--danger);margin-top:4px;font-size:12px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.form-input-icon-wrapper{position:relative}.form-input-icon-wrapper .form-input{padding-left:42px}.form-input-icon{width:18px;height:18px;color:var(--gray-400);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.form-input-action{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--gray-400);cursor:pointer;transition:var(--transition-fast);justify-content:center;align-items:center;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.form-input-action:hover{color:var(--gray-600);background:var(--gray-50)}.badge{white-space:nowrap;border-radius:20px;align-items:center;padding:4px 10px;font-size:12px;font-weight:500;line-height:1.4;display:inline-flex}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:var(--info-light);color:var(--info)}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#0f172a80;justify-content:center;align-items:center;padding:24px;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-card{border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);background:#fff;flex-direction:column;width:90vw;max-width:520px;max-height:90vh;animation:.25s ease-out modalSlideUp;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{color:var(--gray-900);font-size:16px;font-weight:600}.modal-close{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--gray-400);transition:var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--gray-100);color:var(--gray-600)}.modal-body{flex:1;padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--gray-200);justify-content:flex-end;align-items:center;gap:12px;padding:16px 24px;display:flex}.pagination{justify-content:center;align-items:center;gap:4px;display:flex}.pagination-btn{border-radius:var(--radius);min-width:36px;height:36px;color:var(--gray-600);transition:var(--transition-fast);justify-content:center;align-items:center;font-size:14px;font-weight:500;display:flex}.pagination-btn:hover:not(:disabled):not(.active){background:var(--gray-100);color:var(--gray-800)}.pagination-btn:disabled{color:var(--gray-300);cursor:not-allowed}.pagination-btn.active{background:var(--primary);color:#fff}.pagination-ellipsis{min-width:36px;height:36px;color:var(--gray-400);justify-content:center;align-items:center;font-size:14px;display:flex}.spinner{border:2.5px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:.6s linear infinite spin}.spinner-sm{border-width:2px;width:18px;height:18px}.spinner-md{width:32px;height:32px}.spinner-lg{width:48px;height:48px}.loading-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;background:#fffc;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.spinner-fullpage{z-index:60;background:#fffc;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.spinner-inline{justify-content:center;align-items:center;display:inline-flex}.toast-container{z-index:2000;pointer-events:none;flex-direction:column;gap:10px;padding:0;display:flex;position:fixed;top:20px;right:20px}.toast{border-radius:var(--radius);box-shadow:var(--shadow-lg);pointer-events:auto;background:#fff;border-left:4px solid;align-items:center;gap:12px;min-width:320px;max-width:440px;padding:14px 20px;animation:.3s cubic-bezier(.4,0,.2,1) slideInRight;display:flex}.toast-success{border-left-color:var(--success)}.toast-error{border-left-color:var(--danger)}.toast-info{border-left-color:var(--info)}.toast-icon{flex-shrink:0}.toast-message{color:var(--gray-700);flex:1;font-size:14px}.toast-close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--gray-400);transition:var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.toast-close:hover{background:var(--gray-100);color:var(--gray-600)}.toast-exit{animation:.2s ease-in forwards toastSlideOut}.login-page{min-height:100vh;display:flex}.login-left{background:var(--primary-gradient);flex:1;justify-content:center;align-items:center;padding:60px;display:flex;position:relative;overflow:hidden}.login-left-content{z-index:2;color:#fff;max-width:480px;position:relative}.login-brand{letter-spacing:.04em;margin-bottom:8px;font-size:36px;font-weight:800;line-height:1.1}.login-tagline{opacity:.8;margin-bottom:48px;font-size:18px;font-weight:300}.login-features{flex-direction:column;gap:20px;display:flex}.login-feature{opacity:.9;align-items:center;gap:14px;font-size:15px;font-weight:400;display:flex}.login-feature-icon{background:#ffffff26;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.login-shape{opacity:.08;background:#fff;border-radius:50%;position:absolute}.login-shape-1{width:400px;height:400px;top:-120px;right:-100px}.login-shape-2{width:300px;height:300px;bottom:-80px;left:-80px}.login-shape-3{opacity:.05;width:180px;height:180px;top:50%;left:60%}.login-right{background:#fff;flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.login-form-wrapper{width:100%;max-width:400px}.login-logo-area{margin-bottom:40px}.login-title{color:var(--gray-900);letter-spacing:-.02em;margin-bottom:8px;font-size:28px;font-weight:700}.login-subtitle{color:var(--gray-500);margin-bottom:32px;font-size:15px}.login-error{background:var(--danger-light);color:var(--danger);border-radius:var(--radius);border:1px solid #dc262626;align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;font-size:14px;display:flex}.login-forgot{text-align:center;color:var(--gray-400);transition:var(--transition-fast);margin-top:20px;font-size:13px;display:block}.login-forgot:hover{color:var(--primary)}.animate-in{animation:.3s ease-out fadeInUp}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (width<=1024px){.app-sidebar{width:240px}.app-main{margin-left:240px}.app-content{padding:20px}.app-topbar{padding:0 20px}}@media (width<=768px){.app-sidebar{width:var(--sidebar-width);transform:translate(-100%)}.app-sidebar.open{transform:translate(0)}.sidebar-close-btn{display:flex}.app-main{margin-left:0}.mobile-menu-btn{display:flex}.app-topbar{padding:0 16px}.app-content{padding:16px}.topbar-username,.topbar-divider{display:none}.login-page{flex-direction:column}.login-left{flex:none;min-height:auto;padding:40px 24px}.login-brand{font-size:24px}.login-tagline{margin-bottom:0;font-size:14px}.login-features,.login-shape{display:none}.login-right{flex:1;padding:32px 24px}.login-form-wrapper{max-width:100%}.modal-overlay{padding:16px}.modal-card{width:100%;max-height:90vh}.toast-container{top:12px;left:16px;right:16px}.toast{min-width:auto;max-width:100%}}@media (width<=480px){.app-content{padding:12px}.card,.stat-card{padding:16px}.stat-value{font-size:22px}.stat-icon{width:40px;height:40px}.table th,.table td{padding:10px 12px}.login-title{font-size:22px}}
