.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-box{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:400px;animation:slideIn .5s ease-out}.login-header{text-align:center;margin-bottom:30px}.login-header svg{color:var(--primary);margin-bottom:16px}.login-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.login-header p{color:var(--text-secondary);font-size:14px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:8px;font-size:14px}.form-group input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;transition:var(--transition);background-color:var(--bg-primary)}.form-group input:disabled{background-color:var(--bg-tertiary);cursor:not-allowed}.error-message{background-color:#fee2e2;color:#991b1b;padding:12px;border-radius:8px;font-size:14px;margin-bottom:20px;border-left:4px solid var(--danger)}.login-button{width:100%;padding:12px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:var(--transition);box-shadow:0 4px 12px #2563eb4d}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #2563eb66}.login-button:disabled{opacity:.7;cursor:not-allowed}.module-card{background:#fff;border-radius:16px;padding:28px 24px 24px;border:2px solid transparent;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:flex-start;gap:0;box-shadow:0 1px 3px #0000000f;position:relative;min-height:180px}.module-card:hover{border-color:var(--primary, #3b82f6);box-shadow:0 4px 20px #2563eb1a}.module-card-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:20px}.module-card-title{font-size:17px;font-weight:700;color:var(--text-primary, #1e293b);line-height:1.3;margin:0 0 8px;transition:color .2s ease}.module-card:hover .module-card-title{color:var(--primary, #3b82f6)}.module-card-desc{font-size:13px;color:var(--text-secondary, #64748b);line-height:1.5;margin:0;flex:1}.module-card-action{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--primary, #3b82f6);margin-top:16px;opacity:0;transform:translateY(4px);transition:all .2s ease}.module-card:hover .module-card-action{opacity:1;transform:translateY(0)}@media (max-width: 640px){.module-card{padding:22px 18px 18px;min-height:150px}.module-card-icon{width:46px;height:46px;border-radius:12px;margin-bottom:16px}.module-card-title{font-size:15px}}.sidebar{position:fixed;top:0;left:0;height:100vh;background:#1a1d23;display:flex;flex-direction:column;z-index:200;transition:width .25s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:2px 0 8px #0000004d}.sidebar.collapsed{width:64px}.sidebar.expanded{width:240px}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:16px;cursor:pointer;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo-icon{width:32px;height:32px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#fff;flex-shrink:0}.sidebar-logo-text{font-size:18px;font-weight:700;color:#fff;white-space:nowrap;letter-spacing:-.5px}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:100%;padding:8px 0;background:none;border:none;color:#fff6;cursor:pointer;transition:color .2s;flex-shrink:0}.sidebar-toggle:hover{color:#ffffffb3}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-bottom:2px;position:relative}.sidebar-item:hover{background:#ffffff14}.sidebar-item.active{background:#3b82f626}.sidebar-item.active .sidebar-item-icon{color:#3b82f6}.sidebar-item.active .sidebar-item-label{color:#fff;font-weight:600}.sidebar-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:#3b82f6;border-radius:0 3px 3px 0}.sidebar-item-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:#ffffff80;flex-shrink:0;transition:color .2s}.sidebar-item:hover .sidebar-item-icon{color:#fffc}.sidebar-item-label{font-size:13px;color:#ffffffa6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s}.sidebar-item:hover .sidebar-item-label{color:#ffffffe6}.sidebar-divider{height:1px;background:#ffffff14;margin:6px 12px}.sidebar-back{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;color:#ffffff80;font-size:13px;transition:all .2s;margin-bottom:2px}.sidebar-back:hover{background:#ffffff14;color:#ffffffe6}.sidebar-module-title{padding:6px 12px 2px;font-size:11px;font-weight:700;color:#ffffff59;text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-menu-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:6px;cursor:pointer;transition:all .15s ease;margin-bottom:1px}.sidebar-menu-item:hover{background:#ffffff14}.sidebar-menu-item.active{background:#3b82f626}.sidebar-menu-item.active .sidebar-menu-item-label{color:#fff;font-weight:600}.sidebar-menu-item.active .sidebar-menu-item-icon{color:#3b82f6}.sidebar-menu-item-icon{display:flex;align-items:center;justify-content:center;width:16px;flex-shrink:0;color:#fff6;font-size:12px;transition:color .15s}.sidebar-menu-item:hover .sidebar-menu-item-icon{color:#ffffffb3}.sidebar-menu-item-label{font-size:13px;color:#fff9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s;line-height:1.3}.sidebar-menu-item:hover .sidebar-menu-item-label{color:#ffffffe6}.sidebar-menu-item.branch .sidebar-menu-item-label{font-weight:600;color:#ffffffb3}.sidebar-footer{padding:8px;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}.sidebar-user{display:block;padding:6px 12px;font-size:12px;color:#fff6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-item.logout:hover{background:#ef44441f}.sidebar-item.logout:hover .sidebar-item-icon,.sidebar-item.logout:hover .sidebar-item-label{color:#ef4444}.sidebar.collapsed .sidebar-item{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-item-icon{width:22px;height:22px}.sidebar.collapsed .sidebar-back{justify-content:center}.sidebar.collapsed .sidebar-menu-item{justify-content:center;padding:10px}.sidebar-tooltip-portal{position:fixed;transform:translateY(-50%);background:#1e293b;color:#fff;padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;pointer-events:none;z-index:9999;box-shadow:0 4px 12px #00000059;animation:tooltipFadeIn .12s ease-out}.sidebar-tooltip-portal:before{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:5px solid transparent;border-right-color:#1e293b}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-50%) translate(4px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.dashboard-with-sidebar{margin-left:64px;transition:margin-left .25s cubic-bezier(.4,0,.2,1);min-height:100vh}@media (max-width: 768px){.sidebar.expanded{width:100vw}.dashboard-with-sidebar,.dashboard-with-sidebar.sidebar-expanded{margin-left:0}}.menu-card{background:#fff;border-radius:12px;padding:20px;border:2px solid transparent;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:16px;box-shadow:0 1px 3px #0000000f}.menu-card:hover{border-color:var(--primary, #3b82f6);box-shadow:0 4px 16px #2563eb1a;transform:translateY(-1px)}.menu-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:20px}.menu-card-info{flex:1;min-width:0}.menu-card-title{font-size:15px;font-weight:600;color:var(--text-primary, #1e293b);margin:0;line-height:1.3;transition:color .2s}.menu-card:hover .menu-card-title{color:var(--primary, #3b82f6)}.menu-card-count{font-size:12px;color:var(--text-secondary, #64748b);margin:4px 0 0}.menu-card-arrow{color:var(--text-tertiary, #94a3b8);flex-shrink:0;transition:all .2s}.menu-card:hover .menu-card-arrow{color:var(--primary, #3b82f6);transform:translate(2px)}.menu-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:24px;flex-wrap:wrap}.menu-breadcrumb-item{font-size:14px;color:var(--text-secondary, #64748b);cursor:pointer;transition:color .2s;background:none;border:none;padding:0;font-family:inherit}.menu-breadcrumb-item:hover{color:var(--primary, #3b82f6)}.menu-breadcrumb-item.current{color:var(--text-primary, #1e293b);font-weight:600;cursor:default}.menu-breadcrumb-sep{color:var(--text-tertiary, #94a3b8);font-size:12px}.menu-content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.menu-content-header h2{font-size:24px;font-weight:700;color:var(--text-primary)}.menu-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.menu-content-empty,.menu-content-loading{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:14px}@media (max-width: 768px){.menu-cards-grid{grid-template-columns:1fr}.menu-card{padding:16px}.menu-card-icon{width:42px;height:42px}}.dashboard-with-sidebar{margin-left:64px;transition:margin-left .25s cubic-bezier(.4,0,.2,1);min-height:100vh;background-color:var(--bg-secondary)}.dashboard-with-sidebar.sidebar-expanded{margin-left:240px}.dashboard-main{flex:1;max-width:1400px;padding:28px 32px;width:100%}.modules-container{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modules-toolbar{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:24px}.modules-welcome{flex-shrink:0}.modules-welcome h2{font-size:28px;font-weight:800;color:var(--text-primary);margin-bottom:4px;letter-spacing:-.5px}.modules-welcome p{font-size:14px;color:var(--text-secondary)}.modules-search{position:relative;width:300px;flex-shrink:0}.modules-search .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.search-input{width:100%;padding:10px 14px 10px 42px;border:1px solid var(--border);border-radius:10px;font-size:14px;color:var(--text-primary);background:#fff;outline:none;transition:all .2s ease}.search-input::placeholder{color:var(--text-tertiary)}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}.modules-status{grid-column:1 / -1;text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:15px}@media (max-width: 768px){.dashboard-with-sidebar,.dashboard-with-sidebar.sidebar-expanded{margin-left:0}.dashboard-main{padding:20px 16px}.modules-toolbar{flex-direction:column;align-items:stretch;gap:16px}.modules-welcome h2{font-size:22px}.modules-search{width:100%}.modules-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}}.db-setup-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1e293b,#0f172a);padding:20px}.db-setup-box{background:#fff;border-radius:12px;box-shadow:0 25px 80px #0000004d;padding:40px;width:100%;max-width:600px;animation:slideIn .5s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.db-setup-header{text-align:center;margin-bottom:40px}.db-setup-header svg{color:var(--primary);margin-bottom:16px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.db-setup-header h1{font-size:26px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.db-setup-header p{color:var(--text-secondary);font-size:14px}.db-setup-form{margin-bottom:30px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:600;color:var(--text-primary);margin-bottom:8px;font-size:14px}.form-group input{padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;transition:var(--transition);background-color:var(--bg-primary);font-family:Courier New,monospace}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-group input:disabled{background-color:var(--bg-tertiary);cursor:not-allowed;opacity:.6}.status-message{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:16px;animation:slideIn .3s ease-out}.status-message.success{background-color:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.status-message.error{background-color:#fef2f2;color:#7f1d1d;border:1px solid #fecaca}.status-message.loading{background-color:#eff6ff;color:#0c4a6e;border:1px solid #bfdbfe}.status-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.status-icon .spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.form-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.btn{padding:12px 16px;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;box-shadow:0 4px 12px #2563eb4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background-color:#e0e7ff;border-color:var(--primary);color:var(--primary)}.btn:disabled{opacity:.5;cursor:not-allowed}.db-setup-info{background-color:var(--bg-secondary);border-left:4px solid var(--primary);padding:16px;border-radius:8px}.db-setup-info h3{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.db-setup-info ul{list-style:none;padding:0;margin:0}.db-setup-info li{font-size:13px;color:var(--text-secondary);margin-bottom:8px;line-height:1.5}.db-setup-info li:last-child{margin-bottom:0}.db-setup-info strong{color:var(--text-primary);font-weight:600}@media (max-width: 640px){.db-setup-box{padding:24px}.form-row{grid-template-columns:1fr;gap:12px}.form-actions{grid-template-columns:1fr;gap:10px}.db-setup-header h1{font-size:22px}}:root{--primary: #2563eb;--primary-dark: #1e40af;--primary-light: #dbeafe;--secondary: #64748b;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #1e293b;--text-secondary: #64748b;--text-tertiary: #94a3b8;--border: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--transition: all .3s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary)}html,body,#root{width:100%;height:100%}
