*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #1a1a2e;--color-primary-light: #2d2d4a;--color-accent: #4f46e5;--color-accent-light: #6366f1;--color-accent-bg: #eef2ff;--color-bg: #f8f9fc;--color-surface: #ffffff;--color-surface-hover: #f3f4f6;--color-sidebar-bg: #fafbfd;--color-border: #e5e7eb;--color-border-light: #f0f0f5;--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-text-inverse: #ffffff;--color-success: #059669;--color-success-bg: #ecfdf5;--color-success-border: #a7f3d0;--color-warning: #d97706;--color-warning-bg: #fffbeb;--color-warning-border: #fde68a;--color-danger: #dc2626;--color-danger-hover: #b91c1c;--color-danger-bg: #fef2f2;--color-danger-border: #fecaca;--color-info: #2563eb;--color-info-bg: #eff6ff;--color-info-border: #bfdbfe;--color-critical: #991b1b;--color-critical-bg: #fef2f2;--color-high: #dc2626;--color-high-bg: #fef2f2;--color-medium: #d97706;--color-medium-bg: #fffbeb;--color-low: #2563eb;--color-low-bg: #eff6ff;--font-family: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.375rem;--font-size-2xl: 1.75rem;--font-size-3xl: 2.25rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .04);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}[data-theme=dark]{--color-primary: #6366f1;--color-primary-light: #818cf8;--color-accent: #818cf8;--color-accent-light: #a5b4fc;--color-accent-bg: rgba(99, 102, 241, .15);--color-bg: #0f1117;--color-surface: #1a1b23;--color-surface-hover: #24252f;--color-sidebar-bg: #14151d;--color-border: #2a2b35;--color-border-light: #22232d;--color-text-primary: #e8e9ed;--color-text-secondary: #9ca3af;--color-text-tertiary: #6b7280;--color-text-inverse: #ffffff;--color-success: #34d399;--color-success-bg: rgba(52, 211, 153, .12);--color-success-border: rgba(52, 211, 153, .25);--color-warning: #fbbf24;--color-warning-bg: rgba(251, 191, 36, .12);--color-warning-border: rgba(251, 191, 36, .25);--color-danger: #f87171;--color-danger-hover: #ef4444;--color-danger-bg: rgba(248, 113, 113, .12);--color-danger-border: rgba(248, 113, 113, .25);--color-info: #60a5fa;--color-info-bg: rgba(96, 165, 250, .12);--color-info-border: rgba(96, 165, 250, .25);--color-critical: #fca5a5;--color-critical-bg: rgba(248, 113, 113, .15);--color-high: #f87171;--color-high-bg: rgba(248, 113, 113, .12);--color-medium: #fbbf24;--color-medium-bg: rgba(251, 191, 36, .12);--color-low: #60a5fa;--color-low-bg: rgba(96, 165, 250, .12);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .35), 0 2px 4px -2px rgba(0, 0, 0, .25);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -4px rgba(0, 0, 0, .25);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .45), 0 8px 10px -6px rgba(0, 0, 0, .25)}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scrollbar-gutter:stable;color-scheme:light}html[data-theme=dark]{color-scheme:dark}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg);line-height:1.6;min-height:100vh;transition:background-color var(--transition-slow),color var(--transition-slow)}#root{min-height:100vh}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width var(--transition-slow);overflow:hidden}.sidebar--collapsed{width:64px}.sidebar-brand{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-6) var(--space-5);border-bottom:1px solid var(--color-border-light);min-height:69px;transition:padding var(--transition-slow),gap var(--transition-slow);white-space:nowrap}.sidebar-collapse-btn{margin-left:auto;width:28px;height:28px;border:none;background:none;cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;transition:color var(--transition-fast),background var(--transition-fast),opacity var(--transition-slow),width var(--transition-slow)}.sidebar-collapse-btn svg{width:16px;height:16px}.sidebar-collapse-btn:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.sidebar--collapsed .sidebar-brand{padding:var(--space-6) 0;justify-content:center;gap:0}.sidebar--collapsed .sidebar-brand-icon{cursor:pointer;margin:0 auto}.sidebar--collapsed .sidebar-brand-text,.sidebar--collapsed .sidebar-collapse-btn{opacity:0;width:0;min-width:0;flex:0 0 0px;overflow:hidden;pointer-events:none;margin:0;padding:0}.sidebar--collapsed .sidebar-nav{padding:var(--space-4) var(--space-2)}.sidebar--collapsed .sidebar-link{justify-content:center;padding:var(--space-2);gap:0}.sidebar--collapsed .sidebar-link-label{opacity:0;width:0;min-width:0;flex:0 0 0px;overflow:hidden;pointer-events:none}.sidebar--collapsed .sidebar-section-label{opacity:0;height:0;padding:0;margin:0;overflow:hidden;pointer-events:none}.sidebar--collapsed .sidebar-user{padding:var(--space-4) 0;justify-content:center;gap:0}.sidebar--collapsed .sidebar-user-info,.sidebar--collapsed .sidebar-user>button:last-of-type{opacity:0;width:0;min-width:0;flex:0 0 0px;overflow:hidden;pointer-events:none}.sidebar--collapsed .sidebar-user-menu{left:var(--space-1);right:auto;width:180px}.sidebar-brand-icon{width:34px;height:34px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.sidebar-brand-logo{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-md)}.sidebar-brand-text{overflow:hidden;transition:opacity var(--transition-slow),width var(--transition-slow)}.sidebar-brand-text h1{font-size:var(--font-size-base);font-weight:700;color:var(--color-text-primary);line-height:1.2;white-space:nowrap}.sidebar-brand-text span{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.sidebar-nav{padding:var(--space-4) var(--space-3);flex:1;transition:padding var(--transition-slow)}.sidebar-section-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);padding:var(--space-4) var(--space-3) var(--space-2);font-family:Geist,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;white-space:nowrap;transition:opacity var(--transition-slow),height var(--transition-slow),padding var(--transition-slow)}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-sm);font-weight:500;font-family:Geist,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;letter-spacing:-.01em;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),padding var(--transition-slow),gap var(--transition-slow);border:none;background:none;width:100%;text-align:left;white-space:nowrap}.sidebar-link-label{overflow:hidden;transition:opacity var(--transition-slow),width var(--transition-slow)}.sidebar-link:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.sidebar-link.active{background:var(--color-primary);color:var(--color-text-inverse)}.sidebar-link.active svg{color:var(--color-text-inverse)}.sidebar-link svg{width:18px;height:18px;flex-shrink:0}.sidebar-user{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border-light);display:flex;align-items:center;gap:var(--space-3);transition:padding var(--transition-slow),gap var(--transition-slow);white-space:nowrap}.sidebar-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-accent),var(--color-accent-light));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:var(--font-size-sm);flex-shrink:0}.sidebar-user-info{flex:1;min-width:0;overflow:hidden;transition:opacity var(--transition-slow),width var(--transition-slow)}.sidebar-user-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:var(--font-size-xs);color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main-content{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-slow)}.main-content--sidebar-collapsed{margin-left:64px}.breadcrumb-bar{padding:var(--space-3) var(--space-8);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between;background:var(--color-surface)}.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.breadcrumb span{color:var(--color-text-tertiary)}.breadcrumb strong{color:var(--color-text-primary);font-weight:600}.breadcrumb-actions{display:flex;align-items:center;gap:var(--space-3)}.page-header{padding:var(--space-10) var(--space-8) var(--space-8)}.page-header h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary);line-height:1.2;margin-bottom:var(--space-2)}.page-header p{font-size:var(--font-size-base);color:var(--color-text-secondary);max-width:540px}.page-body{padding:var(--space-6) var(--space-8) var(--space-8);flex:1}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-xs)}.card-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-6)}.card-title svg{width:20px;height:20px;color:var(--color-text-secondary)}.intake-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);align-items:start}.scoring-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);align-items:start}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-2)}.form-helper{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--space-1)}.form-input,.form-select{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-text-primary);background:var(--color-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;height:40px}.form-input::placeholder{color:var(--color-text-tertiary)}.form-input:focus,.form-select:focus,.custom-select-trigger:focus,.custom-select-trigger.open{border-color:var(--color-accent);box-shadow:0 0 0 3px #4f46e51a}.custom-select-container{position:relative;width:100%}.custom-select-trigger{display:flex;align-items:center;justify-content:space-between;cursor:pointer;text-align:left;-webkit-user-select:none;user-select:none;min-height:44px;height:auto;padding:10px 14px;border-radius:var(--radius-md)}.custom-select-value{flex:1;white-space:normal;overflow:hidden;text-overflow:ellipsis;padding-right:var(--space-2)}.custom-select-trigger.placeholder-visible{color:var(--color-text-tertiary)}.custom-select-dropdown{position:absolute;top:calc(100% + var(--space-1));left:0;width:100%;z-index:50;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:slideDownFade .15s ease-out}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.custom-select-list{list-style:none;margin:0;padding:var(--space-1);max-height:250px;overflow-y:auto}.custom-select-option{padding:var(--space-2) var(--space-3);margin-bottom:2px;border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);white-space:normal;line-height:1.4}.custom-select-option:last-child{margin-bottom:0}.custom-select-option:hover{background:var(--color-surface-hover)}.custom-select-option.selected{background:var(--color-accent-bg);color:var(--color-accent);font-weight:500}.scoring-section-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);padding-top:var(--space-5);padding-bottom:var(--space-4);border-top:1px solid var(--color-border-light);margin-top:var(--space-2)}.criticality-result{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg);margin-top:var(--space-6);transition:border-color var(--transition-base),background var(--transition-base)}.criticality-result--critical{background:var(--color-danger-bg);border-color:var(--color-danger-border)}.criticality-result--high{background:var(--color-warning-bg);border-color:var(--color-warning-border)}.criticality-result--low{background:var(--color-success-bg);border-color:var(--color-success-border)}.criticality-result-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-bottom:2px}.criticality-result-formula{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-family:Courier New,Courier,monospace}.criticality-badge{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;white-space:nowrap;flex-shrink:0}.criticality-badge--critical{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-border)}.criticality-badge--high{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning-border)}.criticality-badge--low{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.criticality-badge--pending{background:var(--color-surface-hover);color:var(--color-text-tertiary);border:1px solid var(--color-border)}.form-textarea{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-text-primary);background:var(--color-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;resize:vertical;min-height:72px;line-height:1.6}.form-textarea::placeholder{color:var(--color-text-tertiary)}.form-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #4f46e51a}.label-with-btn{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.label-with-btn .form-label{margin-bottom:0}.btn-autofill{display:inline-flex;align-items:center;gap:var(--space-1);padding:3px var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-autofill:hover:not(:disabled){background:var(--color-accent-bg);border-color:var(--color-accent);color:var(--color-accent)}.btn-autofill:disabled{opacity:.4;cursor:not-allowed}.input-with-icon{position:relative}.input-with-icon svg{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--color-text-tertiary)}.input-with-icon .form-input{padding-left:36px}.vendor-url-row{display:flex;align-items:center;gap:var(--space-3)}.vendor-logo-preview{width:44px;height:44px;border-radius:var(--radius-md);background:var(--color-surface-hover);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;transition:all var(--transition-base)}.vendor-logo-preview svg{width:18px;height:18px;color:var(--color-text-tertiary)}.vendor-logo-img{width:100%;height:100%;object-fit:cover;object-position:center}.vendor-logo-spinner{width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.vendor-cell-logo{width:36px;height:36px;border-radius:var(--radius-full);object-fit:contain;background:var(--color-surface);border:1px solid var(--color-border);padding:3px;flex-shrink:0}.info-card{background:var(--color-info-bg);border:1px solid var(--color-info-border);border-radius:var(--radius-md);padding:var(--space-4);display:flex;gap:var(--space-3);align-items:flex-start}.info-card-icon{width:20px;height:20px;color:var(--color-info);flex-shrink:0;margin-top:1px}.info-card h4{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-1)}.info-card p{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.5}.dropzone-wrapper{position:relative}.dropzone-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.dropzone-badge{font-size:var(--font-size-xs);padding:var(--space-1) var(--space-2);background:var(--color-surface-hover);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-weight:500}.dropzone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-10) var(--space-6);text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--color-bg)}.dropzone:hover{border-color:var(--color-accent);background:var(--color-accent-bg)}.dropzone.drag-over{border-color:var(--color-accent);background:var(--color-accent-bg);transform:scale(1.01)}.dropzone-icon{width:48px;height:48px;margin:0 auto var(--space-4);color:var(--color-text-tertiary);background:var(--color-surface);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.dropzone-icon svg{width:24px;height:24px}.dropzone h3{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-1)}.dropzone p{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-bottom:var(--space-4)}.dropzone-browse-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast)}.dropzone-browse-btn:hover{background:var(--color-surface-hover);border-color:var(--color-text-tertiary)}.evidence-source{display:flex;flex-direction:column}.evidence-tabs{display:flex;gap:var(--space-1);margin-bottom:var(--space-5);background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-1);border:1px solid var(--color-border)}.evidence-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.evidence-tab:hover{color:var(--color-text-primary);background:var(--color-surface-hover)}.evidence-tab.active{background:var(--color-bg);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.evidence-tab.has-content:not(.active):after{content:"";width:6px;height:6px;border-radius:50%;background:var(--color-accent);margin-left:var(--space-1)}.evidence-badge{font-size:.625rem;font-weight:600;background:var(--color-accent);color:#fff;border-radius:9999px;padding:0 5px;min-width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;line-height:1}.trust-centre-panel{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);background:var(--color-bg)}.trust-centre-header{display:flex;gap:var(--space-4);margin-bottom:var(--space-5)}.trust-centre-header svg{color:var(--color-accent);flex-shrink:0;margin-top:2px}.trust-centre-header h3{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-1)}.trust-centre-header p{font-size:var(--font-size-xs);color:var(--color-text-tertiary);line-height:1.5}.trust-centre-input-row{display:flex;gap:var(--space-2)}.trust-centre-input{flex:1;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:var(--font-family);transition:border-color var(--transition-fast)}.trust-centre-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-bg)}.trust-centre-input::placeholder{color:var(--color-text-tertiary)}.trust-centre-preview{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.trust-centre-preview svg{color:var(--color-accent);flex-shrink:0;width:16px;height:16px}.trust-centre-preview span{font-size:var(--font-size-xs);color:var(--color-text-secondary);word-break:break-all}.screening-item-url{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:400;word-break:break-all}.file-list{margin-top:var(--space-5)}.file-list-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin-bottom:var(--space-3)}.file-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.file-icon{width:36px;height:36px;background:var(--color-surface-hover);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);position:relative}.file-icon svg{width:18px;height:18px}.file-icon-ready{background:var(--color-success-bg);color:var(--color-success)}.file-ready-tick{position:absolute;bottom:-4px;right:-4px;width:16px;height:16px;background:var(--color-surface);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-xs)}.file-ready-tick svg{width:14px;height:14px;color:var(--color-success)}.file-ready-label{display:inline-flex;align-items:center;gap:var(--space-1);margin-left:var(--space-2);color:var(--color-success);font-weight:600;font-size:var(--font-size-xs)}.file-info{flex:1}.file-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.file-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary);display:flex;align-items:center}.file-remove{width:32px;height:32px;border:none;background:none;cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.file-remove:hover{color:var(--color-danger);background:var(--color-danger-bg)}.action-bar{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-4);padding:var(--space-6) var(--space-8);border-top:1px solid var(--color-border-light);background:var(--color-surface)}.action-bar-hint{margin-right:auto;font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-style:italic}.file-item+.file-item{margin-top:var(--space-2)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;height:40px;min-width:100px}.btn svg{width:16px;height:16px}.btn-ghost{background:transparent;color:var(--color-text-secondary);border-color:transparent}.btn-ghost:hover{color:var(--color-text-primary);background:var(--color-surface-hover)}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-light)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-outline{background:var(--color-surface);color:var(--color-text-primary);border-color:var(--color-border)}.btn-outline:hover{background:var(--color-surface-hover)}.btn-danger{background:var(--color-danger);color:var(--color-text-inverse);border-color:var(--color-danger)}.btn-danger:hover{background:var(--color-danger-hover, #b91c1c);border-color:var(--color-danger-hover, #b91c1c)}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.confirm-modal-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--color-danger-bg);color:var(--color-danger);margin:0 auto var(--space-4)}.processing-overlay{display:flex;align-items:center;justify-content:center;padding:var(--space-12) var(--space-8);flex:1}.processing-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:640px;overflow:hidden}.processing-file-bar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-light)}.processing-file-icon{width:32px;height:32px;background:var(--color-surface-hover);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);flex-shrink:0}.processing-file-icon svg{width:16px;height:16px}.processing-file-info{flex:1}.processing-file-name{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary)}.processing-file-meta{font-size:var(--font-size-xs);color:var(--color-accent)}.processing-status-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--color-surface-hover);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500;color:var(--color-text-primary)}.processing-status-dot{width:8px;height:8px;border-radius:50%;background:var(--color-accent);animation:pulse 1.5s infinite}.processing-body{padding:var(--space-8) var(--space-6);text-align:center}.processing-spinner-wrap{width:64px;height:64px;margin:0 auto var(--space-6);position:relative}.processing-spinner{width:64px;height:64px;border:3px solid var(--color-border-light);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.processing-spinner-icon{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.processing-body h2{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-2)}.processing-body>p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-8)}.progress-section{text-align:left;margin-bottom:var(--space-6)}.progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.progress-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.progress-percent{font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent)}.progress-track{width:100%;height:8px;background:var(--color-bg);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-2)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:var(--radius-full);transition:width .8s ease}.progress-footer{display:flex;justify-content:space-between;font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.processing-steps{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-bottom:var(--space-6)}.processing-step{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border-light);font-size:var(--font-size-sm);color:var(--color-text-tertiary);transition:all var(--transition-base)}.processing-step.done{border-color:var(--color-success-border);background:var(--color-success-bg);color:var(--color-text-primary)}.processing-step.active{border-color:var(--color-border);background:var(--color-surface-hover);color:var(--color-text-primary)}.processing-step-icon{width:20px;height:20px;flex-shrink:0}.processing-step.done .processing-step-icon{color:var(--color-success)}.processing-step.active .processing-step-icon{color:var(--color-accent);animation:spin 2s linear infinite}.report-page{max-width:900px;margin:0 auto;padding:var(--space-8)}.report-hero{background:var(--color-primary);border-radius:var(--radius-xl);padding:var(--space-8);color:var(--color-text-inverse);margin-bottom:var(--space-8);position:relative;overflow:hidden}.report-hero:after{content:"";position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 60%);border-radius:50%}.report-confidential{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:#ffffff1f;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500;margin-bottom:var(--space-4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.report-hero-content{display:flex;align-items:flex-end;justify-content:space-between;position:relative;z-index:1}.report-hero h2{font-size:var(--font-size-2xl);font-weight:800;margin-bottom:var(--space-2)}.report-hero-meta{font-size:var(--font-size-xs);opacity:.6}.report-vendor-badge{padding:var(--space-3) var(--space-5);background:#ffffff1a;border-radius:var(--radius-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);text-align:center}.report-vendor-badge small{display:block;font-size:var(--font-size-xs);opacity:.6;margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:.05em}.report-vendor-badge span{font-size:var(--font-size-base);font-weight:600}.report-vendor-logo{width:48px;height:48px;border-radius:var(--radius-md);object-fit:cover;background:#ffffff26;display:block;margin:var(--space-1) auto}.report-summary-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-6);padding:var(--space-6) var(--space-8);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-8)}.report-stat{text-align:left}.report-stat-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin-bottom:var(--space-1)}.report-stat-value{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary)}.report-grade{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-text-primary);line-height:1}.report-grade-group{display:flex;align-items:center;gap:var(--space-4)}.report-risk-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.report-risk-badge.pass{background:var(--color-success-bg);color:var(--color-success)}.report-risk-badge.fail{background:var(--color-danger-bg);color:var(--color-danger)}.report-risk-badge.warning{background:var(--color-warning-bg);color:var(--color-warning)}.report-score{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.report-section{margin-bottom:var(--space-8)}.report-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-5)}.report-section-title svg{width:20px;height:20px}.executive-summary{background:var(--color-surface);border:1px solid var(--color-border);border-left:3px solid var(--color-text-primary);border-radius:var(--radius-md);padding:var(--space-6);font-size:var(--font-size-base);line-height:1.8;color:var(--color-text-secondary)}.executive-summary strong{color:var(--color-text-primary)}.checklist-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.checklist-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);transition:all var(--transition-fast)}.checklist-item:hover{box-shadow:var(--shadow-sm)}.checklist-status-icon{width:22px;height:22px;flex-shrink:0;margin-top:1px}.checklist-item.pass .checklist-status-icon{color:var(--color-success)}.checklist-item.fail .checklist-status-icon{color:var(--color-danger)}.checklist-item.partial .checklist-status-icon{color:var(--color-warning)}.checklist-item-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-1)}.checklist-item-detail{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.4}.risk-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.risk-table thead th{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--color-border);background:var(--color-bg)}.risk-table tbody td{padding:var(--space-4);border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-sm);color:var(--color-text-secondary);vertical-align:top}.risk-table tbody tr:last-child td{border-bottom:none}.risk-table tbody tr:hover{background:var(--color-surface-hover)}.severity-badge{display:inline-block;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;text-transform:capitalize}.severity-badge.critical{background:var(--color-critical-bg);color:var(--color-critical)}.severity-badge.high{background:var(--color-high-bg);color:var(--color-high)}.severity-badge.medium{background:var(--color-medium-bg);color:var(--color-medium)}.severity-badge.low{background:var(--color-low-bg);color:var(--color-low)}.severity-badge.info{background:var(--color-info-bg);color:var(--color-info)}.risk-title{font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-1)}.risk-description{line-height:1.5}.report-header-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);margin-bottom:var(--space-6);overflow:hidden;box-shadow:var(--shadow-xs)}.report-header-body{display:flex;align-items:center;justify-content:space-between;padding:var(--space-8);gap:var(--space-8)}.report-header-left{display:flex;align-items:center;gap:var(--space-5);flex:1;min-width:0}.report-header-logo{width:52px;height:52px;border-radius:var(--radius-md);object-fit:cover;border:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0}[data-theme=dark] .report-header-logo{background:#fff;border-color:var(--color-border)}.report-header-name-row{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.report-header-vendor-name{font-size:var(--font-size-2xl);font-weight:800;color:var(--color-text-primary);line-height:1.1}.report-vendor-tag{display:inline-block;padding:3px var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-tertiary);letter-spacing:.06em;background:var(--color-bg);flex-shrink:0}.report-header-date{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.report-header-date strong{color:var(--color-text-primary);font-weight:600}.report-header-metrics{display:flex;align-items:flex-start;gap:var(--space-10);flex-shrink:0}.report-header-metric{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2)}.report-header-metric-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary)}.report-header-grade-value{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-text-primary);line-height:1}.report-section-title--exec{color:var(--color-text-primary)}.report-section-title--exec svg{color:var(--color-text-primary)}.cert-status-badge{display:inline-block;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600}.cert-status-active{background:var(--color-success-bg);color:var(--color-success)}.cert-status-expired{background:var(--color-danger-bg);color:var(--color-danger)}.cert-status-unknown{background:var(--color-warning-bg);color:var(--color-warning)}.report-actions-bar{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);margin-bottom:var(--space-6)}.report-footer{display:flex;justify-content:space-between;padding:var(--space-6) 0;border-top:1px solid var(--color-border-light);margin-top:var(--space-8);font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.notification-btn{width:28px;height:28px;border:none;background:none;cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;position:relative}.notification-btn svg{width:16px;height:16px}.notification-btn:hover{background:var(--color-surface-hover)}.theme-toggle-btn{width:28px;height:28px;border:none;background:none;cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;position:relative;transition:color var(--transition-fast),background var(--transition-fast)}.theme-toggle-btn svg{width:16px;height:16px}.theme-toggle-btn:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.error-banner{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);margin-bottom:var(--space-6);animation:slideUp .3s ease}.error-banner svg{width:20px;height:20px;color:var(--color-danger);flex-shrink:0}.error-banner p{font-size:var(--font-size-sm);color:var(--color-danger);flex:1}.error-banner button{font-size:var(--font-size-xs);font-weight:600;color:var(--color-danger);background:none;border:none;cursor:pointer;text-decoration:underline}.warning-banner{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-warning-bg);border:1px solid var(--color-warning-border);border-radius:var(--radius-md);margin-bottom:var(--space-6);animation:slideUp .3s ease}.warning-banner svg{width:20px;height:20px;color:var(--color-warning);flex-shrink:0}.warning-banner p{font-size:var(--font-size-sm);color:var(--color-warning);flex:1}@media(max-width:900px){.sidebar{display:none}.main-content{margin-left:0}.intake-grid,.checklist-grid,.processing-steps{grid-template-columns:1fr}}.breadcrumb-sep{color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.breadcrumb-link{background:none;border:none;font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;padding:0;transition:color var(--transition-fast)}.breadcrumb-link:hover{color:var(--color-accent);text-decoration:underline}.save-success-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-success-bg);border:1px solid var(--color-success-border);border-radius:var(--radius-md);color:var(--color-success);font-size:var(--font-size-sm);font-weight:600;animation:fadeIn .3s ease}.save-success-badge svg{width:16px;height:16px}.vendor-loading{text-align:center;padding:var(--space-12) 0}.vendor-empty{text-align:center;padding:var(--space-12) var(--space-8);color:var(--color-text-tertiary)}.vendor-empty-icon{width:56px;height:56px;margin:0 auto var(--space-5);background:var(--color-surface-hover);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary)}.vendor-empty-icon svg{width:28px;height:28px}.vendor-empty h3{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-2)}.vendor-empty p{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.vendor-dir-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.plan-usage-banner{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-left:auto}.plan-usage-info{display:flex;align-items:center;gap:var(--space-3)}.plan-usage-badge{display:inline-block;padding:2px var(--space-2);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:#4f46e51a;color:var(--color-accent);border-radius:var(--radius-sm)}.plan-usage-text{font-weight:500}.plan-usage-banner--limit{border-color:#d977064d;box-shadow:0 0 0 1px #d977061a}.plan-usage-banner--limit .plan-usage-text{color:#d97706;font-weight:600}.plan-usage-banner--limit .plan-usage-badge{background:#d977061f;color:#d97706}.vendor-filter-bar{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-8);margin-bottom:var(--space-1)}.vendor-filter-search{position:relative;flex:1;max-width:280px}.vendor-filter-search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none;transition:color var(--transition-fast)}.vendor-filter-search:focus-within .vendor-filter-search-icon{color:var(--color-accent)}.vendor-filter-input{width:100%;padding:8px var(--space-3) 8px 36px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);outline:none;transition:all var(--transition-fast)}.vendor-filter-input:hover{border-color:var(--color-text-tertiary)}.vendor-filter-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-bg)}.vendor-filter-input::placeholder{color:var(--color-text-tertiary)}.vendor-filter-group{display:flex;align-items:center;gap:var(--space-2)}.vendor-filter-select-wrap{position:relative;display:flex;align-items:center}.vendor-filter-select-icon{position:absolute;left:10px;color:var(--color-text-tertiary);pointer-events:none}.vendor-filter-select{padding:8px 32px 8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;outline:none;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;transition:all var(--transition-fast);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.vendor-filter-select-icon+.vendor-filter-select{padding-left:30px}.vendor-filter-select:hover{border-color:var(--color-text-tertiary);color:var(--color-text-primary)}.vendor-filter-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-bg);color:var(--color-text-primary)}.vendor-filter-refresh{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.vendor-filter-refresh:hover{border-color:var(--color-text-tertiary);color:var(--color-text-primary);background:var(--color-surface-hover)}.vendor-filter-refresh:active{transform:scale(.95)}.vendor-filter-clear{display:flex;align-items:center;justify-content:center;gap:6px;height:34px;padding:0 12px;border:1px dashed var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.vendor-filter-clear:hover{border-color:var(--color-text-tertiary);color:var(--color-text-primary);background:var(--color-surface-hover)}.vendor-filter-clear:active{transform:scale(.95)}.vendor-table-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs)}.vendor-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.vendor-table thead th{text-align:left;padding:var(--space-3) var(--space-5);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);background:var(--color-bg);border-bottom:1px solid var(--color-border)}.vendor-table tbody td{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-light);color:var(--color-text-primary);vertical-align:middle}.vendor-row{cursor:pointer;transition:background var(--transition-fast)}.vendor-row:hover{background:var(--color-surface-hover)}.vendor-row:last-child td{border-bottom:none}.vendor-cell-name{display:flex;align-items:center;gap:var(--space-3)}.vendor-cell-logo{width:36px;height:36px;border-radius:var(--radius-md);object-fit:cover;border:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0}.vendor-cell-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-accent),var(--color-accent-light));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:var(--font-size-sm);flex-shrink:0}.vendor-cell-title{font-weight:600;color:var(--color-text-primary)}.vendor-cell-url{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.vendor-grade{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin-right:var(--space-2)}.vendor-delete-btn{width:32px;height:32px;border:none;background:none;cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.vendor-delete-btn:hover{background:var(--color-danger-bg);color:var(--color-danger)}.vendor-delete-btn svg{width:16px;height:16px}.vendor-score{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:500}.vendor-detail-logo{width:64px;height:64px;border-radius:var(--radius-md);object-fit:cover;border:1px solid var(--color-border);background:var(--color-surface);box-shadow:var(--shadow-xs);flex-shrink:0}.btn-back{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:400;color:var(--color-text-secondary);background:none;border:none;cursor:pointer;padding:0;transition:color var(--transition-fast)}.btn-back:hover{color:var(--color-text-primary)}.btn-back svg{width:16px;height:16px}.vendor-tabs{display:inline-flex;padding:4px;background:var(--color-border-light);border-radius:var(--radius-lg);margin:0 var(--space-8) var(--space-6);gap:4px}.vendor-tab{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:none;background:transparent;font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.vendor-tab:hover{color:var(--color-text-primary)}.vendor-tab.active{color:var(--color-text-primary);background:var(--color-surface);box-shadow:var(--shadow-sm);font-weight:600}.vendor-tab svg{width:16px;height:16px}.vendor-detail-grid{display:grid;grid-template-columns:7fr 3fr;gap:var(--space-8);align-items:start}.vendor-detail-header{display:flex;align-items:center;gap:var(--space-5)}.vendor-detail-url{color:var(--color-text-secondary)!important;font-size:var(--font-size-sm)!important}.vendor-detail-logo{width:56px;height:56px;border-radius:var(--radius-lg);object-fit:contain;background:var(--color-surface);border:1px solid var(--color-border);padding:6px;flex-shrink:0}.detail-rows{display:flex;flex-direction:column}.detail-row{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start;gap:var(--space-2);padding:var(--space-5) 0;border-bottom:1px solid var(--color-border-light)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:400}.detail-value{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);text-align:left;width:100%}.detail-link{color:var(--color-text-primary);text-decoration:none;transition:color var(--transition-fast)}.detail-link:hover{color:var(--color-accent)}.detail-grade{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text-primary);line-height:1}.detail-view-btn{margin-top:var(--space-8);width:100%}.detail-edit-input,.detail-edit-select,.detail-edit-textarea{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;outline:none;transition:all var(--transition-fast);text-align:left}.detail-edit-input,.detail-edit-select{max-width:100%;width:100%}.detail-edit-input:hover,.detail-edit-select:hover,.detail-edit-textarea:hover{border-color:var(--color-text-tertiary)}.detail-edit-input:focus,.detail-edit-select:focus,.detail-edit-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-bg);background:var(--color-surface)}.detail-edit-input::placeholder,.detail-edit-textarea::placeholder{color:var(--color-text-tertiary);font-weight:400}.detail-edit-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:28px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.detail-edit-textarea{resize:vertical;min-height:80px;line-height:1.5;max-width:100%}.risk-dot{width:8px;height:8px;border-radius:50%;background:currentColor;display:inline-block}.reports-list{display:flex;flex-direction:column;gap:var(--space-4);margin-top:var(--space-2)}.report-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-6) var(--space-8);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast)}.report-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-md)}.report-card-left{display:flex;align-items:center;gap:var(--space-5);flex:1;min-width:0}.report-card-grade-circle{width:56px;height:56px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:800;flex-shrink:0;color:var(--color-text-primary);background:var(--color-surface-hover);border:2px solid var(--color-border)}.report-card-grade-circle.pass{background:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success)}.report-card-grade-circle.fail{background:var(--color-danger-bg);border-color:var(--color-danger-border);color:var(--color-danger)}.report-card-info{flex:1;min-width:0}.report-card-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin-bottom:2px}.report-card-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.report-card-files{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.report-card-file{display:inline-flex;align-items:center;padding:2px var(--space-2);background:var(--color-surface-hover);border-radius:var(--radius-sm);font-size:.6875rem;color:var(--color-text-secondary);font-weight:500}.report-card-right{display:flex;align-items:center;gap:var(--space-6);flex-shrink:0}.report-delete-btn{width:32px;height:32px;border:none;background:none;cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);margin-left:var(--space-2)}.report-delete-btn:hover{background:var(--color-danger-bg);color:var(--color-danger)}.report-delete-btn svg{width:16px;height:16px}.report-card-score{font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-weight:500}.doc-table{width:100%}.doc-table-header{display:grid;grid-template-columns:1fr 140px 100px 80px;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border-light)}.doc-table-row{display:grid;grid-template-columns:1fr 140px 100px 80px;gap:var(--space-3);padding:var(--space-3) var(--space-4);align-items:center;border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast)}.doc-table-row:last-child{border-bottom:none}.doc-table-row:hover{background:var(--color-surface-hover)}.doc-col-name{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);background:var(--color-surface-hover)}.doc-icon svg{width:18px;height:18px}.doc-col-date,.doc-col-size{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.doc-col-actions{display:flex;align-items:center;gap:var(--space-1);justify-content:flex-end}.doc-action-btn{width:30px;height:30px;border:none;background:none;cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.doc-action-btn:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.doc-action-btn svg{width:15px;height:15px}.doc-action-delete:hover{background:var(--color-danger-bg);color:var(--color-danger)}.doc-table-footer{padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);color:var(--color-text-tertiary);border-top:1px solid var(--color-border-light)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:400px;padding:var(--space-6)}.modal-header h3{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-4)}.modal-body{margin-bottom:var(--space-6)}.modal-body p{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.modal-subtext{font-size:var(--font-size-sm)!important;color:var(--color-text-tertiary)!important}.modal-warning{font-size:var(--font-size-sm)!important;color:var(--color-danger)!important;font-weight:500;margin-top:var(--space-4)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3)}.btn-delete{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.slide-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000}.slide-panel{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:100vw;background:var(--color-surface);border-left:1px solid var(--color-border);box-shadow:var(--shadow-xl);z-index:1001;display:flex;flex-direction:column}.slide-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.slide-panel-header h2{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary)}.slide-panel-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.slide-panel-close:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.slide-panel-body{flex:1;overflow-y:auto;padding:var(--space-6)}.slide-panel-field{margin-bottom:var(--space-5)}.slide-panel-label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-2)}.slide-panel-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);flex-shrink:0}@media(max-width:540px){.slide-panel{width:100vw}}.btn-delete:hover{background:var(--color-primary-light)}.btn-delete:disabled{opacity:.5;cursor:not-allowed}@media(max-width:900px){.vendor-detail-grid{grid-template-columns:1fr}.vendor-table-wrap{overflow-x:auto}.vendor-table{min-width:700px}.report-card{flex-direction:column;align-items:flex-start}.report-card-right{width:100%;justify-content:flex-end}}.screening-overlay{display:flex;align-items:center;justify-content:center;padding:var(--space-12) var(--space-8);flex:1}.screening-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:640px;overflow:hidden}.screening-auto{text-align:center;padding:var(--space-10) var(--space-8)}.screening-auto-icon{width:56px;height:56px;margin:0 auto var(--space-5);background:var(--color-success-bg);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-success)}.screening-auto-icon svg{width:28px;height:28px}.screening-auto h2{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-2)}.screening-auto p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6)}.screening-progress-bar{width:200px;height:4px;background:var(--color-border-light);border-radius:var(--radius-full);margin:0 auto;overflow:hidden}.screening-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-success),var(--color-accent));border-radius:var(--radius-full);animation:screeningFill 1.2s ease forwards}@keyframes screeningFill{0%{width:0}to{width:100%}}.screening-header{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-6);border-bottom:1px solid var(--color-border-light)}.screening-header-icon{width:40px;height:40px;background:var(--color-warning-bg);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-warning);flex-shrink:0}.screening-header-icon svg{width:20px;height:20px}.screening-header h2{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-1)}.screening-header p{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.screening-list{padding:var(--space-4) var(--space-6)}.screening-result{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-light);background:var(--color-surface)}.screening-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border-light);transition:all var(--transition-fast)}.screening-item+.screening-item{margin-top:var(--space-3)}.screening-item.screening-pass{border-color:var(--color-success-border);background:var(--color-success-bg)}.screening-item.screening-fail{border-color:var(--color-danger-border);background:var(--color-danger-bg)}.screening-item-icon{width:24px;height:24px;flex-shrink:0}.screening-pass .screening-item-icon{color:var(--color-success)}.screening-fail .screening-item-icon{color:var(--color-danger)}.screening-item-info{flex:1;min-width:0}.screening-item-name{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-bottom:2px}.screening-item-name svg{width:14px;height:14px;color:var(--color-text-tertiary);flex-shrink:0}.screening-item-summary{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.4}.screening-fail .screening-item-summary{color:var(--color-danger)}.screening-item-warning{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);font-weight:500;color:#d97706;margin-top:var(--space-1);line-height:1.4}.screening-item-warning svg{width:14px;height:14px;flex-shrink:0}.screening-badge{font-size:var(--font-size-xs);font-weight:600;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0}.screening-badge-pass{background:#0596691a;color:var(--color-success)}.screening-badge-fail{background:#dc26261a;color:var(--color-danger)}.screening-item.screening-pending{border-color:var(--color-border);background:var(--color-surface-hover)}.screening-pending .screening-item-icon{color:var(--color-text-secondary);animation:spin 1.4s linear infinite}.screening-badge-pending{background:#6366f114;color:var(--color-accent)}.screening-summary-pulse{animation:pulse 1.6s ease-in-out infinite}.screening-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-4);padding:var(--space-5) var(--space-6);border-top:1px solid var(--color-border-light)}@media print{body.printing-report .sidebar,body.printing-report .breadcrumb-bar,body.printing-report .report-actions-bar,body.printing-report .btn-back,body.printing-report .notification-btn,body.printing-report .theme-toggle-btn{display:none!important}body.printing-report .app-layout{display:block}body.printing-report .main-content{margin-left:0;padding:0;overflow:visible}body.printing-report .report-page{max-width:100%;padding:0;margin:0}body.printing-report .report-header-card{-webkit-print-color-adjust:exact;print-color-adjust:exact;break-inside:avoid}body.printing-report .risk-table,body.printing-report .checklist-grid,body.printing-report .report-section{break-inside:avoid}body.printing-report .severity-badge,body.printing-report .report-risk-badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}body.printing-report *{box-shadow:none!important}body.printing-report .report-vendor-logo{background:#fff3}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:var(--space-8);position:relative;overflow:hidden}.auth-page:before{content:"";position:absolute;top:-40%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(79,70,229,.06) 0%,transparent 70%);pointer-events:none}.auth-page:after{content:"";position:absolute;bottom:-30%;left:-15%;width:500px;height:500px;background:radial-gradient(circle,rgba(99,102,241,.04) 0%,transparent 70%);pointer-events:none}.auth-container{width:100%;max-width:420px;position:relative;z-index:1}.auth-brand{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-bottom:var(--space-10)}.auth-brand-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.auth-brand-logo{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-lg)}.auth-brand h1{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10);box-shadow:var(--shadow-lg)}.auth-card h2{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-2)}.auth-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-8);line-height:1.5}.auth-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--font-size-sm);margin-bottom:var(--space-6)}.auth-error svg{flex-shrink:0}.auth-domain-match{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:#4f46e50f;border:1px solid rgba(79,70,229,.18);border-radius:var(--radius-md);margin-bottom:var(--space-6);animation:domainMatchIn .3s ease-out}@keyframes domainMatchIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.auth-domain-match-icon{width:36px;height:36px;background:#4f46e51f;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-accent);flex-shrink:0}.auth-domain-match-content{flex:1;min-width:0}.auth-domain-match-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-bottom:2px;line-height:1.4}.auth-domain-match-subtitle{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.4}.auth-domain-match-btn{flex-shrink:0;height:34px;padding:0 var(--space-4);font-size:var(--font-size-xs);align-self:center}.auth-field-hint{display:block;font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--space-1);line-height:1.4}.auth-field{margin-bottom:var(--space-5)}.auth-field label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-2)}.auth-field input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-text-primary);background:var(--color-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;height:44px}.auth-field input::placeholder{color:var(--color-text-tertiary)}.auth-field input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #4f46e51a}.auth-submit{width:100%;height:44px;margin-top:var(--space-2);font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-md)}.auth-footer{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-border-light);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.auth-switch{background:none;border:none;color:var(--color-accent);font-weight:600;font-size:var(--font-size-sm);font-family:var(--font-family);cursor:pointer;padding:0;transition:color var(--transition-fast)}.auth-switch:hover{color:var(--color-accent-light)}.auth-legal{text-align:center;font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--space-8);line-height:1.5}.auth-success{text-align:center;padding:var(--space-6) 0}.auth-success-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:var(--radius-full);background:var(--color-success-bg);color:var(--color-success);margin-bottom:var(--space-6)}.auth-success h2{margin-bottom:var(--space-3)}.auth-success p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6);line-height:1.6}.auth-google-btn{width:100%;height:44px;display:flex;align-items:center;justify-content:center;gap:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;font-family:var(--font-family);color:var(--color-text-primary);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.auth-google-btn:hover:not(:disabled){background:var(--color-border-light);border-color:var(--color-text-tertiary)}.auth-google-btn:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:var(--space-3);margin:var(--space-6) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-divider span{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.auth-loading-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-user-menu{position:absolute;bottom:calc(100% + var(--space-2));left:var(--space-3);right:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-1);z-index:200;animation:slideDownFade .15s ease-out}.sidebar-user-menu-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);border:none;background:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.sidebar-user-menu-item:hover{background:var(--color-danger-bg);color:var(--color-danger)}.sidebar-user-menu-item svg{flex-shrink:0}@keyframes dashFadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes dashScaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes dashCountUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dashboard-container{display:flex;flex-direction:column;gap:1.25rem;padding-bottom:2rem}.dashboard-container>.page-header{animation:dashFadeUp .45s cubic-bezier(.22,1,.36,1) both}.dashboard-content{display:flex;flex-direction:column;gap:1.25rem;padding:0 var(--space-8)}.dashboard-loading,.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem 2rem;color:var(--color-text-secondary)}.dashboard-kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.dashboard-kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg, 12px);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.25rem;animation:dashFadeUp .45s cubic-bezier(.22,1,.36,1) both}.dashboard-kpi-card:nth-child(1){animation-delay:0s}.dashboard-kpi-card:nth-child(2){animation-delay:.06s}.dashboard-kpi-card:nth-child(3){animation-delay:.12s}.dashboard-kpi-card:nth-child(4){animation-delay:.18s}.dashboard-kpi-card:nth-child(5){animation-delay:.24s}.dashboard-kpi-success{border-left:3px solid var(--color-success)}.dashboard-kpi-danger{border-left:3px solid var(--color-danger)}.kpi-value{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);line-height:1.2;animation:dashCountUp .4s cubic-bezier(.22,1,.36,1) .25s both}.dashboard-kpi-success .kpi-value{color:var(--color-success)}.dashboard-kpi-danger .kpi-value{color:var(--color-danger)}.kpi-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.dashboard-grid-2col{display:grid;grid-template-columns:1.2fr .8fr;gap:1.25rem}.dashboard-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg, 12px);padding:1.25rem;animation:dashScaleIn .5s cubic-bezier(.22,1,.36,1) .3s both}.dashboard-grid-2col .dashboard-panel:nth-child(1){animation-delay:.3s}.dashboard-grid-2col .dashboard-panel:nth-child(2){animation-delay:.4s}.dashboard-panel.dashboard-full-width{animation-name:dashFadeUp;animation-delay:.45s}.dashboard-panel.dashboard-full-width+.dashboard-panel.dashboard-full-width{animation-delay:.55s}.dashboard-full-width{grid-column:1 / -1}.dashboard-panel-title{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);margin-bottom:1rem}.dashboard-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.dashboard-panel-header .dashboard-panel-title{margin-bottom:0}.dashboard-empty{text-align:center;color:var(--color-text-tertiary);padding:2rem 1rem;font-size:var(--font-size-sm)}.dashboard-table-wrap{overflow-x:auto;overflow-y:hidden}.dashboard-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.dashboard-table th{text-align:left;font-weight:600;color:var(--color-text-secondary);padding:.5rem .75rem;border-bottom:1px solid var(--color-border);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.dashboard-table td{padding:.625rem .75rem;border-bottom:1px solid var(--color-border-light);color:var(--color-text-primary);vertical-align:middle}.dashboard-row-clickable{cursor:pointer;transition:background var(--transition-fast);animation:dashFadeUp .35s cubic-bezier(.22,1,.36,1) both}.dashboard-row-clickable:nth-child(1){animation-delay:.35s}.dashboard-row-clickable:nth-child(2){animation-delay:.4s}.dashboard-row-clickable:nth-child(3){animation-delay:.45s}.dashboard-row-clickable:nth-child(4){animation-delay:.5s}.dashboard-row-clickable:nth-child(5){animation-delay:.55s}.dashboard-row-clickable:nth-child(n+6){animation-delay:.58s}.dashboard-row-clickable:hover{background:var(--color-surface-hover)}.fw-medium{font-weight:500}.vendor-cell{display:flex;align-items:center;gap:.5rem}.vendor-logo-sm{width:24px;height:24px;border-radius:4px;object-fit:contain;flex-shrink:0}.vendor-logo-placeholder-sm{width:24px;height:24px;border-radius:4px;background:var(--color-accent-bg);color:var(--color-accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}.grade-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-size:var(--font-size-xs);font-weight:700;color:#fff}.grade-A{background:#059669}.grade-B{background:#10b981}.grade-C{background:#d97706}.grade-D{background:#f59e0b}.grade-F{background:#dc2626}.criticality-badge{display:inline-block;padding:.125rem .5rem;border-radius:999px;font-size:var(--font-size-xs);font-weight:600;text-transform:capitalize}.criticality-critical{background:var(--color-critical-bg);color:var(--color-critical)}.criticality-high{background:var(--color-danger-bg);color:var(--color-danger)}.criticality-medium{background:var(--color-warning-bg);color:var(--color-warning)}.criticality-low{background:var(--color-info-bg);color:var(--color-info)}.days-badge{display:inline-block;padding:.125rem .5rem;border-radius:999px;font-size:var(--font-size-xs);font-weight:600;white-space:nowrap}.days-badge-expired,.days-badge-urgent{background:var(--color-danger-bg);color:var(--color-danger)}.days-badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.days-badge-ok{background:var(--color-success-bg);color:var(--color-success)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.375rem;vertical-align:middle}.status-active{background:var(--color-success)}.status-expired{background:var(--color-danger)}.status-unknown{background:var(--color-text-tertiary)}.dashboard-filter-tabs{display:flex;gap:.25rem;background:var(--color-bg);border-radius:var(--radius-md, 8px);padding:.2rem}.filter-tab{border:none;background:none;padding:.375rem .75rem;font-size:var(--font-size-xs);font-weight:500;font-family:var(--font-family);color:var(--color-text-secondary);border-radius:var(--radius-sm, 6px);cursor:pointer;transition:all var(--transition-fast)}.filter-tab:hover{color:var(--color-text-primary)}.filter-tab.active{background:var(--color-surface);color:var(--color-text-primary);box-shadow:0 1px 2px #0000000f}.systemic-header-left{display:flex;flex-direction:column;gap:.125rem}.systemic-header-left .dashboard-panel-title{margin-bottom:0}.systemic-subtitle{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.systemic-count-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:999px;font-size:var(--font-size-xs);font-weight:600;background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-border);white-space:nowrap}.systemic-risk-list{display:flex;flex-direction:column;gap:.5rem}.systemic-risk-item{border:1px solid var(--color-border);border-radius:var(--radius-md, 8px);overflow:hidden;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.systemic-risk-item:hover{border-color:var(--color-border-hover, var(--color-text-tertiary))}.systemic-risk-item.expanded{border-color:var(--color-accent);box-shadow:0 0 0 2px #4f46e514}.systemic-risk-row{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;font-family:var(--font-family);text-align:left;transition:background var(--transition-fast)}.systemic-risk-row:hover{background:var(--color-surface-hover)}.systemic-severity-bar{width:4px;align-self:stretch;min-height:36px;border-radius:4px;flex-shrink:0}.systemic-risk-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.systemic-risk-label-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.systemic-risk-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.systemic-severity-badge{display:inline-flex;align-items:center;padding:.1rem .5rem;border-radius:999px;font-size:.6875rem;font-weight:600;border:1px solid}.systemic-risk-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.systemic-domain-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:500}.systemic-domain-badge svg{opacity:.6}.systemic-priority-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:500}.systemic-vendor-count{display:flex;flex-direction:column;align-items:center;padding:.25rem .75rem;background:var(--color-surface-hover);border-radius:var(--radius-md, 8px);flex-shrink:0;min-width:52px}.systemic-vendor-count-num{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);line-height:1.2}.systemic-vendor-count-label{font-size:.625rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.03em;font-weight:600}.systemic-chevron{flex-shrink:0;color:var(--color-text-tertiary);transition:transform .2s ease}.systemic-chevron.open{transform:rotate(180deg)}.systemic-vendor-list{border-top:1px solid var(--color-border-light);background:var(--color-bg);padding:.5rem;animation:slideDownFade .15s ease-out}.systemic-risk-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5;padding:.5rem .75rem .75rem;margin:0;border-bottom:1px solid var(--color-border-light)}.systemic-vendor-list-header{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);padding:.25rem .5rem .5rem}.systemic-vendor-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem;border:none;background:none;border-radius:var(--radius-sm, 6px);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;transition:background var(--transition-fast)}.systemic-vendor-item:hover{background:var(--color-surface-hover)}.dashboard-news-list{display:flex;flex-direction:column}.dashboard-news-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);text-decoration:none;color:inherit;border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast)}.dashboard-news-item:last-child{border-bottom:none}.dashboard-news-item:hover{background:var(--color-surface-hover)}.dashboard-news-left{display:flex;align-items:flex-start;gap:var(--space-3);min-width:0}.dashboard-news-content{min-width:0}.dashboard-news-headline{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);line-height:1.4;margin-bottom:2px}.dashboard-news-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.dashboard-news-vendor-link{background:none;border:none;padding:0;font-family:var(--font-family);font-size:var(--font-size-xs);font-weight:600;color:var(--color-accent);cursor:pointer;text-decoration:none}.dashboard-news-vendor-link:hover{text-decoration:underline}.dashboard-news-arrow{flex-shrink:0;color:var(--color-text-tertiary);opacity:0;transition:opacity var(--transition-fast)}.dashboard-news-item:hover .dashboard-news-arrow{opacity:1}@media(max-width:1024px){.dashboard-kpi-row{grid-template-columns:repeat(3,1fr)}.dashboard-grid-2col{grid-template-columns:1fr}}@media(max-width:640px){.dashboard-kpi-row{grid-template-columns:repeat(2,1fr)}}@media(prefers-reduced-motion:reduce){.dashboard-kpi-card,.dashboard-container>.page-header,.dashboard-panel,.dashboard-row-clickable,.kpi-value{animation:none!important}}.email-draft-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000073;display:flex;align-items:center;justify-content:center;padding:var(--space-8);animation:fadeIn .2s ease}.email-draft-modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:960px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .25s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.email-draft-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border)}.email-draft-header h2{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);margin:0}.email-draft-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.email-draft-close:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.email-draft-body{flex:1;overflow-y:auto;padding:var(--space-5) var(--space-6);min-height:200px}.email-draft-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-12) 0;color:var(--color-text-secondary)}.email-draft-loading p{font-size:var(--font-size-sm)}.email-draft-error{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-8) 0;text-align:center}.email-draft-error svg{width:24px;height:24px;color:var(--color-danger)}.email-draft-error p{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.email-draft-copy-bar{display:flex;justify-content:flex-end;margin-bottom:var(--space-3)}.email-draft-content{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5);font-size:var(--font-size-sm);line-height:1.7;color:var(--color-text-primary);white-space:pre-wrap;font-family:var(--font-family)}.email-draft-footer{display:flex;justify-content:flex-end;padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border)}.settings-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-6)}.settings-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border)}.settings-section-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin:0 0 2px}.settings-section-desc{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:0}.settings-member-email{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.role-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full, 9999px);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.01em}.role-admin{background:var(--color-warning-subtle, rgba(217, 119, 6, .1));color:var(--color-warning, #d97706)}.role-member{background:var(--color-surface-raised, rgba(107, 114, 128, .1));color:var(--color-text-secondary, #6b7280)}.invite-status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.invite-status-active{background:var(--color-success-bg);color:var(--color-success)}.invite-status-pending{background:var(--color-warning-bg);color:var(--color-warning)}.settings-member-pending{opacity:.75}.vendor-cell-avatar-pending{background:var(--color-warning-bg)!important;color:var(--color-warning)!important;display:flex;align-items:center;justify-content:center}.invite-actions{display:flex;align-items:center;gap:4px;justify-content:flex-end}.invite-action-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.invite-action-btn:hover{border-color:var(--color-text-tertiary);color:var(--color-text-primary);background:var(--color-surface-hover)}.invite-action-btn-danger:hover{border-color:var(--color-danger-border);color:var(--color-danger);background:var(--color-danger-bg)}.invite-modal{background:var(--color-surface);border-radius:var(--radius-xl);width:100%;max-width:460px;box-shadow:var(--shadow-xl);animation:modalSlideUp .2s ease}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.invite-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border)}.invite-modal-header h3{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin:0}.invite-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.invite-modal-close:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.invite-modal-body{padding:var(--space-6)}.invite-modal-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--space-5);line-height:1.5}.invite-modal-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);margin-bottom:var(--space-2)}.invite-modal-input,.invite-modal-select{width:100%;padding:10px var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);outline:none;transition:all var(--transition-fast);margin-bottom:var(--space-4)}.invite-modal-input:focus,.invite-modal-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-bg)}.invite-modal-input::placeholder{color:var(--color-text-tertiary)}.invite-modal-error{padding:10px var(--space-3);background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500}.invite-modal-success{padding:10px var(--space-3);background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500}.invite-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border)}.invite-banner{display:flex;align-items:center;justify-content:space-between;margin:0 var(--space-8) var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;animation:fadeIn .3s ease}.invite-banner button{background:none;border:none;font-size:18px;cursor:pointer;color:inherit;opacity:.6;padding:0 0 0 var(--space-3)}.invite-banner button:hover{opacity:1}.invite-banner-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.invite-banner-error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-border)}.shared-report-page{min-height:100vh;background:var(--color-bg, #f5f5f7);display:flex;flex-direction:column;align-items:center;padding:var(--space-8) var(--space-4)}.shared-report-container{width:100%;max-width:960px}.shared-report-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:6rem 2rem;color:var(--color-text-secondary)}.shared-report-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:6rem 2rem;text-align:center;color:var(--color-text-secondary)}.shared-report-error-icon{color:var(--color-text-tertiary);opacity:.5;margin-bottom:.5rem}.shared-report-error h2{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary)}.shared-report-footer{text-align:center;padding:var(--space-8) 0 var(--space-4);color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.shared-report-footer a{color:var(--color-primary);text-decoration:none}.shared-report-footer a:hover{text-decoration:underline}.share-link-row{display:flex;gap:var(--space-2);align-items:center}.paywall-gate{display:flex;align-items:center;justify-content:center;flex:1;padding:var(--space-8)}.paywall-gate-card{display:flex;flex-direction:column;align-items:center;text-align:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-12) var(--space-10);width:100%;max-width:480px;gap:var(--space-3);animation:slideUpFade .3s ease-out}@keyframes slideUpFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.paywall-gate-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:var(--radius-full);background:var(--color-accent-bg);color:var(--color-accent);font-size:2rem;margin-bottom:var(--space-3)}.paywall-gate-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary);margin:0}.paywall-gate-body{font-size:var(--font-size-md);color:var(--color-text-secondary);line-height:1.5;margin:0;margin-bottom:var(--space-3);max-width:420px}.paywall-gate-actions{display:flex;gap:var(--space-3)}.billing-card{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}.billing-card-plan{display:flex;align-items:center;gap:var(--space-4)}.billing-plan-badge{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg);flex-shrink:0}.billing-plan-badge[data-plan=free]{background:var(--color-bg-tertiary, #f3f4f6);color:var(--color-text-secondary)}.billing-plan-badge[data-plan=pro]{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.billing-plan-badge[data-plan=enterprise]{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.billing-plan-name{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);margin:0 0 2px}.billing-plan-desc{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:0}.billing-usage{display:flex;flex-direction:column;gap:var(--space-2)}.billing-usage-label{display:flex;justify-content:space-between;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.billing-usage-bar{height:8px;border-radius:var(--radius-full, 9999px);background:var(--color-bg-tertiary, #f3f4f6);overflow:hidden}.billing-usage-fill{height:100%;border-radius:var(--radius-full, 9999px);background:var(--color-primary);transition:width .4s ease}.billing-usage-fill[data-full=true]{background:var(--color-danger, #ef4444)}.billing-usage-note{font-size:var(--font-size-xs, .75rem);color:var(--color-text-tertiary);margin-top:var(--space-1, 4px)}.billing-pro-features{display:flex;flex-wrap:wrap;gap:var(--space-3)}.billing-feature{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.billing-feature svg{color:var(--color-success, #22c55e)}.billing-card-action{padding-top:var(--space-2)}.admin-dashboard{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-6)}.admin-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap}.admin-header h1{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text-primary);margin:0}.admin-subtitle{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:var(--space-1) 0 0}.admin-controls{display:flex;align-items:center;gap:var(--space-3)}.admin-period-picker{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.admin-period-btn{padding:var(--space-1) var(--space-3);font-size:var(--font-size-sm);background:var(--color-surface);color:var(--color-text-secondary);border:none;cursor:pointer;transition:all .15s ease}.admin-period-btn:not(:last-child){border-right:1px solid var(--color-border)}.admin-period-btn.active{background:var(--color-text-primary);color:var(--color-surface)}.admin-period-btn:hover:not(.active){background:var(--color-bg-hover, rgba(0,0,0,.04))}.admin-refresh-btn{font-size:var(--font-size-sm)!important;padding:var(--space-1) var(--space-3)!important}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-3)}.admin-stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-1)}.admin-stat-value{font-size:28px;font-weight:700;color:var(--color-text-primary);font-variant-numeric:tabular-nums;line-height:1}.admin-stat-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.admin-stat-delta{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);font-weight:600;margin-top:var(--space-1)}.admin-stat-delta.up{color:var(--color-success, #16a34a)}.admin-stat-delta.down{color:var(--color-danger, #dc2626)}.admin-stat-delta.flat{color:var(--color-text-tertiary)}.admin-delta-arrow{font-size:14px;line-height:1}.admin-delta-count{font-weight:400;color:var(--color-text-tertiary)}.admin-charts-row{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-4)}.admin-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2)}.admin-card h3{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);margin:0}.admin-card-sub{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin:0}.admin-chart-container{flex:1;min-height:220px}.admin-empty{display:flex;align-items:center;justify-content:center;flex:1;min-height:100px;font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.admin-plan-legend{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2)}.admin-legend-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm)}.admin-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.admin-legend-label{color:var(--color-text-secondary);text-transform:capitalize}.admin-legend-count{margin-left:auto;font-weight:600;color:var(--color-text-primary);font-variant-numeric:tabular-nums}.admin-retention-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);flex:1;align-content:center}.admin-retention-stat{text-align:center;padding:var(--space-3);background:var(--color-bg-secondary, rgba(0,0,0,.02));border-radius:var(--radius-md)}.admin-retention-value{font-size:24px;font-weight:700;color:var(--color-text-primary);line-height:1}.admin-retention-pct{font-size:var(--font-size-sm);color:#dc2626;font-weight:600;margin-top:var(--space-1)}.admin-retention-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--space-1)}.admin-table-wrapper{flex:1;overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.admin-table th{text-align:left;font-weight:500;color:var(--color-text-tertiary);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.04em}.admin-table td{padding:var(--space-2) var(--space-3);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-light, rgba(0,0,0,.04))}.admin-table tbody tr:hover{background:var(--color-bg-hover, rgba(0,0,0,.02))}.admin-rank{color:var(--color-text-tertiary);font-size:var(--font-size-xs);margin-right:var(--space-2)}.admin-plan-badge{display:inline-block;padding:1px 8px;border-radius:var(--radius-full, 999px);font-size:var(--font-size-xs);font-weight:600;text-transform:capitalize}.admin-plan-free{background:#71717a1a;color:#71717a}.admin-plan-pro{background:#dc26261a;color:#dc2626}.admin-plan-enterprise{background:#18181b1a;color:#18181b}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);min-height:300px;color:var(--color-text-tertiary)}.admin-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);min-height:300px;text-align:center}.admin-error h2{font-size:var(--font-size-lg);color:var(--color-danger, #dc2626)}.admin-error p{color:var(--color-text-secondary)}.admin-user-cell{display:flex;flex-direction:column;gap:1px}.admin-user-name{font-weight:500;color:var(--color-text-primary)}.admin-user-email{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.admin-events-badge{display:inline-block;padding:2px 10px;border-radius:var(--radius-full, 999px);background:#dc2626;color:#fff;font-size:var(--font-size-xs);font-weight:600;font-variant-numeric:tabular-nums}@media(max-width:768px){.admin-charts-row{grid-template-columns:1fr}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-header{flex-direction:column}}.news-feed{display:flex;flex-direction:column;gap:var(--space-3)}.news-feed-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.news-item{display:block;padding:var(--space-4) var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);cursor:pointer}.news-item:hover{border-color:var(--color-accent);box-shadow:var(--shadow-md)}.news-item-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.news-item-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.news-item-headline{font-weight:600;font-size:var(--font-size-base);color:var(--color-text-primary);margin-bottom:var(--space-1);line-height:1.4}.news-item-summary{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5;margin-bottom:var(--space-2)}.news-item-link{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);font-weight:600;color:var(--color-accent)}.spin{animation:spin 1s linear infinite}
