:root{--accent:#6c3fe8;--accent-rgb:108,63,232;--accent-2:#00d4b4;--bg-base:#0a0e1a;--bg-surface:#13182a;--bg-elevated:#1c2338;--bg-hover:#232942;--border:hsla(0,0%,100%,.07);--border-accent:rgba(108,63,232,.25);--text-primary:#f0eef9;--text-secondary:#8b8fa8;--text-muted:#545870;--sidebar-w:240px}[data-theme=light]{--bg-base:#f4f3fa;--bg-surface:#fff;--bg-elevated:#f0eef9;--bg-hover:#e8e6f5;--border:rgba(0,0,0,.08);--border-accent:rgba(108,63,232,.2);--text-primary:#0a0e1a;--text-secondary:#5a5e78;--text-muted:#9a9eb8}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;font-family:Inter,sans-serif;background:var(--bg-base);color:var(--text-primary);font-size:14px;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:Inter,sans-serif}ul{list-style:none}.layout{height:100vh}.layout,.main{display:flex;overflow:hidden}.main{flex:1;min-width:0}.main,.sidebar{flex-direction:column}.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:.5px solid var(--border);display:flex;flex-shrink:0}.sidebar-logo{padding:24px 20px 20px;border-bottom:.5px solid var(--border);gap:10px}.logo-icon,.sidebar-logo{display:flex;align-items:center}.logo-icon{width:32px;height:32px;background:var(--accent);border-radius:8px;justify-content:center;font-size:16px;color:#fff;flex-shrink:0}.logo-text{font-family:Syne,sans-serif;font-weight:800;font-size:20px;letter-spacing:-.5px}.logo-text span{color:var(--accent)}.sidebar-nav{padding:12px 10px;flex:1;overflow-y:auto}.nav-section-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);padding:8px 10px 6px;font-weight:500}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;color:var(--text-secondary);font-size:13px;font-weight:500;transition:background .15s,color .15s;cursor:pointer;position:relative;margin-bottom:1px}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:rgba(var(--accent-rgb),.12);color:var(--accent)}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent);border-radius:0 3px 3px 0}.nav-item i{font-size:18px;flex-shrink:0}.nav-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:10px;font-weight:600;padding:2px 6px;border-radius:20px}.sidebar-bottom{padding:12px 10px;border-top:.5px solid var(--border)}.user-card{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .15s}.user-card:hover{background:var(--bg-hover)}.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.avatar,.user-name{font-size:12px;font-weight:600}.user-name{color:var(--text-primary)}.user-role{font-size:11px;color:var(--text-muted)}.topbar{height:56px;background:var(--bg-surface);border-bottom:.5px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0}.topbar-title{font-family:Syne,sans-serif;font-size:16px;font-weight:700;flex:1}.topbar-actions{gap:8px}.icon-btn,.topbar-actions{display:flex;align-items:center}.icon-btn{width:34px;height:34px;border-radius:8px;background:transparent;border:.5px solid var(--border);color:var(--text-secondary);justify-content:center;font-size:17px;transition:background .15s,color .15s}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.accent-btn{display:flex;align-items:center;gap:6px;padding:0 14px;height:34px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;transition:opacity .15s}.accent-btn:hover{opacity:.88}.page{flex:1;overflow-y:auto;padding:24px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.stat-card{background:var(--bg-surface);border:.5px solid var(--border);border-radius:12px;padding:18px 20px;position:relative;overflow:hidden;transition:border-color .2s}.stat-card:hover{border-color:var(--border-accent)}.stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-weight:500;margin-bottom:8px}.stat-value{font-family:Syne,sans-serif;font-size:26px;font-weight:800;color:var(--text-primary);line-height:1;margin-bottom:6px}.stat-delta{font-size:11px;display:flex;align-items:center;gap:4px}.stat-delta.up{color:#00d4b4}.stat-delta.down{color:#e05c5c}.stat-icon{position:absolute;top:18px;right:18px;font-size:22px;color:var(--accent);opacity:.5}.grid-3-1{display:grid;grid-template-columns:2fr 1fr;gap:14px;margin-bottom:24px}.card{background:var(--bg-surface);border:.5px solid var(--border);border-radius:12px;overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:.5px solid var(--border)}.card-title{font-family:Syne,sans-serif;font-size:14px;font-weight:700}.card-body{padding:20px}.card-action{font-size:11px;color:var(--accent);font-weight:500;cursor:pointer}.data-table{width:100%;border-collapse:collapse}.data-table th{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);font-weight:600;padding:10px 16px;text-align:left}.data-table td,.data-table th{border-bottom:.5px solid var(--border)}.data-table td{padding:12px 16px;font-size:13px;color:var(--text-secondary);transition:background .12s}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-hover)}.td-name{color:var(--text-primary)!important;font-weight:500}.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;padding:3px 8px;border-radius:20px}.badge-success{background:#00d4b41f;color:#00d4b4}.badge-warning{background:#f0b4281f;color:#f0b428}.badge-danger{background:#e05c5c1f;color:#e05c5c}.badge-info{background:#6c3fe81f;color:var(--accent)}.progress-bar{height:4px;background:var(--bg-elevated);border-radius:4px;overflow:hidden;margin-top:6px}.progress-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .6s ease}.progress-fill.cyan{background:var(--accent-2)}.activity-item{display:flex;gap:12px;padding:10px 0;border-bottom:.5px solid var(--border)}.activity-item:last-child{border-bottom:none}.activity-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:5px}.activity-dot.cyan{background:var(--accent-2)}.activity-dot.warn{background:#f0b428}.activity-text{font-size:13px;color:var(--text-primary);line-height:1.5}.activity-time{font-size:11px;color:var(--text-muted);margin-top:2px}.chart-wrap{position:relative;height:200px}.module-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.module-pill{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-elevated);border:.5px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .2s}.module-pill:hover{border-color:var(--border-accent)}.module-pill.on{border-color:#00d4b459;background:#00d4b40d}.pill-icon{font-size:18px;color:var(--text-muted)}.module-pill.on .pill-icon{color:var(--accent-2)}.pill-name{font-size:12px;font-weight:600;color:var(--text-secondary)}.module-pill.on .pill-name{color:var(--text-primary)}.accent-picker{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.accent-swatch{width:24px;height:24px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .15s}.accent-swatch:hover{transform:scale(1.15)}.accent-swatch.active{border-color:var(--text-primary)}.theme-toggle{display:flex;background:var(--bg-elevated);border:.5px solid var(--border);border-radius:8px;padding:3px;gap:2px}.theme-opt{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:6px;font-size:12px;font-weight:500;color:var(--text-muted);border:none;background:transparent;cursor:pointer;transition:background .15s,color .15s}.theme-opt.active{background:var(--bg-surface);color:var(--text-primary)}.fade-enter-active,.fade-leave-active{transition:opacity .2s ease}.fade-enter-from,.fade-leave-to{opacity:0}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.auth-wrap{min-height:100vh;background:var(--bg-base);display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{background:var(--bg-surface);border:.5px solid var(--border-accent);border-radius:16px;padding:40px;width:100%;max-width:480px}.auth-logo{font-family:Syne,sans-serif;font-weight:800;font-size:24px;letter-spacing:-.5px;margin-bottom:24px;color:var(--text-primary)}.auth-logo span{color:var(--accent)}.auth-title{font-family:Syne,sans-serif;font-size:22px;font-weight:800;color:var(--text-primary);margin-bottom:6px}.auth-sub{font-size:13px;color:var(--text-secondary);margin-bottom:28px}.auth-error{background:#e05c5c1a;border:.5px solid rgba(224,92,92,.3);border-radius:8px;padding:10px 14px;font-size:13px;color:#e05c5c;margin-bottom:20px;display:flex;align-items:center;gap:8px}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{font-size:12px;color:var(--text-muted);font-weight:500}.auth-field input{background:var(--bg-elevated);border:.5px solid var(--border);border-radius:8px;padding:10px 14px;font-size:14px;color:var(--text-primary);font-family:Inter,sans-serif;outline:none;transition:border-color .15s;width:100%}.auth-field input:focus{border-color:var(--accent)}.auth-field input::-moz-placeholder{color:var(--text-muted)}.auth-field input::placeholder{color:var(--text-muted)}.auth-pw-wrap{position:relative}.auth-pw-wrap input{padding-right:42px}.auth-pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;color:var(--text-secondary);font-size:16px;padding:4px}.auth-btn,.auth-pw-toggle{border:none;cursor:pointer}.auth-btn{background:var(--accent);color:#fff;border-radius:8px;padding:12px;font-size:14px;font-weight:600;font-family:Inter,sans-serif;transition:opacity .15s;margin-top:4px;width:100%}.auth-btn:hover{opacity:.88}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-switch{text-align:center;font-size:13px;color:var(--text-secondary);margin-top:24px}.auth-switch span{color:var(--accent);cursor:pointer;font-weight:500;margin-left:4px}.auth-switch span:hover{text-decoration:underline}.spin{animation:spin 1s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.placeholder-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 56px)}.placeholder-inner{text-align:center}.placeholder-icon{width:80px;height:80px;border-radius:20px;background:rgba(var(--accent-rgb),.1);border:.5px solid var(--border-accent);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:36px;color:var(--accent)}.placeholder-title{font-family:Syne,sans-serif;font-size:24px;font-weight:800;color:var(--text-primary);margin-bottom:8px}.placeholder-sub{font-size:14px;color:var(--text-muted);margin-bottom:28px}.settings-label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);font-weight:600;margin-bottom:10px}.pill-toggle{margin-left:auto;width:28px;height:16px;border-radius:8px;background:var(--bg-base);border:.5px solid var(--border);position:relative;transition:background .2s}.pill-toggle.on{background:var(--accent-2);border-color:var(--accent-2)}.pill-thumb{position:absolute;top:2px;left:2px;width:10px;height:10px;border-radius:50%;background:var(--text-muted);transition:transform .2s,background .2s}.pill-toggle.on .pill-thumb{transform:translate(12px);background:#fff}.infra-pill{gap:10px;padding:12px;background:var(--bg-elevated);border:.5px solid var(--border);border-radius:10px;font-size:20px}.infra-pill,.topbar-user{display:flex;align-items:center}.topbar-user{gap:8px;padding:4px 10px;border-radius:8px;cursor:pointer;border:.5px solid var(--border);transition:background .15s;position:relative}.topbar-user:hover{background:var(--bg-hover)}.topbar-username{font-size:13px;font-weight:500;color:var(--text-primary);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-elevated);border:.5px solid var(--border);border-radius:10px;min-width:180px;z-index:50;box-shadow:0 8px 24px #0000004d;overflow:hidden}.topbar-menu-item{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:background .12s}.topbar-menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.topbar-menu-item.danger{color:#e05c5c}.topbar-menu-item.danger:hover{background:#e05c5c1a}.topbar-menu-divider{height:.5px;background:var(--border);margin:4px 0}.form-select{background:var(--bg-elevated);border:.5px solid var(--border);border-radius:8px;padding:10px 14px;font-size:14px;color:var(--text-primary);width:100%;outline:none}.form-select:focus{border-color:var(--accent)}.portal-wrap{min-height:100vh;background:var(--bg-base);display:flex;flex-direction:column}.portal-header{height:56px;background:var(--bg-surface);border-bottom:.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px}.portal-badge{font-size:11px;background:var(--accent);color:#fff;border-radius:6px;padding:2px 8px;margin-left:10px}.portal-user{display:flex;align-items:center;gap:12px}.portal-email{font-size:13px;color:var(--text-muted)}.portal-nav{display:flex;gap:4px;padding:12px 24px;background:var(--bg-surface);border-bottom:.5px solid var(--border)}.portal-nav-item{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;font-size:14px;color:var(--text-muted);text-decoration:none;transition:all .15s}.portal-nav-item.active,.portal-nav-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.portal-nav-item.active{color:var(--accent)}.portal-main{flex:1;padding:24px;max-width:1200px;width:100%;margin:0 auto}.portal-logo{display:flex;flex-direction:column;align-items:flex-start;gap:2px;line-height:1}.portal-badge{font-size:10px;color:var(--accent);font-weight:600;letter-spacing:.05em;text-transform:uppercase;background:none;padding:0;margin:0}.toast-success{position:fixed;bottom:32px;right:32px;background:var(--accent);color:#fff;padding:14px 22px;border-radius:10px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;z-index:9999;box-shadow:0 8px 32px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
