*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--bg-card:#1a1d27;--bg-sidebar:#141720;--bg-input:#232635;--border:#2a2d3a;--text:#e4e6f0;--text-muted:#8b8fa3;--primary:#e87e04;--primary-hover:#f59a3e;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--radius:8px;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::-webkit-scrollbar-corner{background:0 0}a{color:var(--primary);text-decoration:none}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;width:240px;padding:1.25rem 0;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-brand{color:var(--primary);border-bottom:1px solid var(--border);margin-bottom:.75rem;padding:0 1.25rem 1.25rem;font-size:1.15rem;font-weight:700}.sidebar-section{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:1.25rem 1.25rem .35rem;font-size:.65rem;font-weight:600}.sidebar a{color:var(--text-muted);align-items:center;gap:.5rem;padding:.5rem 1.25rem;font-size:.875rem;transition:all .15s;display:flex}.sidebar a:hover,.sidebar a.active{color:var(--text);background:#e87e041a}.sidebar a.active{border-right:2px solid var(--primary)}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding:1rem 1.25rem}.main-content{flex:1;min-height:100vh;margin-left:240px;padding:1.5rem 2rem}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.page-header h1{font-size:1.5rem;font-weight:700}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.stat-card .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-size:.75rem}.stat-card .value{font-size:1.75rem;font-weight:700}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}table{border-collapse:collapse;width:100%;font-size:.875rem}thead{background:#ffffff08}th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.75rem;font-weight:600}.th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .1s}.th-sortable:hover{color:var(--text)}.th-content{align-items:center;gap:.3rem;display:inline-flex}.sort-indicator{opacity:.25;font-size:.6rem;transition:opacity .1s}.th-sortable:hover .sort-indicator{opacity:.5}.sort-active{opacity:1;color:var(--primary)}td{border-bottom:1px solid var(--border);padding:.75rem 1rem}tbody tr:hover{background:#ffffff05}tbody tr:last-child td{border-bottom:none}.badge{text-transform:uppercase;letter-spacing:.03em;border-radius:999px;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.badge-success{color:var(--success);background:#22c55e26}.badge-warning{color:var(--warning);background:#f59e0b26}.badge-danger{color:var(--danger);background:#ef444426}.badge-info{color:var(--primary);background:#e87e0426}.badge-muted{color:var(--text-muted);background:#8b8fa326}.btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{color:var(--text-muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover{color:var(--text);border-color:var(--text-muted)}.btn-sm{padding:.3rem .6rem;font-size:.75rem}.form-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}@media (width<=600px){.form-grid{grid-template-columns:1fr}}.form-group{margin-bottom:0}.form-group label{color:var(--text-muted);margin-bottom:.35rem;font-size:.8rem;font-weight:500;display:block}input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],select,textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);font-size:.875rem;font-family:var(--font);padding:.6rem .75rem;transition:border-color .15s}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%238b8fa3' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2rem}input:focus,select:focus,textarea:focus{border-color:var(--primary);outline:none}.custom-select{width:100%;position:relative}.custom-select-trigger{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);font-size:.875rem;font-family:var(--font);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;padding:.6rem .75rem;transition:border-color .15s;display:flex}.custom-select-trigger:hover{border-color:var(--text-muted)}.custom-select.open .custom-select-trigger{border-color:var(--primary)}.custom-select-arrow{color:var(--text-muted);flex-shrink:0;transition:transform .15s}.custom-select.open .custom-select-arrow{transform:rotate(180deg)}.custom-select-menu{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);z-index:50;max-height:200px;padding:.25rem 0;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0006}.custom-select-option{color:var(--text);cursor:pointer;padding:.5rem .75rem;font-size:.875rem;transition:background .1s}.custom-select-option:hover{background:var(--bg-input)}.custom-select-option.selected{color:var(--primary)}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:400px;padding:2.5rem}.login-card h1{margin-bottom:.25rem;font-size:1.5rem}.login-card p{color:var(--text-muted);margin-bottom:1.5rem;font-size:.875rem}.login-card .btn{justify-content:center;width:100%;margin-top:.75rem;padding:.65rem}.error-msg{color:var(--danger);border-radius:var(--radius);background:#ef44441a;border:1px solid #ef44444d;margin-bottom:1rem;padding:.5rem .75rem;font-size:.8rem}.pagination{color:var(--text-muted);justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:.8rem;display:flex}.pagination-btns{gap:.5rem;display:flex}.files-layout{gap:1.5rem;min-height:calc(100vh - 3rem);display:flex}.files-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-shrink:0;align-self:flex-start;width:240px;position:sticky;top:1.5rem;overflow-y:auto}.files-sidebar-header{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.75rem;font-size:.8rem;font-weight:600;display:flex}.folder-item{color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.825rem;transition:all .1s;display:flex}.folder-item:hover{color:var(--text);background:#ffffff08}.folder-active{color:var(--text);border-right:2px solid var(--primary);background:#e87e041a}.folder-toggle{text-align:center;flex-shrink:0;width:1rem;font-size:.7rem}.folder-icon{flex-shrink:0;font-size:.9rem}.folder-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.folder-delete{opacity:0;width:1rem;height:1rem;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:opacity .1s,color .1s}.folder-item:hover .folder-delete{opacity:1}.folder-delete:hover{color:var(--danger)}.folder-link{color:var(--primary);cursor:pointer;font-size:.8rem}.folder-link:hover{text-decoration:underline}.files-main{flex:1;min-width:0}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--bg-card);margin-bottom:1rem;padding:2rem;transition:all .2s}.drop-zone:hover{border-color:var(--primary)}.drop-zone-active{border-color:var(--primary);background:#e87e040d}.drop-zone-content{flex-direction:column;align-items:center;gap:.4rem;display:flex}.drop-zone-icon{opacity:.5;font-size:1.75rem}.drop-zone-title{color:var(--text);font-size:.9rem;font-weight:500}.drop-zone-subtitle{color:var(--text-muted);font-size:.75rem}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem}.spinner{border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{justify-content:center;align-items:center;min-height:200px;display:flex}
