@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--color-primary-50: #fff1f1;--color-primary-100: #ffe0e0;--color-primary-200: #ffc5c5;--color-primary-300: #ff9b9b;--color-primary-400: #ff6b6b;--color-primary-500: #FF3333;--color-primary-600: #e62e2e;--color-primary-700: #cc2929;--color-primary-800: #a81f1f;--color-primary-900: #7f1d1d;--color-accent-400: #fca94f;--color-accent-500: #f59e0b;--color-accent-600: #d97706;--color-success-50: #f0fdf4;--color-success-500: #22c55e;--color-success-600: #16a34a;--color-warning-50: #fffbeb;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-error-50: #fef2f2;--color-error-500: #ef4444;--color-error-600: #dc2626;--color-slate-50: #f8fafc;--color-slate-100: #f1f5f9;--color-slate-200: #e2e8f0;--color-slate-300: #cbd5e1;--color-slate-400: #94a3b8;--color-slate-500: #64748b;--color-slate-600: #475569;--color-slate-700: #334155;--color-slate-800: #1e293b;--color-slate-900: #111827;--bg-primary: #ffffff;--bg-secondary: #f4f5f7;--bg-tertiary: var(--color-slate-100);--bg-sidebar: #0a0a0a;--text-primary: var(--color-slate-900);--text-secondary: var(--color-slate-600);--text-tertiary: var(--color-slate-400);--text-inverse: #ffffff;--border-color: var(--color-slate-200);--border-focus: #FF3333;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .9375rem;--font-size-lg: 1.0625rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 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;--space-16: 4rem;--radius-sm: .25rem;--radius-md: .25rem;--radius-lg: .375rem;--radius-xl: .5rem;--radius-2xl: .75rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 256px;--header-height: 56px}[data-theme=dark]{--bg-primary: var(--color-slate-900);--bg-secondary: var(--color-slate-800);--bg-tertiary: var(--color-slate-700);--bg-sidebar: #0a0f1a;--text-primary: var(--color-slate-50);--text-secondary: var(--color-slate-300);--text-tertiary: var(--color-slate-500);--border-color: var(--color-slate-700)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.5;color:var(--text-primary);background-color:var(--bg-secondary)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.25;color:var(--text-primary)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}p{color:var(--text-secondary);margin-bottom:var(--space-4)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);color:var(--text-inverse);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.sidebar-header{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-brand{display:flex;align-items:center;gap:8px;margin-bottom:4px}.sidebar-brand-square{width:14px;height:14px;background:#f33;border-radius:2px}.sidebar-brand-name{font-size:10px;letter-spacing:3px;text-transform:uppercase;font-weight:800;color:#f33}.sidebar-product-name{padding-left:22px;color:#ffffffd1;font-size:13px;font-weight:600}.sidebar-nav{flex:1;padding:10px 8px}.nav-section{margin-bottom:8px}.nav-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#ffffff4d;padding:8px 10px 4px;margin-bottom:2px}.nav-item{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:var(--radius-md);color:#7f7f7f;text-decoration:none;font-size:13px;font-weight:500;transition:all var(--transition-fast);cursor:pointer;position:relative}.nav-item:hover{background:#ffffff0f;color:#cfcfcf}.nav-item.active{background:#ff333324;color:var(--text-inverse);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:5px;bottom:5px;width:2.5px;background:#f33;border-radius:0 2px 2px 0}.nav-item-icon{width:16px;height:16px;opacity:.55}.nav-item.active .nav-item-icon{opacity:1}.main-content{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column}.header{height:var(--header-height);background:var(--bg-primary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50}.page-content{flex:1;padding:28px 32px;max-width:1280px;width:100%;margin:0 auto}.page-header{display:flex;flex-direction:column;gap:8px}.page-header-eyebrow{font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--color-primary-600)}.page-header-title{font-size:clamp(1.75rem,2vw,2.25rem);line-height:1.1;font-weight:700;color:var(--text-primary)}.page-header-subtitle{max-width:860px;font-size:var(--font-size-lg);line-height:1.5;color:var(--text-secondary)}.summary-pills{display:flex;flex-wrap:wrap;gap:var(--space-2)}.summary-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--bg-secondary);font-size:var(--font-size-sm);color:var(--text-secondary);white-space:nowrap}.summary-pill strong{color:var(--text-primary)}.action-cluster{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;justify-content:flex-end}.card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-color)}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.card-description{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-1)}.artifact-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);transition:all var(--transition-base)}.artifact-card:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-md)}.artifact-card.is-input{border-left:3px solid var(--color-primary-500)}.artifact-card.is-output{border-left:4px solid var(--color-accent-500)}.artifact-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.artifact-id{font-family:SF Mono,Consolas,monospace;font-size:var(--font-size-xs);font-weight:600;color:var(--color-primary-600);background:var(--color-primary-50);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.artifact-description{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-2);line-height:1.6}.artifact-actions{display:flex;gap:var(--space-2);margin-top:var(--space-4);flex-wrap:wrap}.artifact-actions .btn{min-width:0;white-space:nowrap}.status-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:11px;font-weight:600}.status-badge.missing{background:var(--color-slate-100);color:var(--color-slate-600)}.status-badge.uploaded,.status-badge.in-progress{background:var(--color-primary-50);color:var(--color-primary-700)}.status-badge.generated{background:var(--color-warning-50);color:var(--color-warning-600)}.status-badge.verified,.status-badge.complete{background:var(--color-success-50);color:var(--color-success-600)}.status-badge.needs-review{background:var(--color-error-50);color:var(--color-error-600)}.progress-bar{height:6px;background:var(--color-slate-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-primary-500);border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-indicator{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm)}.progress-text{font-weight:500;color:var(--text-secondary)}.progress-percentage{font-weight:600;color:var(--color-primary-600)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid transparent;border-radius:var(--radius-lg);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#f33;border-color:#f33;color:#fff}.btn-primary:hover:not(:disabled){background:#cc2929;border-color:#cc2929}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--color-slate-300)}.btn-accent{background:var(--color-warning-500);border-color:var(--color-warning-500);color:#fff}.btn-accent:hover:not(:disabled){background:var(--color-accent-600)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--font-size-base)}.btn-icon{padding:var(--space-2)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);margin-bottom:var(--space-2)}.form-input,.form-textarea,.form-select{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-lg);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--text-primary);background:var(--bg-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #ff33331a}.form-textarea{min-height:120px;resize:vertical}.clause-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:var(--space-6);overflow:hidden}.clause-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);background:var(--color-slate-50);cursor:pointer;transition:background var(--transition-fast)}.clause-header:hover{background:var(--color-slate-100)}.clause-info{display:flex;align-items:center;gap:var(--space-4)}.clause-number{font-size:12px;font-weight:700;color:var(--color-primary-600);font-family:SF Mono,Consolas,monospace}.clause-title{font-weight:600}.clause-progress{display:flex;align-items:center;gap:var(--space-3)}.clause-content{padding:var(--space-5)}.clause-artifacts{display:grid;gap:var(--space-4)}.clause-artifacts-group{margin-bottom:var(--space-4)}.clause-artifacts-title{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.stride-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-4)}.stride-category{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5)}.stride-category-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.stride-icon{width:40px;height:40px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-lg)}.stride-icon.spoofing{background:#fce7f3;color:#be185d}.stride-icon.tampering{background:#fee2e2;color:#dc2626}.stride-icon.repudiation{background:#fef3c7;color:#d97706}.stride-icon.information-disclosure{background:#dbeafe;color:#2563eb}.stride-icon.denial-of-service{background:#e0e7ff;color:#4f46e5}.stride-icon.elevation-of-privilege{background:#ede9fe;color:#7c3aed}.stride-category-title{font-weight:600;color:var(--text-primary)}.stride-category-count{font-size:var(--font-size-sm);color:var(--text-secondary)}.threat-list{list-style:none}.threat-item{padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--space-2);font-size:var(--font-size-sm)}.risk-table{width:100%;border-collapse:collapse}.risk-table th,.risk-table td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--border-color)}.risk-table th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);background:var(--color-slate-50)}.risk-table td{font-size:var(--font-size-sm)}.risk-score{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);font-weight:600;font-size:var(--font-size-sm)}.risk-score.low{background:var(--color-success-50);color:var(--color-success-600)}.risk-score.medium{background:var(--color-warning-50);color:var(--color-warning-600)}.risk-score.high{background:#fef2f2;color:#dc2626}.risk-score.critical{background:#7f1d1d;color:#fff}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-fast)}.modal{background:var(--bg-primary);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp var(--transition-base)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--border-color)}.modal-title{font-size:var(--font-size-lg);font-weight:600}.modal-body{padding:var(--space-5)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-5);border-top:1px solid var(--border-color)}.upload-zone{border:2px dashed var(--border-color);border-radius:var(--radius-xl);padding:var(--space-10);text-align:center;cursor:pointer;transition:all var(--transition-fast)}.upload-zone:hover{border-color:var(--color-primary-500);background:var(--color-primary-50)}.upload-zone.drag-over{border-color:var(--color-primary-500);background:var(--color-primary-100)}.upload-icon{width:48px;height:48px;margin:0 auto var(--space-4);color:var(--color-primary-500)}.upload-title{font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.upload-description{font-size:var(--font-size-sm);color:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--color-primary-500);border-radius:50%;animation:spin .8s linear infinite}@media(max-width:1024px){.sidebar{transform:translate(-100%);transition:transform var(--transition-base)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.mt-4{margin-top:var(--space-4)}.mb-4{margin-bottom:var(--space-4)}.text-center{text-align:center}.text-sm{font-size:var(--font-size-sm)}.font-medium{font-weight:500}.font-semibold{font-weight:600}
