:root{--bg-color:#f3f4f6;--bg-surface:#fff;--text-primary:#111827;--text-secondary:#4b5563;--border-color:#e5e7eb;--accent-primary:#2563eb;--accent-hover:#1d4ed8;--accent-light:#eff6ff;--success:#10b981;--error:#ef4444;--warning:#f59e0b;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--radius-md:8px;--radius-lg:12px;--radius-xl:16px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5}.app-container{flex-direction:column;min-height:100vh;display:flex}.app-header{background-color:var(--bg-surface);border-bottom:1px solid var(--border-color);z-index:10;box-shadow:var(--shadow-sm);align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.header-logo{color:var(--accent-primary);align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;display:flex}.app-main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:2rem}.hero-section{text-align:center;margin-bottom:3rem}.hero-section h1{color:var(--text-primary);letter-spacing:-.025em;margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:1.125rem}.search-wrapper{max-width:600px;margin:0 auto;position:relative}.search-icon{color:var(--text-secondary);position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.search-input{border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-surface);width:100%;color:var(--text-primary);box-shadow:var(--shadow-sm);padding:1rem 1rem 1rem 3rem;font-family:inherit;font-size:1.125rem;transition:all .2s}.search-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-light);outline:none}.section-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:1.5rem;font-weight:600;display:flex}.specializations-section{margin-bottom:3rem}.spec-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem;display:grid}.spec-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-sm);padding:1.5rem;transition:all .2s}.spec-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent-primary);transform:translateY(-2px)}.spec-card.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.spec-card.active p{color:#fffc}.spec-card h3{margin-bottom:.25rem;font-size:1.125rem;font-weight:600}.spec-card p{color:var(--text-secondary);font-size:.875rem}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.project-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:.75rem;padding:1rem 1.25rem;transition:all .2s;display:flex}.project-card:hover{background:var(--accent-light);border-color:var(--accent-primary)}.project-icon{color:var(--text-secondary);font-size:1.25rem}.project-name{word-break:break-all;font-size:1rem;font-weight:500}.folder-card{border-left:4px solid var(--accent-primary)}.btn-primary{background-color:var(--accent-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;padding:.75rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:500;transition:background-color .2s}.btn-primary:hover{background-color:var(--accent-hover)}.btn-text{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;margin-bottom:1.5rem;padding:.5rem 0;font-size:1rem;font-weight:500;display:inline-flex}.btn-text:hover{color:var(--text-primary)}.btn-icon{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.25rem}.btn-icon:hover{color:var(--text-primary)}.audit-header{border-bottom:1px solid var(--border-color);align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.audit-header h2{font-size:1.5rem;font-weight:600}.badge{background:var(--accent-light);color:var(--accent-primary);border-radius:9999px;padding:.25rem .75rem;font-size:.875rem;font-weight:500}.markdown-content{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);max-height:60vh;margin-bottom:2rem;padding:2rem;line-height:1.6;overflow-y:auto}.markdown-content h1,.markdown-content h2,.markdown-content h3{color:var(--text-primary);margin-top:1.5rem;margin-bottom:1rem}.markdown-content p,.markdown-content ul,.markdown-content ol{color:var(--text-secondary);margin-bottom:1rem}.markdown-content pre,.markdown-content code{background:var(--bg-color);border-radius:4px;padding:.2rem .4rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.9em}.markdown-content pre{padding:1rem;overflow-x:auto}.action-bar{border-top:1px solid var(--border-color);justify-content:flex-end;padding:1.5rem 0;display:flex}.questions-list{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);flex-direction:column;margin-bottom:2rem;padding:2rem;display:flex}.audit-row-container{border-bottom:1px solid var(--border-color);padding:1.5rem 0}.audit-row-container:last-child{border-bottom:none}.audit-row{justify-content:space-between;align-items:flex-end;gap:2rem;display:flex}.audit-content{flex:1}.audit-context{color:var(--text-secondary);margin-bottom:.5rem;font-size:.95rem}.audit-context h4{color:var(--text-primary);margin-top:1rem;margin-bottom:1.5rem;font-size:1.5rem;font-weight:500}.audit-context h5{color:var(--text-primary);margin-top:1rem;margin-bottom:.5rem;font-size:1rem;font-weight:500}.audit-context pre,.audit-context code{background:var(--bg-color);color:var(--accent-primary);border-radius:4px;padding:.2rem .4rem;font-family:ui-monospace,SFMono-Regular,Consolas,monospace}.audit-question-text{color:var(--text-primary);font-size:1.125rem;font-weight:500}.audit-actions{align-items:center;gap:1.5rem;display:flex}.radio-label{color:var(--text-secondary);cursor:pointer;text-transform:uppercase;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;display:flex}.radio-label input[type=radio]{appearance:none;border:2px solid var(--text-secondary);cursor:pointer;background:0 0;border-radius:50%;outline:none;width:18px;height:18px;transition:all .2s;position:relative}.radio-label input[type=radio]:checked{border-color:var(--accent-primary)}.radio-label input[type=radio]:checked:after{content:"";background:var(--accent-primary);border-radius:50%;width:8px;height:8px;position:absolute;top:3px;left:3px}.reason-input{border:1px solid var(--border-color);border-radius:var(--radius-md);resize:vertical;background:var(--bg-surface);width:100%;min-height:80px;color:var(--text-primary);padding:.75rem;font-family:inherit;font-size:.9375rem;transition:border-color .2s}.reason-input:focus{border-color:var(--accent-primary);outline:none}.modal{z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-surface);border-radius:var(--radius-xl);width:100%;max-width:800px;max-height:90vh;box-shadow:var(--shadow-lg);flex-direction:column;display:flex}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h2{font-size:1.25rem;font-weight:600}.modal-body{flex:1;padding:1.5rem;overflow-y:auto}.modal-body pre{background:var(--bg-color);border-radius:var(--radius-md);white-space:pre-wrap;color:var(--text-primary);border:1px solid var(--border-color);padding:1.5rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.875rem}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;padding:1.5rem;display:flex}@media (width<=768px){.app-main{padding:1rem}.spec-grid,.projects-grid{grid-template-columns:1fr}.answer-options{flex-direction:column;gap:.5rem}}
