*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#181c27;--surface2:#1e2333;--border:#2a2f42;--primary:#4f7df9;--primary-dark:#3d65e0;--text:#e2e6f0;--text-muted:#6b7280;--green:#22c55e;--red:#ef4444;--sidebar-w:240px;--radius:8px;-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,sans-serif}body{background:var(--bg);color:var(--text);min-height:100vh}#root{min-height:100vh}.layout{flex-direction:column;min-height:100vh;display:flex}.navbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;align-items:center;gap:0;height:52px;padding:0 24px;display:flex;position:fixed;top:0;left:0;right:0}.navbar-brand{color:var(--text);flex-shrink:0;align-items:center;gap:8px;margin-right:24px;font-size:16px;font-weight:700;text-decoration:none;display:flex}.brand-icon{color:var(--primary);font-size:20px}.brand-icon-lg{color:var(--primary);text-align:center;font-size:36px;display:block}.navbar-nav{flex:1;align-items:center;gap:2px;display:flex}.nav-link{border-radius:var(--radius);color:var(--text-muted);white-space:nowrap;padding:6px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:block}.nav-link:hover{background:var(--surface2);color:var(--text)}.nav-link.active{color:var(--primary);background:#4f7df926}.navbar-right{flex-shrink:0;align-items:center;gap:12px;margin-left:auto;display:flex}.user-info{align-items:center;gap:8px;display:flex}.user-avatar{background:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:flex}.user-name{font-size:13px;font-weight:600}.user-role{color:var(--text-muted);font-size:11px}.main-content{flex:1;margin-top:52px;padding:28px 36px}.page-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.page-title{font-size:22px;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:3px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.table{border-collapse:collapse;width:100%;font-size:14px}.table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--surface2);padding:12px 16px;font-size:11px;font-weight:600}.table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:13px 16px}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--surface2)}.badge{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border);border-radius:20px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-block}.badge-green{color:var(--green);background:#22c55e1f;border-color:#22c55e4d}.badge-red{color:var(--red);background:#ef44441f;border-color:#ef44444d}.btn{border-radius:var(--radius);cursor:pointer;border:1px solid #0000;align-items:center;gap:6px;padding:9px 18px;font-size:14px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark)}.btn-secondary{color:var(--text-muted);border-color:var(--border);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--surface2);color:var(--text)}.btn-full{justify-content:center;width:100%}.btn-logout{color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:0 0;padding:7px 14px;font-family:inherit;font-size:13px;transition:all .15s}.btn-logout:hover{background:var(--surface2);color:var(--text)}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text);font-size:13px;font-weight:600}.form-group input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;padding:9px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.form-group input:focus{border-color:var(--primary)}.form-group input::placeholder{color:var(--text-muted)}.form-hint{color:var(--text-muted);font-size:12px}.form-row{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;display:grid}.form-row-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.alert{border-radius:var(--radius);padding:10px 14px;font-size:13px;font-weight:500}.alert-error{color:#f87171;background:#ef44441a;border:1px solid #ef444440}.alert-success{color:#4ade80;background:#22c55e1a;border:1px solid #22c55e40}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:480px;box-shadow:0 20px 60px #00000080}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.modal-header h2{font-size:16px;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-family:inherit;font-size:16px;transition:all .15s}.modal-close:hover{background:var(--surface2);color:var(--text)}.modal-body{padding:20px}.modal-form{flex-direction:column;gap:14px;display:flex}.modal-actions{justify-content:flex-end;gap:10px;padding-top:4px;display:flex}.login-page{background:radial-gradient(ellipse at top, #1a1f35 0%, var(--bg) 60%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:400px;padding:36px;box-shadow:0 24px 64px #0006}.login-brand{text-align:center;margin-bottom:28px}.login-brand h1{margin:8px 0 4px;font-size:22px;font-weight:800}.login-brand p{color:var(--text-muted);font-size:13px}.login-form{flex-direction:column;gap:16px;display:flex}.role-tabs{background:var(--bg);border-radius:var(--radius);padding:3px;display:flex}.role-tab{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;flex:1;padding:7px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.role-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px #0000004d}.empty-state{text-align:center;color:var(--text-muted);padding:48px 20px}.empty-icon{opacity:.4;margin-bottom:10px;font-size:32px}.credentials-box{flex-direction:column;gap:16px;display:flex}.cred-grid{gap:10px;display:grid}.cred-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:3px;padding:10px 14px;display:flex}.cred-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:11px;font-weight:600}.cred-item code{color:var(--primary);word-break:break-all;font-family:Fira Code,Cascadia Code,monospace;font-size:13px}.code-inline{background:var(--bg);color:var(--text-muted);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-family:Fira Code,Cascadia Code,monospace;font-size:12px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:20px}.stat-value{color:var(--primary);font-size:28px;font-weight:700}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:4px;font-size:12px;font-weight:500}.action-btns{align-items:center;gap:4px;display:flex}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{border:1px solid var(--border);width:30px;height:30px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;text-decoration:none;transition:all .15s;display:inline-flex;position:relative}.btn-icon:hover{background:var(--surface2);color:var(--text);border-color:var(--text-muted)}.btn-icon-danger{color:var(--red);border-color:#ef44444d}.btn-icon-danger:hover{color:var(--red);border-color:var(--red);background:#ef44441a}.btn-icon-warning{color:#f59e0b;border-color:#f59e0b4d}.btn-icon-warning:hover{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b}.btn-icon:after{content:attr(data-tooltip);color:var(--text);white-space:nowrap;border:1px solid var(--border);pointer-events:none;opacity:0;z-index:50;background:#1a1f2e;border-radius:5px;padding:4px 8px;font-size:11px;font-weight:500;transition:opacity .15s,transform .15s;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)scale(.85);box-shadow:0 4px 12px #0006}.btn-icon:hover:after{opacity:1;transform:translate(-50%)scale(1)}.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}.btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.backup-list{flex-direction:column;gap:8px;max-height:320px;display:flex;overflow-y:auto}.backup-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;font-size:13px;display:flex}.backup-filename{color:var(--text-muted);word-break:break-all;flex:1;font-family:Fira Code,monospace;font-size:11px}.backup-meta{flex-shrink:0;align-items:center;gap:8px;display:flex}.btn-link{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:13px;text-decoration:underline}.btn-link:hover{color:var(--primary-dark)}.modal-wide{max-width:640px}.size-cell{white-space:nowrap;align-items:center;gap:6px;display:flex}.tabs{border-bottom:1px solid var(--border);gap:2px;margin-bottom:20px;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.notif-badge{background:var(--red);color:#fff;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;margin-left:4px;padding:0 4px;font-size:10px;font-weight:700;line-height:1;display:inline-flex}.plan-badge{color:var(--primary);background:#4f7df91f;border:1px solid #4f7df94d;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.info-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.info-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px}.info-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:3px;font-size:11px;font-weight:600}.info-value{font-size:14px;font-weight:600}.section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;font-size:13px;font-weight:700}.recycle-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.recycle-item:last-child{border-bottom:none}.recycle-info{flex:1;min-width:0}.recycle-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.recycle-meta{color:var(--text-muted);margin-top:2px;font-size:12px}.recycle-actions{flex-shrink:0;gap:6px;display:flex}.days-left{color:var(--red);white-space:nowrap;font-size:11px;font-weight:600}.hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:4px;margin-right:8px;padding:4px;display:none}.hamburger span{background:var(--text-muted);border-radius:2px;width:20px;height:2px;transition:all .2s;display:block}@media (width<=768px){.hamburger{display:flex}.navbar-nav{background:var(--surface);border-bottom:1px solid var(--border);z-index:99;flex-direction:column;gap:2px;padding:8px;display:none;position:fixed;top:52px;left:0;right:0}.navbar-nav.open{display:flex}.navbar-nav .nav-link{width:100%;padding:10px 14px}.navbar-right{gap:6px}.user-name,.nav-link[href=\/change-password]{display:none}.main-content{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.page-header{flex-direction:column;align-items:flex-start;gap:10px}.form-row{grid-template-columns:1fr 1fr}.modal,.modal-wide{max-width:calc(100vw - 24px)}.table{font-size:13px}.table th,.table td{padding:10px}.info-grid{grid-template-columns:1fr}}
