:root{--background:#f8fafc;--foreground:#1e293b;--card:#ffffff;--card-hover:#f1f5f9;--border:#e2e8f0;--primary:#7C3AED;--primary-hover:#6D28D9;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--danger-bg:#fef2f2;--muted:#64748b;--muted-foreground:#94a3b8;--surface:#f1f5f9;--sidebar-bg:#FFFFFF;--sidebar-border:#EDE9F8;--sidebar-text:#6B5B8A;--sidebar-text-hover:#1E1145;--nav-hover-bg:rgba(124,58,237,0.06);--nav-active-bg:rgba(124,58,237,0.10);--nav-active-accent:#7C3AED;--nav-active-text:#5B21B6;--section-header-color:#B0A3CC}[data-theme=dark]{--background:#0a0a0a;--foreground:#ededed;--card:#141414;--card-hover:#1a1a1a;--border:#262626;--primary:#7C3AED;--primary-hover:#6D28D9;--surface:#1e1e1e;--muted:#737373;--muted-foreground:#525252;--sidebar-bg:#F7F4FF;--sidebar-border:#DDD6F5;--danger-bg:#1a0a0a}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,sans-serif;background-color:var(--background);color:var(--foreground);line-height:1.5;min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}.app-shell{overflow:hidden}.app-shell,.main-content{display:flex;height:100vh}.main-content{flex:1 1;flex-direction:column;min-width:0;margin-left:260px;overflow-y:auto;overflow-x:hidden;background:var(--background);transition:margin-left .25s ease;-webkit-overflow-scrolling:touch}[data-sidebar-collapsed=true] .main-content{margin-left:60px}.content-area{flex:1 1;padding:32px;max-width:1400px;width:100%}.sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:linear-gradient(180deg,#FFFFFF,#FDFBFF 50%,#F8F5FF);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;z-index:100;overflow-y:auto;overflow-x:hidden;box-shadow:2px 0 20px rgba(0,0,0,.06),inset -1px 0 0 var(--sidebar-border);transition:width .25s ease}.sidebar.sidebar-collapsed{width:60px}.sidebar:before{content:"";position:-webkit-sticky;position:sticky;top:0;display:block;height:2px;width:100%;flex-shrink:0;background:linear-gradient(90deg,transparent,#7C3AED 30%,#9333EA 60%,#818CF8 85%,transparent);z-index:1}.sb-logo{padding:18px 18px 14px;border-bottom:1px solid var(--sidebar-border);display:flex;flex-direction:column;align-items:flex-start;gap:4px;background:rgba(124,58,237,.04)}.sb-logo-img-wrap{width:164px;height:42px;overflow:hidden;flex-shrink:0}.sb-logo-img{width:275px;height:auto;display:block;margin-left:-57px;margin-top:-56px;pointer-events:none}.sb-logo-name{color:#2D1B69;font-size:13px;font-weight:700;letter-spacing:.02em;line-height:1.1}.sb-logo-sub{color:var(--sidebar-text);font-size:10px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;margin-top:1px}.sb-user{padding:12px 14px;border-bottom:1px solid var(--sidebar-border);display:flex;align-items:center;gap:10px;transition:background .18s ease}.sb-user:hover{background:rgba(124,58,237,.07)}.sb-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#7C3AED,#6366F1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;box-shadow:0 0 0 2px rgba(124,58,237,.2),0 2px 6px rgba(0,0,0,.12)}.sb-user-info{flex:1 1;min-width:0}.sb-user-name{color:var(--sidebar-text-hover);font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-user-role{color:var(--sidebar-text);font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.sb-nav{flex:1 1;padding:10px 8px;overflow-y:auto}.sb-section{margin-bottom:6px}.sb-section-header{display:flex;align-items:center;gap:8px;color:var(--section-header-color);font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:10px 10px 5px}.sb-section-header:after{content:"";flex:1 1;height:1px;background:rgba(167,139,250,.18);border-radius:1px}.sb-link{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;color:var(--sidebar-text);font-size:13px;font-weight:500;transition:all .15s ease;margin-bottom:1px;position:relative;letter-spacing:.01em}.sb-link:hover{background:var(--nav-hover-bg);color:var(--sidebar-text-hover)}.sb-link.active{background:var(--nav-active-bg);color:var(--nav-active-text);font-weight:600}.sb-link.active:before{content:"";position:absolute;left:0;top:5px;bottom:5px;width:3px;background:linear-gradient(180deg,#818CF8,#7C3AED);border-radius:0 3px 3px 0}.sb-link-icon{width:17px;height:17px;flex-shrink:0;opacity:.72;transition:opacity .15s ease}.sb-link:hover .sb-link-icon{opacity:.9}.sb-link.active .sb-link-icon{opacity:1}.sb-footer{padding:10px 8px;border-top:1px solid var(--sidebar-border);background:rgba(124,58,237,.04);display:flex;flex-direction:column;gap:2px}.sb-signout{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;color:var(--sidebar-text);font-size:13px;font-weight:500;background:none;border:none;width:100%;transition:all .15s ease;cursor:pointer;letter-spacing:.01em}.sb-signout:hover{background:rgba(220,38,38,.12);color:#f87171}.sb-signout.sb-signout-icon-only{justify-content:center;padding:8px}.sb-collapse-toggle{display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:8px;color:var(--sidebar-text);font-size:12px;font-weight:500;background:none;border:none;width:100%;transition:all .15s ease;cursor:pointer;letter-spacing:.01em;opacity:.7}.sb-collapse-toggle:hover{background:var(--nav-hover-bg);color:var(--sidebar-text-hover);opacity:1}.sb-link.sb-link-icon-only{justify-content:center;padding:8px;gap:0}.sidebar.sidebar-collapsed .sb-user{justify-content:center;padding:12px 0}.sidebar.sidebar-collapsed .sb-collapse-toggle{justify-content:center;padding:8px}.sidebar.sidebar-collapsed .sb-logo{align-items:center;padding:14px 8px}.sidebar.sidebar-collapsed .sb-section{margin-bottom:4px}.sidebar.sidebar-collapsed .sb-section-header{display:none}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap}.page-title{font-size:24px;font-weight:700;color:var(--foreground);letter-spacing:-.3px}.page-subtitle{color:var(--muted);font-size:14px;margin-top:2px}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:24px;transition:background .15s ease}.card:hover{background:var(--card-hover)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-title{font-size:16px;font-weight:600;color:var(--foreground)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:16px;gap:16px;margin-bottom:28px}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px 24px;display:flex;flex-direction:column;gap:4px}.stat-value{font-size:32px;font-weight:700;color:var(--foreground);line-height:1}.stat-label{font-size:13px;color:var(--muted);font-weight:500;margin-top:4px}.stat-icon{width:36px;height:36px;display:flex;justify-content:center;margin-bottom:12px}.btn,.stat-icon{border-radius:8px;align-items:center}.btn{display:inline-flex;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all .15s ease;text-decoration:none;white-space:nowrap;line-height:1.4}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px;box-shadow:0 0 0 3px rgba(124,58,237,.18)}.btn-primary{background:var(--primary);color:#ffffff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-outline{background:transparent;color:var(--foreground);border:1px solid var(--border)}.btn-outline:hover:not(:disabled){background:var(--surface)}.btn-danger{background:var(--danger);color:#ffffff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{background:transparent;color:var(--muted);border:none}.btn-ghost:hover:not(:disabled){background:var(--surface);color:var(--foreground)}.btn-sm{padding:5px 10px;font-size:12px;border-radius:6px}.btn-icon{padding:6px;border-radius:8px;background:transparent;border:1px solid var(--border);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.btn-icon:hover{background:var(--surface);color:var(--foreground)}.form-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.form-grid.cols-1{grid-template-columns:1fr}.form-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.col-span-2{grid-column:span 2}.label{font-size:13px;font-weight:500;color:var(--foreground)}.input,.select-input,textarea.input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:8px;background:var(--card);color:var(--foreground);font-size:14px;font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease;outline:none}.input:focus,.input:focus-visible,.select-input:focus,.select-input:focus-visible,textarea.input:focus,textarea.input:focus-visible{border-color:var(--primary);box-shadow:0 0 0 3px rgba(124,58,237,.1);outline:2px solid var(--primary);outline-offset:1px}.input::placeholder{color:var(--muted-foreground)}textarea.input{resize:vertical;min-height:80px}.select-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px;cursor:pointer}.text-input,select.text-input,textarea.text-input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:8px;background:var(--card);color:var(--foreground);font-size:14px;font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease;outline:none;box-sizing:border-box}.text-input:focus,.text-input:focus-visible,select.text-input:focus,select.text-input:focus-visible,textarea.text-input:focus,textarea.text-input:focus-visible{border-color:var(--primary);box-shadow:0 0 0 3px rgba(124,58,237,.18);outline:2px solid var(--primary);outline-offset:1px}.text-input::placeholder,textarea.text-input::placeholder{color:var(--muted-foreground);opacity:1}textarea.text-input{resize:vertical;min-height:80px;line-height:1.6}select.text-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px;cursor:pointer}.input-with-icon{position:relative}.input-with-icon .input{padding-left:38px}.input-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none;width:18px;height:18px}.form-actions{display:flex;align-items:center;gap:10px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--border);margin-top:8px}.form-error{font-size:12px;color:var(--danger);margin-top:4px}.table-container{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}table{width:100%;border-collapse:collapse}th{background:var(--surface);color:var(--muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:10px 16px;text-align:left}td,th{border-bottom:1px solid var(--border)}td{padding:12px 16px;font-size:14px;color:var(--foreground);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--card-hover)}.table-empty{text-align:center;padding:48px 16px;color:var(--muted);font-size:14px}.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.badge-success{background:rgba(22,163,74,.12);color:#16a34a}.badge-warning{background:rgba(217,119,6,.12);color:#d97706}.badge-danger{background:rgba(220,38,38,.12);color:#dc2626}.badge-primary{background:rgba(124,58,237,.12);color:var(--primary)}.badge-muted{background:var(--surface);color:var(--muted)}.badge-blue{background:rgba(37,99,235,.12);color:#2563eb}.badge-critical{background:rgba(185,28,28,.15);color:#b91c1c;border:1px solid rgba(185,28,28,.2)}.badge-high{background:rgba(234,88,12,.15);color:#c2410c;border:1px solid rgba(234,88,12,.2)}.badge-medium{background:rgba(161,98,7,.15);color:#a16207;border:1px solid rgba(161,98,7,.2)}.badge-low{background:rgba(37,99,235,.12);color:#1d4ed8;border:1px solid rgba(37,99,235,.2)}.badge-info{border:1px solid var(--border)}.badge-info,.badge-planned{background:var(--surface);color:var(--muted)}.badge-in-progress{background:rgba(37,99,235,.12);color:#2563eb}.badge-review{background:rgba(217,119,6,.12);color:#d97706}.badge-delivered{background:rgba(22,163,74,.12);color:#16a34a}.badge-closed{background:rgba(30,41,59,.12);color:var(--muted)}.badge-role-admin{background:rgba(124,58,237,.15);color:var(--primary)}.badge-role-manager{background:rgba(37,99,235,.12);color:#2563eb}.badge-role-senior{background:rgba(22,163,74,.12);color:#16a34a}.badge-role-tester{background:rgba(217,119,6,.12);color:#d97706}.badge-role-viewer{background:var(--surface);color:var(--muted)}.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:24px;gap:0;overflow-x:auto}.tab{padding:10px 18px;font-size:14px;font-weight:500;color:var(--muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;white-space:nowrap;transition:all .15s ease}.tab:hover{color:var(--foreground)}.tab.active{border-bottom-color:var(--primary)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.modal,.modal-overlay{animation:fadeSlideIn .15s ease}.modal{background:var(--card);border:1px solid var(--border);border-radius:14px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;padding:28px}.modal-lg{max-width:720px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-size:18px;font-weight:700;color:var(--foreground)}.modal-close{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.modal-close:hover{background:var(--surface);color:var(--foreground)}.alert{padding:12px 16px;border-radius:8px;font-size:14px;display:flex;align-items:flex-start;gap:10px}.alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(220,38,38,.2)}.alert-success{background:rgba(22,163,74,.08);color:#15803d;border:1px solid rgba(22,163,74,.2)}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.spinner-dark{border-color:rgba(100,116,139,.3);border-top-color:var(--primary)}.severity-chart{display:flex;flex-direction:column;gap:10px}.severity-bar-row{display:flex;align-items:center;gap:12px}.severity-bar-label{width:90px;font-size:13px;font-weight:500;color:var(--muted);flex-shrink:0}.severity-bar-track{flex:1 1;height:20px;background:var(--surface);border-radius:4px;overflow:hidden}.severity-bar-fill{height:100%;border-radius:4px;transition:width .4s ease;min-width:0}.severity-bar-count{width:32px;text-align:right;font-size:13px;font-weight:600;color:var(--foreground);flex-shrink:0}.upload-zone{border:2px dashed var(--border);border-radius:10px;padding:28px;text-align:center;cursor:pointer;transition:all .15s ease;background:var(--surface)}.upload-zone:hover{border-color:var(--primary);background:rgba(124,58,237,.04)}.upload-zone p{color:var(--muted);font-size:14px}.image-previews{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));grid-gap:12px;gap:12px;margin-top:14px}.image-preview-item{position:relative;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.image-preview-item img{width:100%;height:90px;object-fit:cover;display:block}.image-preview-remove{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:50%;width:20px;height:20px;justify-content:center;cursor:pointer;font-size:12px;line-height:1}.image-preview-remove,.top-bar{display:flex;align-items:center}.top-bar{height:56px;border-bottom:1px solid var(--border);justify-content:flex-end;padding:0 32px;background:var(--card);position:-webkit-sticky;position:sticky;top:0;z-index:50}.user-menu-btn{display:flex;align-items:center;gap:8px;padding:6px 12px 6px 6px;border-radius:40px;background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:all .15s ease}.user-menu-btn:hover{background:var(--card-hover)}.user-menu-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#9333ea);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.user-menu-name{font-size:13px;font-weight:500;color:var(--foreground)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:24px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:8px;min-width:200px;box-shadow:0 4px 20px rgba(0,0,0,.1);z-index:100;animation:fadeSlideIn .12s ease}.user-dropdown-header{padding:8px 10px 12px;border-bottom:1px solid var(--border);margin-bottom:6px}.user-dropdown-name{font-size:14px;font-weight:600;color:var(--foreground)}.user-dropdown-role{font-size:11px;color:var(--muted);margin-top:2px;text-transform:uppercase;letter-spacing:.5px}.dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;font-size:13px;color:var(--muted);background:none;border:none;width:100%;cursor:pointer;transition:all .15s ease;text-align:left}.dropdown-item:hover{background:var(--surface);color:var(--foreground)}.dropdown-item.danger:hover{background:var(--danger-bg);color:var(--danger)}.filter-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:16px}.filter-tab{padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500;background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .15s ease}.filter-tab:hover{color:var(--foreground);background:var(--card-hover)}.filter-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.hamburger{display:none;background:none;border:none;color:var(--foreground);cursor:pointer;padding:6px;border-radius:8px}@media (max-width:768px){.sidebar{transform:translateX(-100%);transition:transform .25s ease;z-index:200}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0}.hamburger{display:flex}.form-grid,.form-grid.cols-3{grid-template-columns:1fr}.form-group.col-span-2{grid-column:span 1}.stats-grid{grid-template-columns:1fr 1fr}.content-area{padding:20px 16px}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.status-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.status-requested{background:rgba(100,116,139,.12);color:#64748b;border:1px solid rgba(100,116,139,.2)}.status-assigned{background:rgba(124,58,237,.12);color:#7c3aed;border:1px solid rgba(124,58,237,.2)}.status-scheduled{background:rgba(14,165,233,.12);color:#0ea5e9;border:1px solid rgba(14,165,233,.2)}.status-work_in_progress{background:rgba(37,99,235,.12);color:#2563eb;border:1px solid rgba(37,99,235,.2)}.status-review{background:rgba(217,119,6,.12);color:#d97706;border:1px solid rgba(217,119,6,.2)}.status-published{background:rgba(22,163,74,.12);color:#16a34a;border:1px solid rgba(22,163,74,.2)}.status-cancelled{background:rgba(220,38,38,.1);color:#dc2626;border:1px solid rgba(220,38,38,.15)}.status-open{background:rgba(37,99,235,.12);color:#2563eb;border:1px solid rgba(37,99,235,.2)}.status-closed{background:rgba(22,163,74,.12);color:#16a34a;border:1px solid rgba(22,163,74,.2)}.status-false_positive{background:rgba(100,116,139,.12);color:#64748b;border:1px solid rgba(100,116,139,.2)}.status-wont_fix{background:rgba(120,53,15,.12);color:#92400e;border:1px solid rgba(120,53,15,.2)}.status-accepted_risk{background:rgba(14,165,233,.12);color:#0369a1;border:1px solid rgba(14,165,233,.2)}.status-compensated{background:rgba(124,58,237,.12);color:#6d28d9;border:1px solid rgba(124,58,237,.2)}.status-in_remediation{background:rgba(234,179,8,.12);color:#a16207;border:1px solid rgba(234,179,8,.2)}.status-remediated{background:rgba(14,165,233,.12);color:#0369a1;border:1px solid rgba(14,165,233,.2)}.status-retest_passed{background:rgba(34,197,94,.12);color:#15803d;border:1px solid rgba(34,197,94,.2)}.status-retest_failed{background:rgba(239,68,68,.12);color:#b91c1c;border:1px solid rgba(239,68,68,.2)}.status-deferred{background:rgba(100,116,139,.12);color:#64748b;border:1px solid rgba(100,116,139,.2)}.status-not_applicable{background:rgba(148,163,184,.12);color:#94a3b8;border:1px solid rgba(148,163,184,.2)}.portal-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.portal-client{background:rgba(37,99,235,.1);color:#3b82f6}.portal-consultant{background:rgba(217,119,6,.1);color:#f59e0b}.portal-system{background:rgba(185,28,28,.1);color:#ef4444}.detail-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:20px;gap:20px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:14px;color:var(--foreground);font-weight:500}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:12px;position:relative;padding-bottom:20px}.timeline-item:last-child{padding-bottom:0}.timeline-dot{width:10px;height:10px;border-radius:50%;background:var(--primary);flex-shrink:0;margin-top:4px;position:relative;z-index:1}.timeline-line{position:absolute;left:4px;top:14px;bottom:0;width:2px;background:var(--border)}.timeline-content{flex:1 1}.timeline-title{font-size:13px;font-weight:600;color:var(--foreground)}.timeline-meta{font-size:12px;color:var(--muted);margin-top:2px}.empty-state{text-align:center;padding:60px 24px;color:var(--muted)}.empty-state-icon{width:48px;height:48px;margin:0 auto 16px;opacity:.4}.empty-state-title{font-size:16px;font-weight:600;color:var(--foreground);margin-bottom:8px}.empty-state-desc{font-size:14px;color:var(--muted);margin-bottom:20px}.kv-list{display:flex;flex-direction:column;gap:12px}.kv-item{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;font-size:14px}.kv-key{color:var(--muted);flex-shrink:0;min-width:140px}.kv-val{font-weight:500;text-align:right}.kv-val,.section-title{color:var(--foreground)}.section-title{font-size:15px;font-weight:600;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.divider{border:none;border-top:1px solid var(--border);margin:20px 0}.text-muted{color:var(--muted)}.text-sm{font-size:13px}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.mono{font-family:Fira Code,Cascadia Code,monospace;font-size:12px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.section-spacing{margin-bottom:28px}.loading-center{justify-content:center;padding:60px 24px;gap:12px}.checkbox-row,.loading-center{display:flex;align-items:center;color:var(--muted);font-size:14px}.checkbox-row{gap:8px;cursor:pointer}.checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 0 0 rgba(124,58,237,.4)}50%{box-shadow:0 0 0 6px rgba(124,58,237,0)}}@keyframes pulseDot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.7}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes pulse{0%,to{background-position:200% 0}50%{background-position:-200% 0}}.content-area{animation:fadeInUp .22s cubic-bezier(.22,1,.36,1) both}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--muted-foreground)}.sb-nav::-webkit-scrollbar-thumb,.sidebar::-webkit-scrollbar-thumb{background:rgba(124,58,237,.18)}.sb-nav::-webkit-scrollbar-thumb:hover,.sidebar::-webkit-scrollbar-thumb:hover{background:rgba(124,58,237,.32)}.sb-link{transition:background .18s ease,color .18s ease,box-shadow .18s ease}.sb-link-icon{transition:transform .2s ease,opacity .2s ease}.sb-link:hover .sb-link-icon{transform:scale(1.1)}.sb-link.active{box-shadow:inset 0 1px 0 rgba(255,255,255,.5),0 1px 3px rgba(124,58,237,.1)}.sb-nav{scrollbar-width:thin;scrollbar-color:transparent transparent;transition:scrollbar-color .2s}.sb-nav:hover{scrollbar-color:rgba(124,58,237,.25) transparent}.top-bar{transition:box-shadow .2s ease;box-shadow:0 1px 0 var(--border)}.top-bar.scrolled{box-shadow:0 2px 16px rgba(0,0,0,.08)}.user-menu-btn{transition:background .18s ease,box-shadow .18s ease,transform .15s ease}.user-menu-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.08)}.user-menu-btn:active{transform:translateY(0)}.user-dropdown{animation:scaleIn .15s cubic-bezier(.22,1,.36,1) both;transform-origin:top right}.dropdown-item{transition:background .12s ease,color .12s ease,transform .12s ease}.dropdown-item:hover{transform:translateX(2px)}.card{transition:background .18s ease,box-shadow .22s ease,transform .22s ease,border-color .18s ease}.card:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.06);border-color:rgba(124,58,237,.15)}.stat-card{transition:background .18s ease,box-shadow .22s ease,transform .22s ease,border-color .18s ease;cursor:default}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.07);border-color:rgba(124,58,237,.2)}.btn{transition:background .15s ease,box-shadow .15s ease,transform .12s ease,color .15s ease,border-color .15s ease}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.1)}.btn:active:not(:disabled){transform:translateY(0);box-shadow:none}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px rgba(124,58,237,.35)}.btn-danger:hover:not(:disabled){box-shadow:0 4px 12px rgba(220,38,38,.3)}.btn-icon{transition:background .15s ease,color .15s ease,transform .12s ease,box-shadow .15s ease}.btn-icon:hover{transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,.08)}.btn-icon:active{transform:translateY(0);box-shadow:none}.tab{transition:color .15s ease,border-bottom-color .15s ease,background .15s ease;position:relative}.tab:hover{background:rgba(124,58,237,.04);border-radius:6px 6px 0 0}.tab.active{color:var(--primary)}.filter-tab{transition:background .15s ease,color .15s ease,border-color .15s ease,transform .12s ease,box-shadow .15s ease}.filter-tab:hover{transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,.06)}.filter-tab:active{transform:translateY(0)}.filter-tab.active{box-shadow:0 2px 8px rgba(124,58,237,.3)}.input,.select-input,textarea.input{transition:border-color .18s ease,box-shadow .18s ease,background .15s ease}.modal-overlay{animation:fadeIn .18s ease both;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.modal{animation:scaleIn .2s cubic-bezier(.22,1,.36,1) both;transform-origin:center top;box-shadow:0 20px 60px rgba(0,0,0,.15),0 4px 20px rgba(0,0,0,.1)}td,tr{transition:background .12s ease}.upload-zone{transition:border-color .18s ease,background .18s ease,transform .15s ease,box-shadow .18s ease}.upload-zone:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(124,58,237,.08)}.image-preview-item{transition:transform .18s ease,box-shadow .18s ease}.image-preview-item:hover{transform:scale(1.03);box-shadow:0 4px 12px rgba(0,0,0,.12)}.timeline-dot{transition:transform .2s ease}.timeline-item:hover .timeline-dot{transform:scale(1.4)}.empty-state-icon{animation:fadeIn .4s ease both}.badge,.status-badge{transition:transform .12s ease,box-shadow .12s ease}.notif-badge,.notif-unread-dot{animation:pulseDot 2s ease-in-out infinite}.severity-bar-fill{transition:width .6s cubic-bezier(.22,1,.36,1)}.skeleton{background:linear-gradient(90deg,var(--surface) 25%,var(--card-hover) 50%,var(--surface) 75%);background-size:400px 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:6px;display:inline-block}.skeleton-text{height:14px;border-radius:4px}.skeleton-title{height:20px;border-radius:4px}.skeleton-badge{height:22px;width:60px;border-radius:20px}.skeleton-pulse{background:var(--border);border-radius:4px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-pulse.skeleton-text{height:14px;margin-bottom:8px}.skeleton-pulse.skeleton-title{height:20px;width:40%;margin-bottom:12px}.tabs{scrollbar-width:none;-ms-overflow-style:none}.tabs::-webkit-scrollbar{display:none}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}button:focus:not(:focus-visible),input:focus:not(:focus-visible),select:focus:not(:focus-visible),textarea:focus:not(:focus-visible){outline:none}.hamburger{transition:background .15s ease,transform .15s ease}.hamburger:hover{background:var(--surface);transform:scale(1.05)}.section-title{transition:color .15s ease}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.content-area{animation:none}.main-content,html{scroll-behavior:auto}}