@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f5f5f5;--bg-elevated: #ffffff;--bg-hover: #f0f0f0;--color-primary: #1e40af;--color-primary-hover: #1e3a8a;--color-primary-light: #2563eb;--color-primary-dark: #1e3a8a;--color-accent: #3b82f6;--color-accent-hover: #2563eb;--color-success: #10b981;--color-success-light: #059669;--color-warning: #f59e0b;--color-warning-light: #d97706;--color-error: #ef4444;--color-error-light: #dc2626;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #64748b;--text-muted: #94a3b8;--border-subtle: #e2e8f0;--border-default: #cbd5e1;--border-strong: #94a3b8;--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);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 9999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--font-mono: "SF Mono", "Monaco", "Cascadia Code", "Courier New", monospace;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 36px;--text-5xl: 48px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;color:var(--text-primary);margin-bottom:var(--space-4)}h1{font-size:var(--text-4xl);font-weight:700;letter-spacing:-.025em}h2{font-size:var(--text-3xl);letter-spacing:-.02em}h3{font-size:var(--text-2xl);letter-spacing:-.015em}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{color:var(--text-secondary);margin-bottom:var(--space-4);line-height:1.7}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-light)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}::selection{background-color:#dbeafe;color:var(--text-primary)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fadeIn{animation:fadeIn var(--transition-base) ease-out}.animate-slideIn{animation:slideIn var(--transition-base) ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}*:focus{outline:none}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}.transition{transition:all var(--transition-base)}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);color:var(--text-secondary);font-size:var(--text-lg)}.loading-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-6)}.loading-spinner{position:relative;width:80px;height:80px}.spinner-ring{position:absolute;width:100%;height:100%;border:3px solid transparent;border-radius:50%;animation:spin 2s cubic-bezier(.5,0,.5,1) infinite}.spinner-ring:nth-child(1){border-top-color:var(--color-primary);animation-delay:-.45s}.spinner-ring:nth-child(2){border-top-color:var(--color-accent);animation-delay:-.3s}.spinner-ring:nth-child(3){border-top-color:#6366f14d;animation-delay:-.15s}.loading-text{font-size:var(--text-base);font-weight:500;color:var(--text-secondary);letter-spacing:.05em}.customizations-modal.modal-content{max-width:none!important;width:calc(100vw - 3rem)!important;max-height:none!important;height:calc(100vh - 3rem)!important;display:flex;flex-direction:column;margin:1.5rem}.customizations-modal .modal-header-actions{display:flex;gap:.5rem;align-items:center}.customizations-content{display:flex;flex:1;overflow:hidden;gap:1rem}.customizations-sidebar{width:280px;display:flex;flex-direction:column;gap:1rem;border-right:1px solid var(--border-color);padding-right:1rem;overflow:hidden}.search-box svg{color:var(--text-secondary)}.entity-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.entity-list-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0 .5rem .5rem;margin-top:.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.05em}.entity-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;margin-left:.5rem;border-radius:8px;background:transparent;cursor:pointer;transition:all .2s;color:var(--text-primary);position:relative;border-left:3px solid transparent}.entity-item:hover{background:var(--bg-hover)}.entity-item.active{background:var(--bg-hover);border-left-color:var(--primary-color)}.entity-item .entity-icon{flex-shrink:0;color:var(--text-secondary)}.entity-item.active .entity-icon{color:var(--primary-color)}.entity-item-info{flex:1;min-width:0}.entity-item-name{font-weight:500;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.entity-item-meta{font-size:.75rem;color:var(--text-secondary);margin-top:.125rem}.entity-chevron{flex-shrink:0;color:var(--text-tertiary)}.customizations-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.entity-header{padding-top:.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color);margin-bottom:1rem}.entity-header-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.entity-header-title h4{font-size:1.5rem;font-weight:700;margin:0}.entity-header-badges{display:flex;gap:.5rem}.entity-logical-name{font-family:Courier New,monospace;font-size:.875rem;color:var(--text-secondary);margin:.25rem 0}.entity-description{font-size:.875rem;color:var(--text-secondary);margin:.5rem 0 0;line-height:1.5}.entity-tabs{display:flex;gap:.5rem;border-bottom:1px solid var(--border-color);margin-bottom:1rem;overflow-x:auto}.entity-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:none;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}.entity-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.entity-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.entity-content{flex:1;overflow-y:auto;padding-right:.5rem}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table thead{position:sticky;top:0;background:var(--bg-primary);z-index:1}.data-table th{text-align:left;padding:.75rem 1rem;font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-color);white-space:nowrap}.data-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);vertical-align:top}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table code{font-family:Courier New,monospace;font-size:.8125rem;color:var(--primary-color);background:var(--bg-secondary);padding:.125rem .375rem;border-radius:4px}.data-table .text-success{color:#10b981}.data-table .text-muted{color:var(--text-tertiary)}.data-table .ml-1{margin-left:.25rem}.items-list{display:flex;flex-direction:column;gap:.75rem}.item-card{padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color);transition:all .2s}.item-card:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #0000001a}.item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.item-header h5{font-size:1rem;font-weight:600;margin:0}.item-badges{display:flex;gap:.5rem}.item-meta{font-size:.8125rem;color:var(--text-secondary);margin:.25rem 0 0}.item-meta.text-xs{font-size:.75rem}.config-tab{padding:.5rem 0}.config-sections{display:flex;flex-direction:column;gap:2rem}.config-section{background:var(--bg-secondary);padding:1.5rem;border-radius:8px;border:1px solid var(--border-color)}.config-section h5{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary)}.config-table{width:100%;border-collapse:collapse;font-size:.875rem}.config-table tr{border-bottom:1px solid var(--border-color)}.config-table tr:last-child{border-bottom:none}.config-table td{padding:.75rem 0}.config-table td:first-child{font-weight:500;color:var(--text-secondary);width:40%}.config-table td:last-child{color:var(--text-primary);font-weight:500}.config-table code{font-family:Courier New,monospace;font-size:.8125rem;color:var(--primary-color);background:var(--bg-primary);padding:.125rem .375rem;border-radius:4px}.empty-state-large p{margin:0;font-size:.875rem}.entity-list::-webkit-scrollbar,.entity-content::-webkit-scrollbar,.entity-tabs::-webkit-scrollbar{width:10px;height:10px}.entity-list::-webkit-scrollbar-track,.entity-content::-webkit-scrollbar-track,.entity-tabs::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.entity-list::-webkit-scrollbar-thumb,.entity-content::-webkit-scrollbar-thumb,.entity-tabs::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px;border:2px solid #f1f5f9}.entity-list::-webkit-scrollbar-thumb:hover,.entity-content::-webkit-scrollbar-thumb:hover,.entity-tabs::-webkit-scrollbar-thumb:hover{background:#94a3b8}.security-roles-modal.modal-content{max-width:none!important;width:calc(100vw - 3rem)!important;max-height:none!important;height:calc(100vh - 3rem)!important;display:flex;flex-direction:column;margin:1.5rem}.security-roles-body{display:flex!important;flex-direction:row!important;gap:0;flex:1;overflow:hidden}.security-roles-sidebar{width:320px;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg-secondary)}.sidebar-search{padding:12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;background:var(--bg)}.sidebar-search input{flex:1;border:none;background:transparent;outline:none;font-size:14px;color:var(--text)}.sidebar-search input::placeholder{color:var(--text-secondary)}.roles-list{flex:1;overflow-y:auto}.role-item{display:flex;align-items:center;gap:12px;padding:12px;cursor:pointer;border-bottom:1px solid var(--border);border-left:3px solid transparent;transition:all .2s ease}.role-item:hover{background:var(--bg-hover)}.role-item.active{background:var(--bg-hover);border-left-color:var(--primary-color)}.role-item-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}.role-item.active .role-item-icon{color:var(--primary-color)}.role-item-content{flex:1;min-width:0}.role-item-name{font-weight:500;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-item-meta{display:flex;align-items:center;gap:6px;margin-top:4px}.role-item-arrow{flex-shrink:0;color:var(--text-secondary);opacity:0;transition:opacity .2s ease}.role-item:hover .role-item-arrow,.role-item.active .role-item-arrow{opacity:1}.security-roles-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.role-details-header{padding:20px 24px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.role-details-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.role-details-title h4{font-size:20px;font-weight:600;color:var(--text);margin:0}.role-badges{display:flex;gap:8px}.role-description{color:var(--text-secondary);font-size:14px;margin:8px 0 0}.privileges-search{padding:16px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;background:var(--bg)}.privileges-search input{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;color:var(--text);background:var(--bg-secondary);outline:none;transition:border-color .2s ease}.privileges-search input:focus{border-color:var(--primary)}.privileges-search input::placeholder{color:var(--text-secondary)}.privileges-table-container{flex:1;overflow:auto;padding:16px 24px}.privileges-table{width:100%;border-collapse:collapse;font-size:13px}.privileges-table thead{position:sticky;top:0;background:var(--bg);z-index:10}.privileges-table thead:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--border)}.privileges-table th{padding:12px 8px;text-align:left;font-weight:600;color:var(--text);border-bottom:2px solid var(--border);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.privileges-table th:first-child{padding-left:0}.privileges-table td{padding:12px 8px;border-bottom:1px solid var(--border);vertical-align:middle}.privileges-table td:first-child{padding-left:0}.privileges-table tbody tr:hover{background:var(--bg-hover)}.privileges-table .entity-name{font-weight:500;color:var(--text);font-family:Consolas,Monaco,monospace;font-size:12px}.privileges-table .empty-cell{text-align:center;color:var(--text-secondary);padding:24px}.privileges-table .badge{display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.text-muted{color:var(--text-tertiary);font-size:16px;font-weight:300}.access-level-legend{padding:16px 24px;border-top:1px solid var(--border);background:var(--bg-secondary)}.access-level-legend h5{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin:0 0 12px}.legend-items{display:flex;gap:20px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.legend-item .badge{font-size:11px}.security-roles-content .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);gap:12px}.security-roles-content .empty-state p{font-size:14px;margin:0}.badge-info{background:#e0f2fe;color:#0369a1}.badge-warning{background:#fef3c7;color:#b45309}.badge-primary{background:#dbeafe;color:#1e40af}.badge-success{background:#d1fae5;color:#065f46}.badge-muted{background:var(--bg-secondary);color:var(--text-tertiary)}.roles-list::-webkit-scrollbar,.privileges-table-container::-webkit-scrollbar{width:10px;height:10px}.roles-list::-webkit-scrollbar-track,.privileges-table-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.roles-list::-webkit-scrollbar-thumb,.privileges-table-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px;border:2px solid #f1f5f9}.roles-list::-webkit-scrollbar-thumb:hover,.privileges-table-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width: 768px){.security-roles-modal.modal-content{width:100vw!important;height:100vh!important;margin:0}.security-roles-body{flex-direction:column}.security-roles-sidebar{width:100%;max-height:200px;border-right:none;border-bottom:1px solid var(--border)}.privileges-table-container{overflow-x:auto}.privileges-table{min-width:900px}}.global-option-sets-modal.modal-content{max-width:none!important;width:calc(100vw - 3rem)!important;max-height:none!important;height:calc(100vh - 3rem)!important;display:flex;flex-direction:column;margin:1.5rem}.global-option-sets-body{display:flex!important;flex-direction:row!important;gap:0;flex:1;overflow:hidden}.global-option-sets-sidebar{width:320px;border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;background:var(--bg-secondary)}.option-sets-list{flex:1;overflow-y:auto;padding:var(--space-2)}.option-set-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--space-1);border-left:3px solid transparent}.option-set-item:hover{background:var(--bg-hover)}.option-set-item.active{background:var(--bg-hover);border-left-color:var(--primary-color)}.option-set-item-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:#6366f11a;color:var(--color-primary);flex-shrink:0}.option-set-item-content{flex:1;min-width:0}.option-set-item-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.option-set-item-meta{margin-top:2px}.option-set-item-arrow{color:var(--text-muted);flex-shrink:0;transition:transform var(--transition-fast)}.option-set-item.active .option-set-item-arrow{transform:translate(4px)}.global-option-sets-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.option-set-details-header{padding:var(--space-6);border-bottom:1px solid var(--border-subtle);background:var(--bg)}.option-set-details-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.option-set-details-title h4{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0}.option-set-meta,.option-set-name{display:flex;align-items:center;gap:var(--space-2)}.option-set-name code{padding:var(--space-1) var(--space-2);background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text-secondary)}.options-list-container{flex:1;overflow-y:auto;padding:var(--space-4)}.options-table{width:100%;border-collapse:collapse}.options-table thead{position:sticky;top:0;background:var(--bg);z-index:10}.options-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-default);background:var(--bg)}.options-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm)}.options-table tbody tr:hover{background:var(--bg-hover)}.option-value code{padding:var(--space-1) var(--space-2);background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--color-primary);font-weight:600}.option-label{color:var(--text-primary);font-weight:500}.option-color{color:var(--text-secondary)}.color-preview{display:flex;align-items:center;gap:var(--space-2)}.color-swatch{width:24px;height:24px;border-radius:var(--radius-sm);border:1px solid var(--border-default);flex-shrink:0}.color-preview code{padding:var(--space-1) var(--space-2);background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);gap:var(--space-3)}.empty-state svg{color:var(--text-tertiary)}.empty-state p{margin:0;font-size:var(--text-sm)}.export-dropdown{position:relative;display:inline-block}.export-dropdown button{display:flex;align-items:center;gap:.5rem}.export-dropdown .chevron{transition:transform .2s ease}.export-dropdown .chevron.open{transform:rotate(180deg)}.export-dropdown-menu{position:absolute;top:calc(100% + .5rem);right:0;min-width:260px;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;z-index:1000;overflow:hidden;padding:.5rem 0}.export-dropdown-group-header{padding:.5rem 1rem;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;border-bottom:1px solid #e2e8f0;margin-top:.25rem}.export-dropdown-group-header:first-child{margin-top:0}.export-dropdown-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:#fff;border:none;cursor:pointer;text-align:left;transition:all .15s ease}.export-dropdown-item:hover{background-color:#f1f5f9}.export-dropdown-item:active{background-color:#e2e8f0;transform:scale(.98)}.export-dropdown-item:disabled{opacity:.5;cursor:not-allowed}.export-dropdown-item .item-icon{display:flex;align-items:center;color:#64748b}.export-dropdown-item .item-content{display:flex;flex-direction:column;gap:.125rem;flex:1}.export-dropdown-item .item-label{font-weight:500;color:#0f172a;font-size:.875rem;line-height:1.25}.export-dropdown-item .item-description{font-size:.75rem;color:#64748b;line-height:1.25}@media (prefers-color-scheme: dark){.export-dropdown-menu{background:#1e293b;border-color:#334155}.export-dropdown-group-header{background:#0f172a;border-color:#334155;color:#94a3b8}.export-dropdown-item{background:#1e293b}.export-dropdown-item:hover{background-color:#334155}.export-dropdown-item:active{background-color:#475569}.export-dropdown-item .item-label{color:#f1f5f9}.export-dropdown-item .item-description,.export-dropdown-item .item-icon{color:#94a3b8}}.connection-references-modal.modal-content{max-width:none!important;width:calc(100vw - 3rem)!important;max-height:none!important;height:calc(100vh - 3rem)!important;display:flex;flex-direction:column;margin:1.5rem}.connection-references-body{display:flex!important;flex-direction:column!important;gap:0;flex:1;overflow:hidden}.connection-refs-search{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-subtle);background:var(--bg)}.connection-refs-search svg{color:var(--text-muted);flex-shrink:0}.connection-refs-search input{flex:1;border:none;background:transparent;font-size:var(--text-sm);color:var(--text-primary);outline:none}.connection-refs-search input::placeholder{color:var(--text-muted)}.connection-refs-table-container{flex:1;overflow-y:auto;padding:var(--space-4)}.connection-refs-table{width:100%;border-collapse:collapse}.connection-refs-table thead{position:sticky;top:0;background:var(--bg);z-index:10}.connection-refs-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-default);background:var(--bg)}.connection-refs-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm)}.connection-refs-table tbody tr:hover{background:var(--bg-hover)}.conn-ref-name{color:var(--text-primary);font-weight:600}.conn-ref-logical-name code{padding:var(--space-1) var(--space-2);background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--text-secondary)}.conn-ref-connector{color:var(--text-primary)}.conn-ref-customizable,.conn-ref-state{text-align:center}.empty-cell{text-align:center;color:var(--text-muted);padding:var(--space-8)!important}.badge-xs{display:inline-flex;align-items:center;gap:4px;font-size:10px;padding:2px 6px;line-height:1}.upload-screen{min-height:100vh;padding:var(--space-8)}.upload-screen:has(.file-selection-container){padding:0;height:100vh;overflow:hidden}.upload-screen:has(.file-selection-container) .screen-header{display:none}.upload-zone:hover{border-color:var(--color-primary);background:var(--bg-elevated)}.upload-zone:hover:before{opacity:1}.upload-zone.dragging{border-color:var(--color-primary);background:var(--bg-elevated);transform:scale(1.01)}.upload-zone.dragging:before{opacity:1}.progress-card{max-width:600px;margin:0 auto}.progress-content{text-align:center;padding:var(--space-8)}.progress-content svg{color:var(--color-primary);margin-bottom:var(--space-6)}.progress-content h3{margin-bottom:var(--space-2)}.progress-content p{color:var(--text-secondary);margin-bottom:var(--space-6)}.progress-content progress{margin-bottom:var(--space-3)}.file-selection-container{background:var(--bg-secondary);height:100vh;display:flex;flex-direction:column;overflow:hidden}.solution-top-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);padding:var(--space-5) var(--space-8);background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle);flex-shrink:0;z-index:20;box-shadow:0 1px 3px #0000000d}.dark .solution-top-bar{background:#111827}.solution-top-bar-left{display:flex;align-items:center;gap:var(--space-4);flex:1;min-width:0}.solution-top-bar-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;flex-shrink:0}.solution-top-bar-icon svg{width:20px;height:20px}.solution-top-bar-info{flex:1;min-width:0}.solution-title-row{display:flex;align-items:center;gap:var(--space-2)}.solution-top-bar-info h2{font-size:var(--text-xl);font-weight:700;margin:0;color:var(--text-primary);letter-spacing:-.01em;line-height:1.2}.info-button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.solution-top-bar-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.solution-top-bar-actions{display:flex;align-items:center;gap:var(--space-3)}.section-header{margin-top:48px!important;margin-bottom:20px!important;padding:0;width:100%}.section-header:first-child{margin-top:0!important}.section-header h3{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0!important}.section-header div h3{margin:0!important}.file-categories-wrapper{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-6) var(--space-8) var(--space-20) var(--space-8);background:var(--bg-secondary)}.file-categories-wrapper::-webkit-scrollbar{width:8px}.file-categories-wrapper::-webkit-scrollbar-track{background:transparent}.file-categories-wrapper::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:4px}.file-categories-wrapper::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.components-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-4);padding:0;margin-top:0;margin-bottom:0}.component-card{display:grid;grid-template-rows:auto 1fr auto;padding:var(--space-4);background:var(--bg-elevated);border:2px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);position:relative;min-height:110px}.component-card-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-muted);line-height:1}.component-card-meta .file-count{color:var(--text-secondary);font-weight:600;white-space:nowrap;line-height:1}.component-card-meta .selected-count{color:var(--color-primary);font-weight:600;white-space:nowrap;line-height:1}.component-card-meta .meta-divider{color:var(--text-muted)}.component-card-checkbox{display:flex;align-items:center;cursor:pointer;z-index:2;line-height:1}.component-card-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.component-card-special{border-color:var(--color-primary);background:linear-gradient(135deg,#6366f10d,#8b5cf60d)}.component-card-special:hover{background:linear-gradient(135deg,#6366f114,#8b5cf614);box-shadow:0 6px 16px #6366f133}.component-card-special .component-card-icon{background:linear-gradient(135deg,#6366f126,#8b5cf626)}.component-card-badge{display:flex;align-items:center;line-height:1}.status-icon.status-failed{color:var(--color-danger)}.status-icon.status-pending{color:var(--text-muted)}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out}.modal-content{background:var(--bg-elevated);border-radius:var(--radius-2xl);box-shadow:0 20px 60px #0000004d;max-width:700px;width:90%;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--border-subtle)}.modal-title{display:flex;align-items:center;gap:var(--space-4)}.modal-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff}.modal-title h3{margin:0;font-size:var(--text-xl);color:var(--text-primary)}.modal-title p{margin:var(--space-1) 0 0 0;font-size:var(--text-sm);color:var(--text-secondary)}.modal-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.modal-actions{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-subtle)}.modal-file-list{flex:1;overflow-y:auto;padding:var(--space-2) var(--space-6)}.modal-file-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--space-1)}.modal-file-item:hover{background:var(--bg-hover)}.modal-file-item.not-recommended{opacity:.6}.modal-file-item.not-recommended:hover{opacity:.8}.modal-file-item input[type=checkbox]{flex-shrink:0}.modal-file-item svg{color:var(--text-muted);flex-shrink:0}.modal-file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.modal-file-name-row{display:flex;align-items:center;gap:var(--space-2)}.modal-file-name{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge-xs{font-size:10px;padding:2px 6px;line-height:1}.badge-muted{background:var(--bg-secondary);color:var(--text-muted);border:1px solid var(--border-subtle)}.modal-file-path{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-file-size{font-size:var(--text-xs);color:var(--text-secondary);flex-shrink:0}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end}.category-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);-webkit-user-select:none;user-select:none}.category-card-header:hover{background:var(--bg-hover)}.category-title{display:flex;align-items:center;gap:var(--space-3);flex:1}.category-title-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:#6366f11a;color:var(--color-primary);transition:all var(--transition-fast)}.category-card:hover .category-title-icon{transform:scale(1.05);background:#6366f126}.category-title-text{display:flex;flex-direction:column;gap:2px}.category-title-text h3{font-size:var(--text-base);font-weight:600;margin:0;color:var(--text-primary)}.category-title-text span{font-size:var(--text-xs);color:var(--text-muted)}.category-select-all{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border-subtle);font-size:var(--text-xs);color:var(--text-secondary);transition:all var(--transition-fast)}.category-select-all:hover{background:var(--bg-hover);border-color:var(--border-default)}.category-select-all input[type=checkbox]{margin:0}.file-item-compact{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3);cursor:pointer;transition:all var(--transition-fast);border-radius:var(--radius-md);margin-bottom:var(--space-1);border:1px solid transparent}.file-item-compact:hover{background:var(--bg-hover);border-color:var(--border-subtle)}.file-item-compact:has(input:checked){background:#6366f10d}.file-item-compact-left{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.file-item-compact-left svg{color:var(--text-muted);flex-shrink:0}.file-info{flex:1;min-width:0}.file-name-compact{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.file-size-compact{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px;display:block}.file-item-compact input[type=checkbox]{flex-shrink:0}.floating-actions-bar{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-8);background:#fffffffa;border-top:1px solid var(--border-default);box-shadow:0 -2px 12px #00000014;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex-shrink:0;z-index:20}.dark .floating-actions-bar{background:#111827fa}.floating-actions-left,.floating-actions-right{display:flex;align-items:center;gap:var(--space-3)}.documentation-result{animation:fadeIn var(--transition-base) ease-out}.doc-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-subtle)}.doc-header-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xl);background:#10b9811a;color:var(--color-success);flex-shrink:0}.doc-header h2{margin-bottom:var(--space-2)}.doc-header p{margin:0;color:var(--text-secondary)}.doc-preview{margin-bottom:var(--space-6);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-subtle);background:var(--bg-tertiary)}.doc-preview-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);font-size:var(--text-sm);font-weight:500}.doc-preview pre{padding:var(--space-6);margin:0;max-height:500px;overflow-y:auto;font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.7;color:var(--text-secondary);white-space:pre-wrap;word-wrap:break-word}.hidden-mobile{display:inline}.show-mobile{display:none}.category-card{animation:slideUp .3s ease-out;animation-fill-mode:both}.category-card:nth-child(1){animation-delay:.05s}.category-card:nth-child(2){animation-delay:.1s}.category-card:nth-child(3){animation-delay:.15s}.category-card:nth-child(4){animation-delay:.2s}.category-card:nth-child(5){animation-delay:.25s}.category-card:nth-child(6){animation-delay:.3s}@media (max-width: 1024px){.solution-top-bar{padding:var(--space-4) var(--space-6)}.components-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width: 768px){.upload-screen{padding:var(--space-4)}.upload-zone{padding:var(--space-10)}.upload-screen:has(.file-selection-container){padding:0;height:calc(100vh - 57px)}.file-selection-container{height:calc(100vh - 57px)}.solution-top-bar{flex-direction:column;align-items:stretch;padding:var(--space-4);gap:var(--space-3)}.solution-top-bar-left{width:100%}.solution-top-bar-icon{width:36px;height:36px}.solution-top-bar-icon svg{width:18px;height:18px}.solution-top-bar-info h2{font-size:var(--text-lg)}.solution-top-bar-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);width:100%}.solution-top-bar-actions button{width:100%;justify-content:center;font-size:var(--text-xs);padding:var(--space-3) var(--space-4)}.file-categories-wrapper{padding:var(--space-4);padding-bottom:calc(var(--space-20) + var(--space-8))}.components-grid{grid-template-columns:1fr;gap:var(--space-3)}.component-card{padding:var(--space-4);gap:var(--space-3);min-height:100px}.component-card-icon{width:36px;height:36px}.component-card-main{gap:var(--space-2)}.component-card-main h4{font-size:var(--text-sm)}.floating-actions-bar{flex-direction:column;padding:var(--space-4);gap:var(--space-3)}.floating-actions-left{width:100%;justify-content:space-between}.floating-actions-right,.floating-actions-right button{width:100%}.hidden-mobile{display:none!important}.show-mobile{display:inline!important}.modal-content{width:95%;max-height:90vh;margin:var(--space-4)}.modal-header,.modal-footer{padding:var(--space-4)}.modal-file-list{padding:var(--space-2) var(--space-4)}}@media (max-width: 480px){.solution-top-bar-actions{grid-template-columns:1fr}.component-card-main h4{font-size:var(--text-sm)}.component-card-meta{font-size:10px}}.toggle-container{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-elevated);transition:all var(--transition-fast)}.toggle-switch{position:relative;width:36px;height:20px;background:var(--border-default);border-radius:10px;transition:all var(--transition-base)}.toggle-switch:before{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:all var(--transition-base);box-shadow:0 1px 3px #0003}@media (prefers-color-scheme: dark){.wmde-markdown,.wmde-markdown-var{color-scheme:dark;--color-prettylights-syntax-comment: #8b949e;--color-prettylights-syntax-constant: #79c0ff;--color-prettylights-syntax-entity: #d2a8ff;--color-prettylights-syntax-storage-modifier-import: #c9d1d9;--color-prettylights-syntax-entity-tag: #7ee787;--color-prettylights-syntax-keyword: #ff7b72;--color-prettylights-syntax-string: #a5d6ff;--color-prettylights-syntax-variable: #ffa657;--color-prettylights-syntax-brackethighlighter-unmatched: #f85149;--color-prettylights-syntax-invalid-illegal-text: #f0f6fc;--color-prettylights-syntax-invalid-illegal-bg: #8e1519;--color-prettylights-syntax-carriage-return-text: #f0f6fc;--color-prettylights-syntax-carriage-return-bg: #b62324;--color-prettylights-syntax-string-regexp: #7ee787;--color-prettylights-syntax-markup-list: #f2cc60;--color-prettylights-syntax-markup-heading: #1f6feb;--color-prettylights-syntax-markup-italic: #c9d1d9;--color-prettylights-syntax-markup-bold: #c9d1d9;--color-prettylights-syntax-markup-deleted-text: #ffdcd7;--color-prettylights-syntax-markup-deleted-bg: #67060c;--color-prettylights-syntax-markup-inserted-text: #aff5b4;--color-prettylights-syntax-markup-inserted-bg: #033a16;--color-prettylights-syntax-markup-changed-text: #ffdfb6;--color-prettylights-syntax-markup-changed-bg: #5a1e02;--color-prettylights-syntax-markup-ignored-text: #c9d1d9;--color-prettylights-syntax-markup-ignored-bg: #1158c7;--color-prettylights-syntax-meta-diff-range: #d2a8ff;--color-prettylights-syntax-brackethighlighter-angle: #8b949e;--color-prettylights-syntax-sublimelinter-gutter-mark: #484f58;--color-prettylights-syntax-constant-other-reference-link: #a5d6ff;--color-fg-default: #c9d1d9;--color-fg-muted: #8b949e;--color-fg-subtle: #484f58;--color-canvas-default: #0d1117;--color-canvas-subtle: #161b22;--color-border-default: #30363d;--color-border-muted: #21262d;--color-neutral-muted: rgba(110, 118, 129, .4);--color-accent-fg: #58a6ff;--color-accent-emphasis: #1f6feb;--color-attention-subtle: rgba(187, 128, 9, .15);--color-danger-fg: #f85149;--color-danger-emphasis: #da3633;--color-attention-fg: #d29922;--color-attention-emphasis: #9e6a03;--color-done-fg: #a371f7;--color-done-emphasis: #8957e5;--color-success-fg: #3fb950;--color-success-emphasis: #238636;--color-copied-active-bg: #2e9b33}}@media (prefers-color-scheme: light){.wmde-markdown,.wmde-markdown-var{color-scheme:light;--color-prettylights-syntax-comment: #6e7781;--color-prettylights-syntax-constant: #0550ae;--color-prettylights-syntax-entity: #8250df;--color-prettylights-syntax-storage-modifier-import: #24292f;--color-prettylights-syntax-entity-tag: #116329;--color-prettylights-syntax-keyword: #cf222e;--color-prettylights-syntax-string: #0a3069;--color-prettylights-syntax-variable: #953800;--color-prettylights-syntax-brackethighlighter-unmatched: #82071e;--color-prettylights-syntax-invalid-illegal-text: #f6f8fa;--color-prettylights-syntax-invalid-illegal-bg: #82071e;--color-prettylights-syntax-carriage-return-text: #f6f8fa;--color-prettylights-syntax-carriage-return-bg: #cf222e;--color-prettylights-syntax-string-regexp: #116329;--color-prettylights-syntax-markup-list: #3b2300;--color-prettylights-syntax-markup-heading: #0550ae;--color-prettylights-syntax-markup-italic: #24292f;--color-prettylights-syntax-markup-bold: #24292f;--color-prettylights-syntax-markup-deleted-text: #82071e;--color-prettylights-syntax-markup-deleted-bg: #ffebe9;--color-prettylights-syntax-markup-inserted-text: #116329;--color-prettylights-syntax-markup-inserted-bg: #dafbe1;--color-prettylights-syntax-markup-changed-text: #953800;--color-prettylights-syntax-markup-changed-bg: #ffd8b5;--color-prettylights-syntax-markup-ignored-text: #eaeef2;--color-prettylights-syntax-markup-ignored-bg: #0550ae;--color-prettylights-syntax-meta-diff-range: #8250df;--color-prettylights-syntax-brackethighlighter-angle: #57606a;--color-prettylights-syntax-sublimelinter-gutter-mark: #8c959f;--color-prettylights-syntax-constant-other-reference-link: #0a3069;--color-fg-default: #24292f;--color-fg-muted: #57606a;--color-fg-subtle: #6e7781;--color-canvas-default: #ffffff;--color-canvas-subtle: #f6f8fa;--color-border-default: #d0d7de;--color-border-muted: hsl(210, 18%, 87%);--color-neutral-muted: rgba(175, 184, 193, .2);--color-accent-fg: #0969da;--color-accent-emphasis: #0969da;--color-attention-subtle: #fff8c5;--color-danger-fg: #d1242f;--color-danger-emphasis: #cf222e;--color-attention-fg: #9a6700;--color-attention-emphasis: #9a6700;--color-done-fg: #8250df;--color-done-emphasis: #8250df;--color-success-fg: #1a7f37;--color-success-emphasis: #1f883d;--color-copied-active-bg: #2e9b33}}[data-color-mode*=dark] .wmde-markdown,[data-color-mode*=dark] .wmde-markdown-var,.wmde-markdown-var[data-color-mode*=dark],.wmde-markdown[data-color-mode*=dark],body[data-color-mode*=dark]{color-scheme:dark;--color-prettylights-syntax-comment: #8b949e;--color-prettylights-syntax-constant: #79c0ff;--color-prettylights-syntax-entity: #d2a8ff;--color-prettylights-syntax-storage-modifier-import: #c9d1d9;--color-prettylights-syntax-entity-tag: #7ee787;--color-prettylights-syntax-keyword: #ff7b72;--color-prettylights-syntax-string: #a5d6ff;--color-prettylights-syntax-variable: #ffa657;--color-prettylights-syntax-brackethighlighter-unmatched: #f85149;--color-prettylights-syntax-invalid-illegal-text: #f0f6fc;--color-prettylights-syntax-invalid-illegal-bg: #8e1519;--color-prettylights-syntax-carriage-return-text: #f0f6fc;--color-prettylights-syntax-carriage-return-bg: #b62324;--color-prettylights-syntax-string-regexp: #7ee787;--color-prettylights-syntax-markup-list: #f2cc60;--color-prettylights-syntax-markup-heading: #1f6feb;--color-prettylights-syntax-markup-italic: #c9d1d9;--color-prettylights-syntax-markup-bold: #c9d1d9;--color-prettylights-syntax-markup-deleted-text: #ffdcd7;--color-prettylights-syntax-markup-deleted-bg: #67060c;--color-prettylights-syntax-markup-inserted-text: #aff5b4;--color-prettylights-syntax-markup-inserted-bg: #033a16;--color-prettylights-syntax-markup-changed-text: #ffdfb6;--color-prettylights-syntax-markup-changed-bg: #5a1e02;--color-prettylights-syntax-markup-ignored-text: #c9d1d9;--color-prettylights-syntax-markup-ignored-bg: #1158c7;--color-prettylights-syntax-meta-diff-range: #d2a8ff;--color-prettylights-syntax-brackethighlighter-angle: #8b949e;--color-prettylights-syntax-sublimelinter-gutter-mark: #484f58;--color-prettylights-syntax-constant-other-reference-link: #a5d6ff;--color-fg-default: #c9d1d9;--color-fg-muted: #8b949e;--color-fg-subtle: #484f58;--color-canvas-default: #0d1117;--color-canvas-subtle: #161b22;--color-border-default: #30363d;--color-border-muted: #21262d;--color-neutral-muted: rgba(110, 118, 129, .4);--color-accent-fg: #58a6ff;--color-accent-emphasis: #1f6feb;--color-attention-subtle: rgba(187, 128, 9, .15);--color-danger-fg: #f85149}[data-color-mode*=light] .wmde-markdown,[data-color-mode*=light] .wmde-markdown-var,.wmde-markdown-var[data-color-mode*=light],.wmde-markdown[data-color-mode*=light],body[data-color-mode*=light]{color-scheme:light;--color-prettylights-syntax-comment: #6e7781;--color-prettylights-syntax-constant: #0550ae;--color-prettylights-syntax-entity: #8250df;--color-prettylights-syntax-storage-modifier-import: #24292f;--color-prettylights-syntax-entity-tag: #116329;--color-prettylights-syntax-keyword: #cf222e;--color-prettylights-syntax-string: #0a3069;--color-prettylights-syntax-variable: #953800;--color-prettylights-syntax-brackethighlighter-unmatched: #82071e;--color-prettylights-syntax-invalid-illegal-text: #f6f8fa;--color-prettylights-syntax-invalid-illegal-bg: #82071e;--color-prettylights-syntax-carriage-return-text: #f6f8fa;--color-prettylights-syntax-carriage-return-bg: #cf222e;--color-prettylights-syntax-string-regexp: #116329;--color-prettylights-syntax-markup-list: #3b2300;--color-prettylights-syntax-markup-heading: #0550ae;--color-prettylights-syntax-markup-italic: #24292f;--color-prettylights-syntax-markup-bold: #24292f;--color-prettylights-syntax-markup-deleted-text: #82071e;--color-prettylights-syntax-markup-deleted-bg: #ffebe9;--color-prettylights-syntax-markup-inserted-text: #116329;--color-prettylights-syntax-markup-inserted-bg: #dafbe1;--color-prettylights-syntax-markup-changed-text: #953800;--color-prettylights-syntax-markup-changed-bg: #ffd8b5;--color-prettylights-syntax-markup-ignored-text: #eaeef2;--color-prettylights-syntax-markup-ignored-bg: #0550ae;--color-prettylights-syntax-meta-diff-range: #8250df;--color-prettylights-syntax-brackethighlighter-angle: #57606a;--color-prettylights-syntax-sublimelinter-gutter-mark: #8c959f;--color-prettylights-syntax-constant-other-reference-link: #0a3069;--color-fg-default: #24292f;--color-fg-muted: #57606a;--color-fg-subtle: #6e7781;--color-canvas-default: #ffffff;--color-canvas-subtle: #f6f8fa;--color-border-default: #d0d7de;--color-border-muted: hsl(210, 18%, 87%);--color-neutral-muted: rgba(175, 184, 193, .2);--color-accent-fg: #0969da;--color-accent-emphasis: #0969da;--color-attention-subtle: #fff8c5;--color-danger-fg: #cf222e}.wmde-markdown{-webkit-text-size-adjust:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";font-size:16px;line-height:1.5;word-wrap:break-word;color:var(--color-fg-default);background-color:var(--color-canvas-default)}.wmde-markdown details,.wmde-markdown figcaption,.wmde-markdown figure{display:block}.wmde-markdown summary{display:list-item}.wmde-markdown [hidden]{display:none!important}.wmde-markdown a{background-color:transparent;color:var(--color-accent-fg);text-decoration:none}.wmde-markdown a:active,.wmde-markdown a:hover{outline-width:0}.wmde-markdown abbr[title]{border-bottom:none;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.wmde-markdown b,.wmde-markdown strong{font-weight:600}.wmde-markdown dfn{font-style:italic}.wmde-markdown h1{margin:.67em 0;font-weight:600;padding-bottom:.3em;font-size:2em;border-bottom:1px solid var(--color-border-muted)}.wmde-markdown mark{background-color:var(--color-attention-subtle);color:var(--color-text-primary)}.wmde-markdown small{font-size:90%}.wmde-markdown sub,.wmde-markdown sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}.wmde-markdown sub{bottom:-.25em}.wmde-markdown sup{top:-.5em}.wmde-markdown img{display:inline-block;border-style:none;max-width:100%;box-sizing:content-box;background-color:var(--color-canvas-default)}.wmde-markdown code,.wmde-markdown kbd,.wmde-markdown pre,.wmde-markdown samp{font-family:monospace,monospace;font-size:1em}.wmde-markdown figure{margin:1em 40px}.wmde-markdown hr{box-sizing:content-box;overflow:hidden;background:transparent;border:0;border-bottom:1px solid var(--color-border-muted);height:.25em;padding:0;margin:24px 0;background-color:var(--color-border-default)}.wmde-markdown input{font:inherit;margin:0;overflow:visible;font-family:inherit;font-size:inherit;line-height:inherit}.wmde-markdown [type=button],.wmde-markdown [type=reset],.wmde-markdown [type=submit]{-webkit-appearance:button}.wmde-markdown [type=button]::-moz-focus-inner,.wmde-markdown [type=reset]::-moz-focus-inner,.wmde-markdown [type=submit]::-moz-focus-inner{border-style:none;padding:0}.wmde-markdown [type=button]:-moz-focusring,.wmde-markdown [type=reset]:-moz-focusring,.wmde-markdown [type=submit]:-moz-focusring{outline:1px dotted ButtonText}.wmde-markdown [type=checkbox],.wmde-markdown [type=radio]{box-sizing:border-box;padding:0}.wmde-markdown [type=number]::-webkit-inner-spin-button,.wmde-markdown [type=number]::-webkit-outer-spin-button{height:auto}.wmde-markdown [type=search]{-webkit-appearance:textfield;outline-offset:-2px}.wmde-markdown [type=search]::-webkit-search-cancel-button,.wmde-markdown [type=search]::-webkit-search-decoration{-webkit-appearance:none}.wmde-markdown ::-webkit-input-placeholder{color:inherit;opacity:.54}.wmde-markdown ::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}.wmde-markdown a:hover{text-decoration:underline}.wmde-markdown hr:before{display:table;content:""}.wmde-markdown hr:after{display:table;clear:both;content:""}.wmde-markdown table{border-spacing:0;border-collapse:collapse;display:block;width:max-content;max-width:100%}.wmde-markdown td,.wmde-markdown th{padding:0}.wmde-markdown details summary{cursor:pointer}.wmde-markdown details:not([open])>*:not(summary){display:none!important}.wmde-markdown kbd{display:inline-block;padding:3px 5px;font:11px ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;line-height:10px;color:var(--color-fg-default);vertical-align:middle;background-color:var(--color-canvas-subtle);border:solid 1px var(--color-neutral-muted);border-bottom-color:var(--color-neutral-muted);border-radius:6px;box-shadow:inset 0 -1px 0 var(--color-neutral-muted)}.wmde-markdown h1,.wmde-markdown h2,.wmde-markdown h3,.wmde-markdown h4,.wmde-markdown h5,.wmde-markdown h6{margin-top:24px;margin-bottom:16px;font-weight:600;line-height:1.25}.wmde-markdown h2{font-weight:600;padding-bottom:.3em;font-size:1.5em;border-bottom:1px solid var(--color-border-muted)}.wmde-markdown h3{font-weight:600;font-size:1.25em}.wmde-markdown h4{font-weight:600;font-size:1em}.wmde-markdown h5{font-weight:600;font-size:.875em}.wmde-markdown h6{font-weight:600;font-size:.85em;color:var(--color-fg-muted)}.wmde-markdown p{margin-top:0;margin-bottom:10px}.wmde-markdown blockquote{margin:0;padding:0 1em;color:var(--color-fg-muted);border-left:.25em solid var(--color-border-default)}.wmde-markdown ul,.wmde-markdown ol{margin-top:0;margin-bottom:0;padding-left:2em}.wmde-markdown ol ol,.wmde-markdown ul ol{list-style-type:lower-roman}.wmde-markdown ul ul ol,.wmde-markdown ul ol ol,.wmde-markdown ol ul ol,.wmde-markdown ol ol ol{list-style-type:lower-alpha}.wmde-markdown dd{margin-left:0}.wmde-markdown tt,.wmde-markdown code{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;font-size:12px}.wmde-markdown pre{margin-top:0;margin-bottom:0;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;font-size:12px;word-wrap:normal}.wmde-markdown .octicon{display:inline-block;overflow:visible!important;vertical-align:text-bottom;fill:currentColor}.wmde-markdown ::placeholder{color:var(--color-fg-subtle);opacity:1}.wmde-markdown input::-webkit-outer-spin-button,.wmde-markdown input::-webkit-inner-spin-button{margin:0;appearance:none}.wmde-markdown [data-catalyst]{display:block}.wmde-markdown:before{display:table;content:""}.wmde-markdown:after{display:table;clear:both;content:""}.wmde-markdown>*:first-child{margin-top:0!important}.wmde-markdown>*:last-child{margin-bottom:0!important}.wmde-markdown a:not([href]){color:inherit;text-decoration:none}.wmde-markdown .absent{color:var(--color-danger-fg)}.wmde-markdown a.anchor{float:left;padding-right:4px;margin-left:-20px;line-height:1}.wmde-markdown .anchor:focus{outline:none}.wmde-markdown p,.wmde-markdown blockquote,.wmde-markdown ul,.wmde-markdown ol,.wmde-markdown dl,.wmde-markdown table,.wmde-markdown pre,.wmde-markdown details{margin-top:0;margin-bottom:16px}.wmde-markdown blockquote>:first-child{margin-top:0}.wmde-markdown blockquote>:last-child{margin-bottom:0}.wmde-markdown sup>a:before{content:"["}.wmde-markdown sup>a:after{content:"]"}.wmde-markdown h1 .octicon-link,.wmde-markdown h2 .octicon-link,.wmde-markdown h3 .octicon-link,.wmde-markdown h4 .octicon-link,.wmde-markdown h5 .octicon-link,.wmde-markdown h6 .octicon-link{color:var(--color-fg-default);vertical-align:middle;visibility:hidden}.wmde-markdown h1:hover .anchor,.wmde-markdown h2:hover .anchor,.wmde-markdown h3:hover .anchor,.wmde-markdown h4:hover .anchor,.wmde-markdown h5:hover .anchor,.wmde-markdown h6:hover .anchor{text-decoration:none}.wmde-markdown h1:hover .anchor .octicon-link,.wmde-markdown h2:hover .anchor .octicon-link,.wmde-markdown h3:hover .anchor .octicon-link,.wmde-markdown h4:hover .anchor .octicon-link,.wmde-markdown h5:hover .anchor .octicon-link,.wmde-markdown h6:hover .anchor .octicon-link{visibility:visible}.wmde-markdown h1 tt,.wmde-markdown h1 code,.wmde-markdown h2 tt,.wmde-markdown h2 code,.wmde-markdown h3 tt,.wmde-markdown h3 code,.wmde-markdown h4 tt,.wmde-markdown h4 code,.wmde-markdown h5 tt,.wmde-markdown h5 code,.wmde-markdown h6 tt,.wmde-markdown h6 code{padding:0 .2em;font-size:inherit}.wmde-markdown ul.no-list,.wmde-markdown ol.no-list{padding:0;list-style-type:none}.wmde-markdown ol[type="1"]{list-style-type:decimal}.wmde-markdown ol[type=a]{list-style-type:lower-alpha}.wmde-markdown ol[type=i]{list-style-type:lower-roman}.wmde-markdown div>ol:not([type]){list-style-type:decimal}.wmde-markdown ul ul,.wmde-markdown ul ol,.wmde-markdown ol ol,.wmde-markdown ol ul{margin-top:0;margin-bottom:0}.wmde-markdown li>p{margin-top:16px}.wmde-markdown li+li{margin-top:.25em}.wmde-markdown dl{padding:0}.wmde-markdown dl dt{padding:0;margin-top:16px;font-size:1em;font-style:italic;font-weight:600}.wmde-markdown dl dd{padding:0 16px;margin-bottom:16px}.wmde-markdown table th{font-weight:600}.wmde-markdown table th,.wmde-markdown table td{padding:6px 13px;border:1px solid var(--color-border-default)}.wmde-markdown table tr{background-color:var(--color-canvas-default);border-top:1px solid var(--color-border-muted)}.wmde-markdown table tr:nth-child(2n){background-color:var(--color-canvas-subtle)}.wmde-markdown table img{background-color:transparent}.wmde-markdown img[align=right]{padding-left:20px}.wmde-markdown img[align=left]{padding-right:20px}.wmde-markdown .emoji{max-width:none;vertical-align:text-top;background-color:transparent}.wmde-markdown span.frame{display:block;overflow:hidden}.wmde-markdown span.frame>span{display:block;float:left;width:auto;padding:7px;margin:13px 0 0;overflow:hidden;border:1px solid var(--color-border-default)}.wmde-markdown span.frame span img{display:block;float:left}.wmde-markdown span.frame span span{display:block;padding:5px 0 0;clear:both;color:var(--color-fg-default)}.wmde-markdown span.align-center{display:block;overflow:hidden;clear:both}.wmde-markdown span.align-center>span{display:block;margin:13px auto 0;overflow:hidden;text-align:center}.wmde-markdown span.align-center span img{margin:0 auto;text-align:center}.wmde-markdown span.align-right{display:block;overflow:hidden;clear:both}.wmde-markdown span.align-right>span{display:block;margin:13px 0 0;overflow:hidden;text-align:right}.wmde-markdown span.align-right span img{margin:0;text-align:right}.wmde-markdown span.float-left{display:block;float:left;margin-right:13px;overflow:hidden}.wmde-markdown span.float-left span{margin:13px 0 0}.wmde-markdown span.float-right{display:block;float:right;margin-left:13px;overflow:hidden}.wmde-markdown span.float-right>span{display:block;margin:13px auto 0;overflow:hidden;text-align:right}.wmde-markdown code,.wmde-markdown tt{padding:.2em .4em;margin:0;font-size:85%;background-color:var(--color-neutral-muted);border-radius:6px}.wmde-markdown code br,.wmde-markdown tt br{display:none}.wmde-markdown del code{text-decoration:inherit}.wmde-markdown pre code{font-size:100%}.wmde-markdown pre>code{padding:0;margin:0;word-break:normal;white-space:pre;background:transparent;border:0}.wmde-markdown pre{font-size:85%;line-height:1.45;background-color:var(--color-canvas-subtle);border-radius:6px}.wmde-markdown pre code,.wmde-markdown pre tt{display:inline;max-width:auto;padding:0;margin:0;overflow:visible;line-height:inherit;word-wrap:normal;background-color:transparent;border:0}.wmde-markdown pre>code{padding:16px;overflow:auto;display:block}.wmde-markdown pre>code::-webkit-scrollbar{background:transparent;width:8px;height:8px}.wmde-markdown pre>code::-webkit-scrollbar-thumb{background:var(--color-fg-muted);border-radius:10px}.wmde-markdown .csv-data td,.wmde-markdown .csv-data th{padding:5px;overflow:hidden;font-size:12px;line-height:1;text-align:left;white-space:nowrap}.wmde-markdown .csv-data .blob-num{padding:10px 8px 9px;text-align:right;background:var(--color-canvas-default);border:0}.wmde-markdown .csv-data tr{border-top:0}.wmde-markdown .csv-data th{font-weight:600;background:var(--color-canvas-subtle);border-top:0}.wmde-markdown .footnotes{font-size:12px;color:var(--color-fg-muted);border-top:1px solid var(--color-border-default)}.wmde-markdown .footnotes ol{padding-left:16px}.wmde-markdown .footnotes li{position:relative}.wmde-markdown .footnotes li:target:before{position:absolute;inset:-8px -8px -8px -24px;pointer-events:none;content:"";border:2px solid var(--color-accent-emphasis);border-radius:6px}.wmde-markdown .footnotes li:target{color:var(--color-fg-default)}.wmde-markdown .footnotes .data-footnote-backref g-emoji{font-family:monospace}.wmde-markdown .task-list-item{list-style-type:none}.wmde-markdown .task-list-item label{font-weight:400}.wmde-markdown .task-list-item.enabled label{cursor:pointer}.wmde-markdown .task-list-item+.wmde-markdown .task-list-item{margin-top:3px}.wmde-markdown .task-list-item .handle{display:none}.wmde-markdown .task-list-item-checkbox,.wmde-markdown .contains-task-list input[type=checkbox]{margin:0 .2em .25em -1.6em;vertical-align:middle}.wmde-markdown .contains-task-list:dir(rtl) .task-list-item-checkbox,.wmde-markdown .contains-task-list:dir(rtl) input[type=checkbox]{margin:0 -1.6em .25em .2em}.wmde-markdown ::-webkit-calendar-picker-indicator{filter:invert(50%)}.wmde-markdown pre{position:relative}.wmde-markdown pre .copied{visibility:hidden;display:flex;position:absolute;cursor:pointer;color:var(--color-fg-default);top:6px;right:6px;border-radius:5px;background:var(--color-border-default);padding:6px;font-size:12px;transition:all .3s}.wmde-markdown pre .copied .octicon-copy{display:block}.wmde-markdown pre .copied .octicon-check{display:none}.wmde-markdown pre:hover .copied{visibility:visible}.wmde-markdown pre:hover .copied:hover{background:var(--color-prettylights-syntax-entity-tag);color:var(--color-canvas-default)}.wmde-markdown pre:hover .copied:active,.wmde-markdown pre .copied.active{background:var(--color-copied-active-bg);color:var(--color-canvas-default)}.wmde-markdown pre .active .octicon-copy{display:none}.wmde-markdown pre .active .octicon-check{display:block}.wmde-markdown .markdown-alert{padding:.5rem 1em;color:inherit;margin-bottom:16px;border-left:.25em solid var(--borderColor-default, var(--color-border-default))}.wmde-markdown .markdown-alert>:last-child{margin-bottom:0!important}.wmde-markdown .markdown-alert .markdown-alert-title{display:flex;align-items:center;line-height:1;font-weight:500;font-size:14px}.wmde-markdown .markdown-alert .markdown-alert-title svg.octicon{margin-right:var(--base-size-8, 8px)!important}.wmde-markdown .markdown-alert.markdown-alert-note{border-left-color:var(--borderColor-accent-emphasis, var(--color-accent-emphasis))}.wmde-markdown .markdown-alert.markdown-alert-note .markdown-alert-title{color:var(--fgColor-accent, var(--color-accent-fg))}.wmde-markdown .markdown-alert.markdown-alert-tip{border-left-color:var(--borderColor-success-emphasis, var(--color-success-emphasis))}.wmde-markdown .markdown-alert.markdown-alert-tip .markdown-alert-title{color:var(--fgColor-success, var(--color-success-fg))}.wmde-markdown .markdown-alert.markdown-alert-important{border-left-color:var(--borderColor-done-emphasis, var(--color-done-emphasis))}.wmde-markdown .markdown-alert.markdown-alert-important .markdown-alert-title{color:var(--fgColor-done, var(--color-done-fg))}.wmde-markdown .markdown-alert.markdown-alert-warning{border-left-color:var(--borderColor-attention-emphasis, var(--color-attention-emphasis))}.wmde-markdown .markdown-alert.markdown-alert-warning .markdown-alert-title{color:var(--fgColor-attention, var(--color-attention-fg))}.wmde-markdown .markdown-alert.markdown-alert-caution{border-left-color:var(--borderColor-danger-emphasis, var(--color-danger-emphasis))}.wmde-markdown .markdown-alert.markdown-alert-caution .markdown-alert-title{color:var(--fgColor-danger, var(--color-danger-fg))}.wmde-markdown .highlight-line{background-color:var(--color-neutral-muted)}.wmde-markdown .code-line.line-number:before{display:inline-block;width:1rem;text-align:right;margin-right:16px;color:var(--color-fg-subtle);content:attr(line);white-space:nowrap}.wmde-markdown .token.comment,.wmde-markdown .token.prolog,.wmde-markdown .token.doctype,.wmde-markdown .token.cdata{color:var(--color-prettylights-syntax-comment)}.wmde-markdown .token.namespace{opacity:.7}.wmde-markdown .token.property,.wmde-markdown .token.tag,.wmde-markdown .token.selector,.wmde-markdown .token.constant,.wmde-markdown .token.symbol,.wmde-markdown .token.deleted{color:var(--color-prettylights-syntax-entity-tag)}.wmde-markdown .token.maybe-class-name{color:var(--color-prettylights-syntax-variable)}.wmde-markdown .token.property-access,.wmde-markdown .token.operator,.wmde-markdown .token.boolean,.wmde-markdown .token.number,.wmde-markdown .token.selector .token.class,.wmde-markdown .token.attr-name,.wmde-markdown .token.string,.wmde-markdown .token.char,.wmde-markdown .token.builtin{color:var(--color-prettylights-syntax-constant)}.wmde-markdown .token.deleted{color:var(--color-prettylights-syntax-markup-deleted-text)}.wmde-markdown .code-line .token.deleted{background-color:var(--color-prettylights-syntax-markup-deleted-bg)}.wmde-markdown .token.inserted{color:var(--color-prettylights-syntax-markup-inserted-text)}.wmde-markdown .code-line .token.inserted{background-color:var(--color-prettylights-syntax-markup-inserted-bg)}.wmde-markdown .token.variable{color:var(--color-prettylights-syntax-constant)}.wmde-markdown .token.entity,.wmde-markdown .token.url,.wmde-markdown .language-css .token.string,.wmde-markdown .style .token.string,.wmde-markdown .token.color,.wmde-markdown .token.atrule,.wmde-markdown .token.attr-value,.wmde-markdown .token.function,.wmde-markdown .token.class-name{color:var(--color-prettylights-syntax-string)}.wmde-markdown .token.rule,.wmde-markdown .token.regex,.wmde-markdown .token.important,.wmde-markdown .token.keyword{color:var(--color-prettylights-syntax-keyword)}.wmde-markdown .token.coord{color:var(--color-prettylights-syntax-meta-diff-range)}.wmde-markdown .token.important,.wmde-markdown .token.bold{font-weight:700}.wmde-markdown .token.italic{font-style:italic}.wmde-markdown .token.entity{cursor:help}.markdown-renderer{max-width:100%;padding:1.5rem;overflow-x:auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.markdown-renderer .wmde-markdown{background:transparent!important;font-family:inherit!important;color:#1f2937!important}.markdown-renderer .wmde-markdown>*:first-child{margin-top:0!important}.markdown-renderer .wmde-markdown>*:last-child{margin-bottom:0!important}.markdown-renderer .wmde-markdown h1{font-size:2rem;font-weight:700;margin-top:0;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb;color:#111827}.markdown-renderer .wmde-markdown h2{font-size:1.5rem;font-weight:600;margin-top:2rem;margin-bottom:1rem;padding-bottom:.375rem;border-bottom:1px solid #e5e7eb;color:#1f2937}.markdown-renderer .wmde-markdown h3{font-size:1.25rem;font-weight:600;margin-top:1.5rem;margin-bottom:.75rem;color:#374151}.markdown-renderer .wmde-markdown h4{font-size:1.125rem;font-weight:600;margin-top:1.25rem;margin-bottom:.5rem;color:#4b5563}.markdown-renderer .wmde-markdown a{color:#3b82f6;text-decoration:none;font-weight:500;transition:color .2s}.markdown-renderer .wmde-markdown a:hover{color:#2563eb;text-decoration:underline}.markdown-renderer .wmde-markdown pre{background-color:#f9fafb!important;border:1px solid #e5e7eb!important;border-radius:.5rem!important;padding:1rem!important;margin:1rem 0!important;overflow-x:auto!important}.markdown-renderer .wmde-markdown code{font-family:Consolas,Monaco,Courier New,monospace!important;font-size:.875rem!important}.markdown-renderer .wmde-markdown :not(pre)>code{background-color:#f3f4f6!important;color:#dc2626!important;padding:.125rem .375rem!important;border-radius:.25rem!important;font-size:.875em!important;font-weight:500!important;border:none!important}.markdown-renderer .wmde-markdown table{border-radius:.5rem;border:1px solid #e5e7eb;overflow:hidden;font-size:.875rem;background-color:#fff}.markdown-renderer .wmde-markdown thead{background-color:#f9fafb}.markdown-renderer .wmde-markdown th{padding:.75rem 1rem;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.markdown-renderer .wmde-markdown td{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;color:#1f2937}.markdown-renderer .wmde-markdown tbody tr:hover{background-color:#f9fafb}.markdown-renderer .wmde-markdown tbody tr:last-child td{border-bottom:none}.markdown-renderer .wmde-markdown blockquote{margin:1rem 0!important;padding:.75rem 1rem!important;border-left:4px solid #3b82f6!important;background-color:#eff6ff!important;color:#1e40af!important;font-style:italic}.markdown-renderer .wmde-markdown ul,.markdown-renderer .wmde-markdown ol{padding-left:1.5rem;margin:1rem 0}.markdown-renderer .wmde-markdown li{margin-bottom:.375rem;line-height:1.7}.markdown-renderer .mermaid{display:flex;justify-content:center;margin:1.5rem 0;padding:1.5rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem}.markdown-renderer .wmde-markdown img{max-width:100%;height:auto;border-radius:.5rem;margin:1rem 0}.markdown-renderer .wmde-markdown hr{border:none;border-top:1px solid #e5e7eb;margin:2rem 0}.markdown-renderer::-webkit-scrollbar{width:8px;height:8px}.markdown-renderer::-webkit-scrollbar-track{background-color:#f3f4f6;border-radius:4px}.markdown-renderer::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:4px}.markdown-renderer::-webkit-scrollbar-thumb:hover{background-color:#9ca3af}.component-processing-modal.modal-content{max-width:none!important;width:calc(100vw - 3rem)!important;max-height:none!important;height:calc(100vh - 3rem)!important;display:flex;flex-direction:column;margin:1.5rem}.component-processing-modal .modal-header-actions{display:flex;gap:.5rem;align-items:center}.component-processing-content{display:flex;flex:1;overflow:hidden;gap:1rem}.component-processing-sidebar{width:400px;display:flex;flex-direction:column;gap:1rem;border-right:1px solid var(--border-color);padding-right:1rem;overflow:hidden}.search-box{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary)}.search-box svg{color:var(--text-secondary);flex-shrink:0}.search-box input{flex:1;border:none;background:transparent;outline:none;font-size:.875rem;color:var(--text-primary)}.search-box input::placeholder{color:var(--text-tertiary)}.file-list-actions{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-left:.5rem}.file-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}.file-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;margin-left:.5rem;border-radius:8px;background:transparent;cursor:pointer;transition:all .2s;color:var(--text-primary);position:relative;border-left:3px solid transparent}.file-item:hover{background:var(--bg-hover)}.file-item.active{background:var(--bg-hover);border-left-color:var(--primary-color)}.file-item input[type=checkbox]{flex-shrink:0}.file-item .file-icon{flex-shrink:0;color:var(--text-secondary)}.file-item.active .file-icon{color:var(--primary-color)}.file-item-info{flex:1;min-width:0}.file-item-name{font-weight:500;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item-meta{font-size:.75rem;color:var(--text-secondary);margin-top:.125rem}.component-processing-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.documentation-header{padding-bottom:1rem;border-bottom:1px solid var(--border-color);margin-bottom:1rem}.documentation-header-title{display:flex;align-items:center;gap:.75rem}.documentation-header-title h4{font-size:1.25rem;font-weight:600;margin:0}.documentation-content{flex:1;overflow-y:auto;padding-right:.5rem}.markdown-preview{font-family:Courier New,monospace;font-size:.875rem;white-space:pre-wrap;word-break:break-word;margin:0;padding:1.5rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color);line-height:1.6;color:var(--text-primary)}.empty-state{text-align:center;padding:2rem;color:var(--text-secondary)}.empty-state p{margin:0;font-size:.875rem}.empty-state-large{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);gap:1rem}.empty-state-large svg{opacity:.3}.empty-state-large h4{margin:0;font-size:1.25rem;font-weight:600}.empty-state-large p{margin:0;font-size:.875rem;max-width:400px;text-align:center}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.file-list::-webkit-scrollbar,.documentation-content::-webkit-scrollbar{width:10px;height:10px}.file-list::-webkit-scrollbar-track,.documentation-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.file-list::-webkit-scrollbar-thumb,.documentation-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px;border:2px solid #f1f5f9}.file-list::-webkit-scrollbar-thumb:hover,.documentation-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.view-mode-tabs{display:flex;gap:.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color);margin-bottom:1rem}.view-mode-tab{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.view-mode-tab:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--primary-color)}.view-mode-tab.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.view-mode-tab:disabled{opacity:.5;cursor:not-allowed}.file-content-header{padding-bottom:1rem;border-bottom:1px solid var(--border-color);margin-bottom:1rem}.file-content-header h4{font-size:1.125rem;font-weight:600;margin:0 0 .5rem;color:var(--text-primary)}.file-content-meta{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.file-content-meta .meta-divider{margin:0 .25rem}.file-content-preview{font-family:Courier New,Consolas,Monaco,monospace;font-size:.875rem;white-space:pre-wrap;word-break:break-word;margin:0;padding:1.5rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color);line-height:1.6;color:var(--text-primary);overflow-x:auto}.compare-component-modal{max-width:none!important;width:calc(100vw - 3rem)!important;max-height:none!important;height:calc(100vh - 3rem)!important;display:flex;flex-direction:column;margin:1.5rem}.compare-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-default);background:var(--bg-secondary);padding:0 var(--space-6)}.compare-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);position:relative;margin-bottom:-2px}.compare-tab:hover:not(:disabled){color:var(--color-primary);background:var(--bg-hover)}.compare-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);background:var(--bg-primary)}.compare-tab:disabled{opacity:.5;cursor:not-allowed}.compare-tab-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;background:var(--bg-primary);min-height:0}.documentation-view{display:flex;flex-direction:column;height:100%}.documentation-header{padding:var(--space-6);border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);background:var(--bg-secondary);flex-shrink:0}.documentation-header h3{margin:0 0 var(--space-2) 0;font-size:var(--text-xl);font-weight:600;color:var(--text-primary)}.documentation-meta{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.doc-path{font-size:var(--text-sm);color:var(--text-muted);font-family:var(--font-mono)}.documentation-content{flex:1;overflow-y:auto;padding:var(--space-6)}.documentation-content h1,.documentation-content h2,.documentation-content h3{margin-top:var(--space-6);margin-bottom:var(--space-3);color:var(--text-primary)}.documentation-content h1:first-child,.documentation-content h2:first-child,.documentation-content h3:first-child{margin-top:0}.documentation-content p{margin-bottom:var(--space-4);line-height:1.7;color:var(--text-secondary)}.documentation-content ul,.documentation-content ol{margin-bottom:var(--space-4);padding-left:var(--space-6)}.documentation-content li{margin-bottom:var(--space-2);line-height:1.7;color:var(--text-secondary)}.documentation-content code{background:var(--bg-secondary);padding:2px var(--space-2);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.9em;color:var(--color-primary)}.documentation-content pre{background:var(--bg-tertiary);padding:var(--space-4);border-radius:var(--radius-lg);overflow-x:auto;margin-bottom:var(--space-4);border:1px solid var(--border-subtle)}.documentation-content pre code{background:none;padding:0;color:var(--text-primary)}.documentation-metadata{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-subtle);background:var(--bg-secondary);flex-shrink:0}.stat-add{color:var(--color-success);font-weight:600}.stat-del{color:var(--color-danger);font-weight:600}@media (max-width: 768px){.compare-component-modal{width:100vw!important;height:100vh!important;margin:0;border-radius:0}.modal-split{grid-template-columns:1fr;grid-template-rows:200px 1fr}.diff-sidebar{border-right:none;border-bottom:1px solid var(--border-default)}.diff-file-list{max-height:150px}.compare-tabs{padding:0 var(--space-4)}.compare-tab{padding:var(--space-3) var(--space-4);font-size:var(--text-xs)}.documentation-header,.documentation-content,.documentation-metadata{padding:var(--space-4)}}.compare-tab-content{animation:fadeIn .2s ease-out}.quota-warning-banner{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.25rem;margin-bottom:1.5rem;border-radius:12px;border:2px solid;animation:slideDown .3s ease-out}.quota-warning-banner.quota-error{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#ef4444}.quota-warning-banner.quota-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}.quota-warning-content{display:flex;align-items:flex-start;gap:1rem;flex:1}.quota-warning-content svg{flex-shrink:0;margin-top:2px}.quota-error .quota-warning-content svg{color:#dc2626}.quota-warning .quota-warning-content svg{color:#d97706}.quota-warning-text{flex:1}.quota-warning-text h4{margin:0 0 .5rem;font-size:1rem;font-weight:600}.quota-error .quota-warning-text h4{color:#991b1b}.quota-warning .quota-warning-text h4{color:#92400e}.quota-warning-text p{margin:0 0 .75rem;font-size:.875rem;line-height:1.5}.quota-error .quota-warning-text p{color:#7f1d1d}.quota-warning .quota-warning-text p{color:#78350f}.quota-warning-stats{display:flex;align-items:center;gap:.75rem;font-size:.875rem;font-weight:600}.quota-error .quota-warning-stats{color:#991b1b}.quota-warning .quota-warning-stats{color:#92400e}.quota-separator{opacity:.5}.quota-warning-close{background:transparent;border:none;padding:.25rem;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0}.quota-error .quota-warning-close{color:#991b1b}.quota-warning .quota-warning-close{color:#92400e}.quota-warning-close:hover{background:#0000001a}.quota-warning-close:active{background:#00000026}.modal-xl{max-width:none!important;width:calc(100vw - 3rem)!important;max-height:none!important;height:calc(100vh - 3rem)!important;display:flex;flex-direction:column;margin:1.5rem}.modal-split{display:grid;grid-template-columns:400px 1fr;gap:0;overflow:hidden;flex:1;min-height:0}.diff-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-default);display:flex;flex-direction:column;overflow:hidden}.diff-sidebar-header{padding:var(--space-4);border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;align-items:center;gap:var(--space-3)}.diff-sidebar-header h3{margin:0;font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.sidebar-actions{display:flex;gap:var(--space-2)}.btn-xs{padding:var(--space-1) var(--space-2);font-size:var(--text-xs);display:inline-flex;align-items:center;gap:var(--space-1)}.diff-sidebar-search{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-default);display:flex;align-items:center;gap:var(--space-2);background:var(--bg-primary)}.diff-sidebar-search input{flex:1;border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-secondary);outline:none;transition:border-color var(--transition-base)}.diff-sidebar-search input:focus{border-color:var(--color-primary)}.diff-sidebar-search input::placeholder{color:var(--text-muted)}.diff-empty-message{padding:var(--space-8);text-align:center;color:var(--text-muted)}.diff-empty-message p{margin:0;font-size:var(--text-sm)}.diff-file-list{flex:1;overflow-y:auto;padding:var(--space-2)}.diff-file-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);border:1px solid transparent;margin-bottom:var(--space-2)}.diff-file-item:hover{background:var(--bg-hover)}.diff-file-item.active{background:var(--bg-active);border-color:var(--color-primary)}.diff-file-item.change-added{border-left:3px solid var(--color-success)}.diff-file-item.change-modified{border-left:3px solid var(--color-warning)}.diff-file-item.change-removed{border-left:3px solid var(--color-danger)}.change-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:var(--radius-md)}.change-icon-added{background:var(--color-success-bg);color:var(--color-success)}.change-icon-modified{background:var(--color-warning-bg);color:var(--color-warning)}.change-icon-removed{background:var(--color-danger-bg);color:var(--color-danger)}.diff-file-item-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.diff-file-name{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.diff-file-stats{display:flex;gap:var(--space-2);font-size:var(--text-xs)}.stat-add-sm{color:var(--color-success)}.stat-del-sm{color:var(--color-danger)}.diff-view-panel{background:var(--bg-primary);overflow-y:auto;display:flex;flex-direction:column}.diff-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-12);color:var(--text-muted);text-align:center}.diff-empty-state h3{margin:0;font-size:var(--text-xl);font-weight:600;color:var(--text-secondary)}.diff-empty-state p{margin:0;font-size:var(--text-base);color:var(--text-muted)}.diff-viewer{display:flex;flex-direction:column;height:100%}.diff-viewer-header{padding:var(--space-6);border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);background:var(--bg-secondary)}.diff-viewer-header h3{margin:0 0 var(--space-2) 0;font-size:var(--text-xl);font-weight:600;color:var(--text-primary)}.diff-viewer-meta{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.diff-path{font-size:var(--text-sm);color:var(--text-muted);font-family:var(--font-mono)}.diff-stats-large{display:flex;gap:var(--space-4);font-size:var(--text-sm);font-weight:600}.diff-viewer-content{flex:1;overflow-y:auto;padding:var(--space-4)}.diff-hunks{display:flex;flex-direction:column;gap:var(--space-4)}.diff-hunk{border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.diff-hunk-header{background:var(--bg-secondary);padding:var(--space-2) var(--space-4);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-muted);border-bottom:1px solid var(--border-default)}.diff-lines{background:var(--bg-primary)}.diff-line{display:flex;align-items:center;font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.6;padding:2px var(--space-4)}.diff-line-prefix{width:20px;flex-shrink:0;text-align:center;font-weight:600;-webkit-user-select:none;user-select:none}.diff-line-content{flex:1;white-space:pre-wrap;word-break:break-all}.diff-line-number{display:inline-block;width:50px;text-align:right;padding-right:var(--space-3);color:var(--text-muted);-webkit-user-select:none;user-select:none;flex-shrink:0}.diff-line-added{background:#22c55e1a;color:var(--text-primary)}.diff-line-added .diff-line-prefix{color:var(--color-success)}.diff-line-removed{background:#ef44441a;color:var(--text-primary)}.diff-line-removed .diff-line-prefix{color:var(--color-danger)}.diff-line-context{background:var(--bg-primary)}.diff-line-context .diff-line-prefix{color:var(--text-muted)}.diff-content-full{display:flex;flex-direction:column;gap:var(--space-3)}.diff-content-label{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);padding:var(--space-2) 0}.diff-content-preview{background:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:0;margin:0;overflow-x:auto}.modal-stats-inline{display:flex;gap:var(--space-3);margin-top:var(--space-2);flex-wrap:wrap}.stat-badge{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1);padding:4px 8px;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:700;white-space:nowrap;line-height:1;height:20px}.stat-badge.stat-add{background:var(--color-success-bg);color:var(--color-success)}.stat-badge.stat-mod{background:var(--color-warning-bg);color:var(--color-warning)}.stat-badge.stat-rem{background:var(--color-danger-bg);color:var(--color-danger)}.diff-stats{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.badge-success{background:var(--color-success-bg);color:var(--color-success);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:600}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:600}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:600}@media (max-width: 768px){.modal-xl{width:100vw!important;height:100vh!important;margin:0;border-radius:0}.modal-split{grid-template-columns:1fr;grid-template-rows:200px 1fr}.diff-sidebar{border-right:none;border-bottom:1px solid var(--border-default)}.diff-file-list{max-height:150px}}.diff-file-list::-webkit-scrollbar,.diff-viewer-content::-webkit-scrollbar{width:10px;height:10px}.diff-file-list::-webkit-scrollbar-track,.diff-viewer-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.diff-file-list::-webkit-scrollbar-thumb,.diff-viewer-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px;border:2px solid #f1f5f9}.diff-file-list::-webkit-scrollbar-thumb:hover,.diff-viewer-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.compare-screen{max-width:1200px;margin:0 auto}.compare-container{display:flex;flex-direction:column;gap:var(--space-8)}.compare-card{background:linear-gradient(135deg,#6366f10d,#8b5cf60d);border-color:#6366f133}.compare-header{margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-subtle)}.compare-header-content{display:flex;align-items:flex-start;gap:var(--space-4)}.compare-header-icon{color:var(--color-primary);flex-shrink:0;margin-top:4px}.compare-header h2{font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2) 0}.compare-header p{margin:0;color:var(--text-secondary);font-size:var(--text-base);line-height:1.5}.version-uploaders{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--space-6);margin-bottom:var(--space-8);align-items:start}.version-uploader{display:flex;flex-direction:column;gap:var(--space-3)}.uploader-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.uploader-label{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0}.uploader-label-hint{font-size:var(--text-sm);color:var(--text-muted);font-weight:500}.upload-drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-12) var(--space-6);background:var(--bg-secondary);border:2px dashed var(--border-default);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base);min-height:200px}.upload-drop-zone:hover{border-color:var(--color-primary);background:var(--bg-elevated);transform:translateY(-2px)}.upload-drop-zone.dragging{border-color:var(--color-primary);background:#6366f10d;box-shadow:0 0 0 4px #6366f11a}.upload-icon{color:var(--text-muted);transition:all var(--transition-base)}.upload-drop-zone:hover .upload-icon{color:var(--color-primary);transform:scale(1.1)}.upload-text{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0}.upload-hint{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.uploaded-solution{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);min-height:200px}.uploaded-solution-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0;transition:all var(--transition-base)}.uploaded-solution-icon-success{background:linear-gradient(135deg,#10b98126,#05966926);color:#10b981}.uploaded-solution-info{flex:1}.uploaded-solution-info h4{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2) 0}.uploaded-solution-meta{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-sm)}.uploaded-solution-info p{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.btn-icon-sm{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.btn-icon-sm:hover{background:var(--bg-secondary);color:var(--text-primary)}.compare-arrow-vertical{display:flex;align-items:center;justify-content:center;color:var(--color-primary);padding-top:40px}.arrow-icon{transition:all var(--transition-base)}.solution-comparison-bar{display:grid;grid-template-columns:1fr auto 1fr auto;gap:var(--space-6);align-items:center;padding:var(--space-6);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);margin-bottom:var(--space-6)}.solution-comparison-item{display:flex;flex-direction:column;gap:var(--space-2)}.solution-comparison-label{font-size:var(--text-sm);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.solution-comparison-details h3{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2) 0}.solution-comparison-meta{display:flex;align-items:center;gap:var(--space-3)}.solution-comparison-arrow{display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.solution-comparison-actions{display:flex;justify-content:flex-end}.compare-actions{display:flex;justify-content:center;padding-top:var(--space-6);border-top:1px solid var(--border-subtle)}.section-header{margin-top:var(--space-4);margin-bottom:var(--space-3);padding:0;width:100%;display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.section-header:first-child{margin-top:0}.section-actions{display:flex;gap:var(--space-2);align-items:center}.section-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.diff-results-container{display:flex;flex-direction:column;gap:var(--space-6)}.diff-summary-card{padding:var(--space-8);background:linear-gradient(135deg,#6366f10d,#8b5cf60d);border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-xl)}.diff-summary-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-subtle)}.diff-summary-title{display:flex;align-items:flex-start;gap:var(--space-4)}.diff-summary-title svg{color:var(--color-primary);flex-shrink:0;margin-top:4px}.diff-summary-title h2{font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-1) 0}.diff-summary-actions{display:flex;gap:var(--space-3)}.diff-summary-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.diff-stat{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);transition:all var(--transition-base)}.diff-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.diff-stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0}.diff-stat-added .diff-stat-icon{background:linear-gradient(135deg,#10b9811a,#0596691a);color:#10b981}.diff-stat-modified .diff-stat-icon{background:linear-gradient(135deg,#f59e0b1a,#d977061a);color:#f59e0b}.diff-stat-removed .diff-stat-icon{background:linear-gradient(135deg,#ef44441a,#dc26261a);color:#ef4444}.diff-stat-unchanged .diff-stat-icon{background:linear-gradient(135deg,#6b72801a,#4b55631a);color:#6b7280}.diff-stat-content{display:flex;flex-direction:column;gap:var(--space-1)}.diff-stat-value{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary)}.diff-stat-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.diff-details{display:flex;flex-direction:column;gap:var(--space-4)}.diff-details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.diff-details-title{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0}.diff-details-controls{display:flex;align-items:center;gap:var(--space-4)}.selected-count{font-size:var(--text-sm);font-weight:600;color:var(--color-primary);padding:var(--space-2) var(--space-4);background:#6366f11a;border-radius:var(--radius-md)}.ai-instruction-card{display:flex;gap:var(--space-6);padding:var(--space-8);background:linear-gradient(135deg,#8b5cf60d,#6366f10d);border:2px dashed rgba(99,102,241,.3);border-radius:var(--radius-xl);margin-bottom:var(--space-6)}.ai-instruction-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:linear-gradient(135deg,#8b5cf626,#6366f126);border-radius:var(--radius-lg);color:var(--color-primary);flex-shrink:0}.ai-instruction-content{flex:1}.ai-instruction-content h4{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-3) 0}.ai-instruction-content p{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6;margin:0 0 var(--space-4) 0}.ai-instruction-steps{display:flex;flex-direction:column;gap:var(--space-3)}.ai-step{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--text-primary)}.ai-step-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-primary);color:#fff;border-radius:50%;font-weight:600;font-size:var(--text-sm);flex-shrink:0}.diff-category-card{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base)}.diff-category-card:hover{border-color:var(--border-subtle);box-shadow:var(--shadow-sm)}.diff-category-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5);cursor:pointer;transition:all var(--transition-fast);background:var(--bg-secondary)}.diff-category-header:hover{background:var(--bg-elevated)}.diff-category-title{display:flex;align-items:center;gap:var(--space-3)}.diff-category-title h4{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0}.diff-category-stats{display:flex;gap:var(--space-2)}.diff-mini-stat{padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600}.diff-mini-stat-added{background:#10b9811a;color:#10b981}.diff-mini-stat-modified{background:#f59e0b1a;color:#f59e0b}.diff-mini-stat-removed{background:#ef44441a;color:#ef4444}.diff-category-items{display:flex;flex-direction:column;gap:1px;background:var(--border-subtle)}.diff-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--bg-elevated);transition:all var(--transition-fast)}.diff-item:hover{background:var(--bg-secondary)}.diff-item-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);flex-shrink:0}.diff-item-added .diff-item-icon{background:#10b9811a;color:#10b981}.diff-item-modified .diff-item-icon{background:#f59e0b1a;color:#f59e0b}.diff-item-removed .diff-item-icon{background:#ef44441a;color:#ef4444}.diff-item-content{flex:1}.diff-item-name{font-size:var(--text-base);font-weight:500;color:var(--text-primary);margin-bottom:var(--space-1)}.diff-item-details{font-size:var(--text-sm);color:var(--text-secondary)}.diff-item-badge{flex-shrink:0}.badge-added{background:#10b9811a;color:#10b981;border-color:#10b98133}.badge-modified{background:#f59e0b1a;color:#f59e0b;border-color:#f59e0b33}.badge-removed{background:#ef44441a;color:#ef4444;border-color:#ef444433}.extraction-progress{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6);background:#6366f10d;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-lg);margin-top:var(--space-6)}.extraction-progress svg{color:var(--color-primary)}.extraction-progress p{margin:0;color:var(--text-primary);font-size:var(--text-sm);font-weight:500}.diff-calculator-container{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-subtle)}.diff-calculator{display:flex;flex-direction:column;gap:var(--space-4)}.diff-calculator-idle{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-6)}.diff-calculator-idle .text-muted{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.diff-calculator-progress{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-6);background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg)}.diff-calculator-progress .progress-header{display:flex;justify-content:space-between;align-items:center}.diff-calculator-progress .progress-header-content{display:flex;align-items:center;gap:var(--space-3)}.diff-calculator-progress .progress-header h3{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0}.progress-bar-container{width:100%;height:32px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary),rgba(139,92,246,.8));display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--text-sm);font-weight:600;transition:width .3s ease}.progress-message{font-size:var(--text-sm);color:var(--text-secondary);margin:0;text-align:center}.diff-calculator-error{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-6)}.component-diff-list{display:flex;flex-direction:column;gap:var(--space-6)}.component-diff-list-empty{padding:var(--space-6)}.diff-summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.diff-card{padding:var(--space-6);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);transition:all var(--transition-base)}.diff-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.diff-card-added{border-color:#10b9814d;background:linear-gradient(135deg,#10b9810d,#0596690d)}.diff-card-modified{border-color:#f59e0b4d;background:linear-gradient(135deg,#f59e0b0d,#d977060d)}.diff-card-removed{border-color:#ef44444d;background:linear-gradient(135deg,#ef44440d,#dc26260d)}.diff-card-icon{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.diff-card-content{display:flex;flex-direction:column;gap:var(--space-1)}.diff-card-count{font-size:var(--text-3xl);font-weight:700;color:var(--text-primary)}.diff-card-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.category-list{display:flex;flex-direction:column;gap:var(--space-3)}.category-section{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden}.category-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5);cursor:pointer;transition:all var(--transition-fast);background:var(--bg-secondary)}.category-header:hover{background:var(--bg-elevated)}.category-header-left{display:flex;align-items:center;gap:var(--space-3)}.category-expand-icon{color:var(--text-muted);font-size:var(--text-sm);width:16px;display:inline-block}.category-name{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0}.category-count{font-size:var(--text-sm);color:var(--text-secondary);margin-left:var(--space-2)}.category-badges{display:flex;gap:var(--space-2)}.badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;border:1px solid transparent}.category-content{display:flex;flex-direction:column;gap:1px;background:var(--border-subtle)}.component-item{background:var(--bg-elevated);border-left:3px solid transparent}.component-item-added{border-left-color:#10b981}.component-item-modified{border-left-color:#f59e0b}.component-item-removed{border-left-color:#ef4444}.component-item-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);cursor:pointer;transition:all var(--transition-fast)}.component-item-header:hover{background:var(--bg-secondary)}.component-checkbox{width:18px;height:18px;cursor:pointer;flex-shrink:0}.component-expand-icon{color:var(--text-muted);font-size:var(--text-sm);width:16px;display:inline-block}.component-icon{font-size:var(--text-base);flex-shrink:0}.component-name{font-size:var(--text-base);font-weight:500;color:var(--text-primary);flex:1}.component-item-left{display:flex;align-items:center;gap:var(--space-3);flex:1}.component-item-right{display:flex;align-items:center;gap:var(--space-3)}.component-stats{display:flex;gap:var(--space-2);font-size:var(--text-sm);font-weight:600}.stat-added{color:#10b981}.stat-deleted{color:#ef4444}.component-item-details{padding:var(--space-5);background:var(--bg-secondary);border-top:1px solid var(--border-subtle)}.component-path{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4)}.component-path code{font-family:var(--font-mono);font-size:var(--text-sm);padding:var(--space-1) var(--space-2);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm)}.component-diff-content{margin-top:var(--space-4)}.component-diff-content strong{display:block;margin-bottom:var(--space-2);color:var(--text-primary);font-size:var(--text-sm)}.diff-preview{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-4);font-family:var(--font-mono);font-size:var(--text-sm);overflow-x:auto;margin:0}.diff-hunk{margin-bottom:var(--space-4)}.diff-hunk:last-child{margin-bottom:0}.diff-hunk-header{color:var(--color-primary);font-weight:600;margin-bottom:var(--space-2);padding:var(--space-2);background:#6366f11a;border-radius:var(--radius-sm)}.diff-line{padding:2px var(--space-2);margin:0;line-height:1.6}.diff-line-added{background:#10b9811a;color:#059669}.diff-line-removed{background:#ef44441a;color:#dc2626}.diff-line-context{color:var(--text-secondary)}.diff-line-truncated,.diff-hunk-truncated{padding:var(--space-2);color:var(--text-muted);font-style:italic;text-align:center}.component-info{margin-top:var(--space-4)}.info-badge{display:inline-block;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-3)}.info-badge-added{background:#10b9811a;color:#10b981}.info-badge-removed{background:#ef44441a;color:#ef4444}.component-info p{margin:0;font-size:var(--text-sm);color:var(--text-secondary)}.diff-stat-icon-text{font-size:var(--text-xl);font-weight:700}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:90vh;display:flex;flex-direction:column;width:100%;max-width:800px}.modal-large{max-width:1000px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-6);border-bottom:1px solid var(--border-subtle)}.modal-header h2{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0}.modal-body{flex:1;overflow-y:auto;padding:var(--space-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-6);border-top:1px solid var(--border-subtle)}.markdown-preview{font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.6;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-6);overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;margin:0}.doc-mode-toggle-container{margin-bottom:var(--space-6)}.doc-mode-label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3)}.doc-mode-toggle{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.doc-mode-option{position:relative;padding:var(--space-4);background:var(--bg-secondary);border:2px solid var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-align:left}.doc-mode-option:hover{border-color:var(--color-primary);background:var(--bg-elevated);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.doc-mode-option:disabled{opacity:.5;cursor:not-allowed;transform:none}.doc-mode-active{border-color:var(--color-primary);background:#6366f11a;box-shadow:0 0 0 3px #6366f11a}.doc-mode-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.doc-mode-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.doc-mode-info-icon{color:var(--text-muted)}.doc-mode-description{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.doc-mode-tooltip{position:absolute;top:100%;left:0;right:0;margin-top:var(--space-2);padding:var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;font-size:var(--text-sm)}.doc-mode-tooltip strong{display:block;margin-bottom:var(--space-2);color:var(--text-primary)}.doc-mode-tooltip p{margin:0 0 var(--space-2) 0;color:var(--text-secondary)}.doc-mode-tooltip ul{margin:0;padding-left:var(--space-5);color:var(--text-secondary)}.doc-mode-tooltip li{margin-bottom:var(--space-1)}.doc-mode-info{margin-top:var(--space-3)}.documentation-section{margin-top:var(--space-6)}.release-summary-panel{background:linear-gradient(135deg,#8b5cf60d,#6366f10d);border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-xl);padding:var(--space-6);margin-top:var(--space-6)}.release-summary-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid rgba(99,102,241,.2)}.release-summary-title{display:flex;align-items:flex-start;gap:var(--space-4)}.release-summary-title svg{color:var(--color-primary);flex-shrink:0;margin-top:4px}.release-summary-title h2{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-1) 0}.summary-meta{font-size:var(--text-sm);color:var(--text-muted)}.release-summary-actions{display:flex;gap:var(--space-2)}.release-summary-content{display:flex;flex-direction:column;gap:var(--space-6)}.summary-text{font-size:var(--text-base);line-height:1.7;color:var(--text-primary)}.summary-section{padding:var(--space-5);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg)}.summary-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-3) 0}.summary-section-title svg{color:var(--color-primary)}.summary-list{margin:0;padding-left:var(--space-6);list-style-type:disc}.summary-list li{margin-bottom:var(--space-2);color:var(--text-primary)}.summary-list-impacts{list-style-type:none;padding-left:0}.summary-list-impacts li{padding-left:var(--space-6);position:relative}.summary-list-impacts li:before{content:"⚠️";position:absolute;left:0}.summary-statistics{padding:var(--space-5);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg)}.summary-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.summary-stat-item{display:flex;flex-direction:column;align-items:center;padding:var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-md)}.summary-stat-value{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-1)}.summary-stat-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.release-summary-generating,.release-summary-error,.release-summary-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center}.release-summary-generating svg,.release-summary-error svg,.release-summary-empty svg{color:var(--color-primary);margin-bottom:var(--space-4)}.release-summary-generating h3,.release-summary-error h3,.release-summary-empty h3{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2) 0}.release-summary-generating p,.release-summary-error p,.release-summary-empty p{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-4) 0;max-width:500px}.release-summary-error svg{color:#ef4444}.change-documentation-panel{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-6)}.change-documentation-panel-empty{padding:var(--space-12) var(--space-6)}.empty-state{text-align:center;max-width:400px;margin:0 auto}.empty-state h3{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2) 0}.empty-state p{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.documentation-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle)}.documentation-title{display:flex;align-items:flex-start;gap:var(--space-4)}.documentation-title svg{color:var(--color-primary);flex-shrink:0;margin-top:4px}.documentation-title h2{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-1) 0}.documentation-stats{display:flex;gap:var(--space-6)}.stat-item{display:flex;flex-direction:column;align-items:flex-end}.stat-label{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-1)}.stat-value{font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.documentation-progress{margin-bottom:var(--space-6)}.progress-text{font-size:var(--text-sm);color:var(--text-secondary);margin:var(--space-2) 0 0 0;text-align:center}.documentation-summary{margin-bottom:var(--space-4)}.summary-badges{display:flex;gap:var(--space-3);flex-wrap:wrap}.summary-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500}.summary-badge-completed{background:#10b9811a;color:#10b981}.summary-badge-processing{background:#f59e0b1a;color:#f59e0b}.summary-badge-failed{background:#ef44441a;color:#ef4444}.documentation-list{display:flex;flex-direction:column;gap:var(--space-3)}.doc-item{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base)}.doc-item:hover{border-color:var(--border-subtle);box-shadow:var(--shadow-sm)}.doc-item-completed{border-left:3px solid #10b981}.doc-item-processing{border-left:3px solid #f59e0b}.doc-item-failed{border-left:3px solid #ef4444}.doc-item-pending{border-left:3px solid var(--border-default)}.doc-item-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);cursor:pointer;transition:all var(--transition-fast)}.doc-item-header:hover{background:var(--bg-elevated)}.doc-item-left{display:flex;align-items:center;gap:var(--space-3);flex:1}.doc-expand-icon{color:var(--text-muted);display:flex;align-items:center}.doc-status-icon{display:flex;align-items:center}.status-icon-completed{color:#10b981}.status-icon-processing{color:#f59e0b}.status-icon-failed{color:#ef4444}.status-icon-pending{width:20px;height:20px;border-radius:50%;border:2px solid var(--border-default);background:var(--bg-secondary)}.doc-item-info{flex:1}.doc-component-name{font-size:var(--text-base);font-weight:500;color:var(--text-primary);margin:0 0 var(--space-1) 0}.doc-component-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);margin:0}.doc-separator{color:var(--text-muted)}.doc-change-type{font-weight:500}.doc-change-added{color:#10b981}.doc-change-modified{color:#f59e0b}.doc-change-removed{color:#ef4444}.doc-item-actions{display:flex;gap:var(--space-2)}.doc-item-content{padding:var(--space-5);background:var(--bg-elevated);border-top:1px solid var(--border-subtle)}.doc-documentation{font-size:var(--text-sm);line-height:1.6;color:var(--text-primary)}.markdown-content{max-width:100%}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4{margin-top:var(--space-4);margin-bottom:var(--space-2);color:var(--text-primary)}.markdown-content h1{font-size:var(--text-xl)}.markdown-content h2{font-size:var(--text-lg)}.markdown-content h3{font-size:var(--text-base)}.markdown-content h4{font-size:var(--text-sm)}.markdown-content p{margin-bottom:var(--space-3)}.markdown-content ul{margin:var(--space-2) 0;padding-left:var(--space-5)}.markdown-content li{margin-bottom:var(--space-1)}.markdown-content code{font-family:var(--font-mono);font-size:.9em;padding:2px 6px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm)}.markdown-content pre{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-4);overflow-x:auto}.markdown-content pre code{background:none;border:none;padding:0}.doc-status-message{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary)}.doc-status-error{background:#ef44440d;border-color:#ef444433;color:#dc2626}.error-title{font-weight:600;margin:0 0 var(--space-1) 0}.error-message{font-size:var(--text-sm);margin:0}@media (max-width: 968px){.solution-comparison-bar{grid-template-columns:1fr;gap:var(--space-4)}.solution-comparison-arrow{transform:rotate(90deg)}.solution-comparison-actions{justify-content:stretch}.solution-comparison-actions button{width:100%}.diff-summary-header{flex-direction:column;gap:var(--space-4)}.diff-summary-actions{width:100%}.diff-summary-actions button{flex:1}.diff-summary-stats{grid-template-columns:repeat(2,1fr)}.diff-summary-cards{grid-template-columns:1fr}.diff-details-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.diff-details-controls{width:100%;flex-direction:column;align-items:stretch}.ai-instruction-card{flex-direction:column;text-align:center}.ai-instruction-icon{margin:0 auto}}@media (max-width: 768px){.version-uploaders{grid-template-columns:1fr;gap:var(--space-4)}.compare-arrow-vertical{transform:rotate(90deg);padding:var(--space-2) 0}.diff-summary-stats{grid-template-columns:1fr}.diff-category-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.diff-item,.component-item-header{flex-wrap:wrap}.component-stats{width:100%;justify-content:flex-start;padding-left:40px}}.compare-upload-section{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-6)}.compare-upload-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle)}.compare-upload-header h3{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0}.compare-upload-header svg{color:var(--color-primary)}.version-uploaders-compact{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--space-4);align-items:center}.version-upload-card{display:flex;flex-direction:column;gap:var(--space-3)}.version-label{display:flex;align-items:center;gap:var(--space-2)}.version-badge{font-size:var(--text-xs);font-weight:600;padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);text-transform:uppercase;letter-spacing:.05em}.version-badge.baseline{background:#6b72801a;color:#6b7280}.version-badge.updated{background:#6366f11a;color:var(--color-primary)}.upload-zone-compact{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-6);background:var(--bg-secondary);border:2px dashed var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);min-height:120px}.upload-zone-compact:hover{border-color:var(--color-primary);background:var(--bg-elevated)}.upload-zone-compact.dragging{border-color:var(--color-primary);background:#6366f10d}.upload-zone-compact svg{color:var(--text-muted);transition:color var(--transition-base)}.upload-zone-compact:hover svg{color:var(--color-primary)}.upload-zone-compact span{font-size:var(--text-sm);color:var(--text-secondary);text-align:center}.uploaded-version{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);min-height:120px}.uploaded-version .check-icon{color:#10b981;flex-shrink:0}.version-info{flex:1;display:flex;flex-direction:column;gap:var(--space-1)}.version-name{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.version-meta{font-size:var(--text-sm);color:var(--text-secondary)}.compare-arrow{display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.extraction-progress span{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.compare-top-bar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);margin-bottom:var(--space-6)}.compare-top-bar-left{display:flex;align-items:center;gap:var(--space-6);flex:1}.solution-versions{display:flex;align-items:center;gap:var(--space-3)}.version-item{display:flex;align-items:center;gap:var(--space-2)}.version-label-small{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.version-name-small{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.badge-neutral-sm,.badge-primary-sm{font-size:var(--text-xs);padding:2px var(--space-2);border-radius:var(--radius-sm);font-weight:600}.badge-neutral-sm{background:#6b72801a;color:#6b7280}.badge-primary-sm{background:#6366f11a;color:var(--color-primary)}.version-arrow{color:var(--text-muted)}.change-stats-inline{display:flex;align-items:center;gap:var(--space-3);padding-left:var(--space-4);border-left:1px solid var(--border-subtle)}.stat-item{font-size:var(--text-sm);font-weight:600;padding:var(--space-1) var(--space-3);border-radius:var(--radius-md)}.stat-item.stat-added{background:#10b9811a;color:#10b981}.stat-item.stat-modified{background:#f59e0b1a;color:#f59e0b}.stat-item.stat-removed{background:#ef44441a;color:#ef4444}.compare-top-bar-actions{display:flex;align-items:center;gap:var(--space-2)}.component-changes-section{display:flex;flex-direction:column;gap:var(--space-4)}.section-header-compact{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-3);border-bottom:1px solid var(--border-subtle)}.section-header-compact h3{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0}.section-header-compact .selected-count{font-size:var(--text-sm);font-weight:600;color:var(--color-primary);padding:var(--space-2) var(--space-3);background:#6366f11a;border-radius:var(--radius-md)}.diff-categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.diff-category-tile{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base)}.diff-category-tile:hover{transform:translateY(-2px);border-color:var(--color-primary);box-shadow:var(--shadow-md)}.diff-category-header{display:flex;justify-content:space-between;align-items:center}.diff-category-header h4{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0}.category-total{font-size:var(--text-xl);font-weight:700;color:var(--color-primary)}.diff-category-stats{display:flex;gap:var(--space-2);flex-wrap:wrap}.stat-badge{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600}.stat-badge-added{background:#10b9811a;color:#10b981}.stat-badge-modified{background:#f59e0b1a;color:#f59e0b}.stat-badge-removed{background:#ef44441a;color:#ef4444}.stat-badge .stat-icon{font-weight:700}.modal-stats{display:flex;gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-lg)}.modal-stat{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600}.component-list{display:flex;flex-direction:column;gap:var(--space-2);max-height:60vh;overflow-y:auto}.component-item-modal{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-fast)}.component-item-modal:hover{border-color:var(--border-subtle)}.change-type-added{border-left:3px solid #10b981}.change-type-modified{border-left:3px solid #f59e0b}.change-type-removed{border-left:3px solid #ef4444}.component-item-header-modal{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);gap:var(--space-3)}.component-item-left-modal{display:flex;align-items:center;gap:var(--space-3);flex:1}.expand-button{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.expand-button:hover{color:var(--text-primary)}.change-badge{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-md);font-weight:700;font-size:var(--text-sm);flex-shrink:0}.change-badge-added{background:#10b9811a;color:#10b981}.change-badge-modified{background:#f59e0b1a;color:#f59e0b}.change-badge-removed{background:#ef44441a;color:#ef4444}.component-name-modal{font-size:var(--text-base);font-weight:500;color:var(--text-primary);flex:1}.component-item-right-modal{display:flex;align-items:center;gap:var(--space-2)}.component-stats-modal{display:flex;gap:var(--space-2);font-size:var(--text-sm);font-weight:600}.stat-add{color:#10b981}.stat-del{color:#ef4444}.component-item-details-modal{padding:var(--space-4);background:var(--bg-elevated);border-top:1px solid var(--border-subtle)}.component-path-modal{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4)}.component-path-modal code{font-family:var(--font-mono);font-size:var(--text-sm);padding:var(--space-1) var(--space-2);background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm)}.component-diff-content-modal{margin-top:var(--space-4)}.component-diff-content-modal strong{display:block;margin-bottom:var(--space-2);color:var(--text-primary);font-size:var(--text-sm)}.diff-preview-modal{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-4);font-family:var(--font-mono);font-size:var(--text-xs);overflow-x:auto;margin:0;max-height:400px;overflow-y:auto}.diff-hunk-modal{margin-bottom:var(--space-4)}.diff-hunk-header-modal{color:var(--color-primary);font-weight:600;margin-bottom:var(--space-2);padding:var(--space-2);background:#6366f11a;border-radius:var(--radius-sm)}.diff-line-modal{padding:2px var(--space-2);margin:0;line-height:1.6}.diff-line-truncated-modal,.diff-hunk-truncated-modal{padding:var(--space-2);color:var(--text-muted);font-style:italic;text-align:center}.component-info-modal{margin-top:var(--space-4);padding:var(--space-3);border-radius:var(--radius-md)}.info-added{background:#10b9810d;border:1px solid rgba(16,185,129,.2)}.info-removed{background:#ef44440d;border:1px solid rgba(239,68,68,.2)}.info-badge-modal{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:600;margin-bottom:var(--space-2)}.component-info-modal p{margin:0;font-size:var(--text-sm);color:var(--text-secondary)}@media (max-width: 968px){.compare-top-bar{flex-direction:column;align-items:stretch}.compare-top-bar-left{flex-direction:column;align-items:stretch;gap:var(--space-4)}.change-stats-inline{border-left:none;border-top:1px solid var(--border-subtle);padding-left:0;padding-top:var(--space-3)}.compare-top-bar-actions{flex-wrap:wrap}.diff-categories-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}@media (max-width: 768px){.version-uploaders-compact{grid-template-columns:1fr}.compare-arrow{transform:rotate(90deg)}.solution-versions{flex-direction:column;align-items:stretch;gap:var(--space-4)}.version-arrow{transform:rotate(90deg)}.change-stats-inline{justify-content:center}.diff-categories-grid{grid-template-columns:1fr}}.compare-screen-v2{min-height:100vh;background:var(--bg-primary)}.compare-upload-state{min-height:100vh;padding:var(--space-8);max-width:1200px;margin:0 auto}.upload-state-container{width:100%}.upload-state-header{margin-bottom:var(--space-8)}.upload-state-header-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--color-primary);vertical-align:middle;margin-right:var(--space-3)}.upload-state-header-icon svg{width:32px;height:32px}.upload-state-header h1{display:inline;margin:0;font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);vertical-align:middle}.upload-state-header p{margin:var(--space-2) 0 0 0;font-size:var(--text-base);color:var(--text-secondary)}.upload-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--space-6);margin-bottom:var(--space-6)}.upload-card{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-5);transition:all var(--transition-base)}.upload-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);border:none!important;background:transparent!important}.upload-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;border:none!important;background:transparent!important;padding:0!important}.upload-remove-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:var(--space-1);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.upload-remove-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.upload-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:180px;padding:var(--space-6);background:var(--bg-secondary);border:2px dashed var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base)}.upload-dropzone:hover{border-color:var(--color-primary);background:var(--bg-elevated)}.upload-dropzone.is-dragging{border-color:var(--color-primary);background:#6366f10d;border-style:solid}.upload-icon{width:64px;height:64px;margin:0 auto var(--space-3);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xl);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;transition:all var(--transition-base)}.upload-icon svg{width:28px;height:28px}.upload-dropzone:hover .upload-icon{transform:scale(1.05)}.upload-text{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.upload-success{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:180px;padding:var(--space-6);gap:var(--space-3);border:1px solid var(--border-default)!important;border-radius:var(--radius-lg);background:var(--bg-secondary);cursor:default!important;border-style:solid!important}.success-icon{color:#10b981}.success-info{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.solution-name{font-size:var(--text-base);font-weight:600;color:var(--text-primary);text-align:center}.solution-version{font-size:var(--text-sm);color:var(--text-secondary);padding:2px var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md)}.upload-arrow{display:flex;align-items:center;justify-content:center;color:var(--color-primary);padding-top:60px}.upload-progress{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-5);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);margin-bottom:var(--space-6)}.upload-progress svg{color:var(--color-primary)}.upload-progress span{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.upload-actions{margin-top:var(--space-6)}.upload-error{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-5);background:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-xl);color:#ef4444}.upload-error svg{flex-shrink:0}.upload-error span{font-size:var(--text-sm);font-weight:500}.results-header-sticky{position:sticky;top:0;z-index:100;background:var(--bg-elevated);border-bottom:1px solid var(--border-default);box-shadow:0 1px 3px #0000000d}.results-header-sticky .solution-top-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);padding:var(--space-5) var(--space-8);background:var(--bg-elevated);flex-shrink:0}.results-header-sticky .solution-top-bar-left{display:flex;align-items:center;gap:var(--space-4);flex:1;min-width:0}.results-header-sticky .solution-top-bar-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;flex-shrink:0}.results-header-sticky .solution-top-bar-icon svg{width:20px;height:20px}.results-header-sticky .solution-top-bar-info{flex:1;min-width:0}.results-header-sticky .solution-title-row{display:flex;align-items:center;gap:var(--space-2)}.results-header-sticky .solution-top-bar-info h2{font-size:var(--text-xl);font-weight:700;margin:0;color:var(--text-primary);letter-spacing:-.01em;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.results-header-sticky .solution-top-bar-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.results-header-sticky .solution-top-bar-meta .badge{font-size:var(--text-xs);padding:2px var(--space-2)}.results-header-sticky .solution-top-bar-meta .badge-secondary{background:#6b72801a;color:#6b7280;border:1px solid rgba(107,114,128,.2)}.results-header-sticky .solution-top-bar-meta .badge-primary{background:#6366f11a;color:var(--color-primary);border:1px solid rgba(99,102,241,.2)}.results-header-sticky .solution-top-bar-meta .arrow-icon{color:var(--text-muted);flex-shrink:0}.results-header-sticky .solution-top-bar-meta .meta-divider{color:var(--text-muted)}.results-header-sticky .solution-top-bar-actions{display:flex;align-items:center;gap:var(--space-3)}.results-header-content{max-width:1400px;margin:0 auto;padding:var(--space-4) var(--space-6);display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.results-header-left{display:flex;align-items:center;gap:var(--space-6);flex:1;min-width:0}.solution-info{display:flex;align-items:center;gap:var(--space-2);min-width:0;flex-shrink:1}.solution-text{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.version-text{font-weight:400;color:var(--text-secondary)}.arrow-icon{color:var(--text-muted);flex-shrink:0}.stats-pills{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.pill{padding:4px var(--space-3);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:700;letter-spacing:.02em}.pill-added{background:#10b9811a;color:#059669}.pill-modified{background:#f59e0b1a;color:#d97706}.pill-removed{background:#ef44441a;color:#dc2626}.results-header-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);height:32px;display:inline-flex;align-items:center;gap:var(--space-2)}.btn-group{display:flex;gap:1px;background:var(--border-default);border-radius:var(--radius-md);overflow:hidden}.btn-group .btn{border-radius:0;border:none}.btn-group .btn:first-child{border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md)}.btn-group .btn:last-child{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.results-main-content{min-height:calc(100vh - 60px);padding:var(--space-6);background:var(--bg-primary)}.results-container{max-width:1400px;margin:0 auto}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.category-card-wrapper{display:flex;flex-direction:column;gap:0}.category-card{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-5);cursor:pointer;transition:all var(--transition-base);position:relative}.category-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.category-card.is-expanded{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent}.category-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4)}.category-title{display:flex;align-items:baseline;gap:var(--space-3);flex:1;min-width:0}.category-title h4{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-count{font-size:var(--text-2xl);font-weight:700;color:var(--color-primary);flex-shrink:0}.category-badges{display:flex;gap:var(--space-2);flex-wrap:wrap}.mini-badge{padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:700}.badge-add{background:#10b9811a;color:#059669}.badge-mod{background:#f59e0b1a;color:#d97706}.badge-rem{background:#ef44441a;color:#dc2626}.category-expanded-content{background:var(--bg-secondary);border:1px solid var(--border-default);border-top:none;border-bottom-left-radius:var(--radius-xl);border-bottom-right-radius:var(--radius-xl);overflow:hidden;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.component-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);cursor:pointer;transition:all var(--transition-fast);border-left:3px solid transparent}.component-row:hover{background:var(--bg-elevated)}.component-row.change-added{border-left-color:#10b981}.component-row.change-modified{border-left-color:#f59e0b}.component-row.change-removed{border-left-color:#ef4444}.component-checkbox{width:16px;height:16px;cursor:pointer;flex-shrink:0}.change-indicator{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-weight:700;font-size:var(--text-xs);flex-shrink:0}.indicator-added{background:#10b9811a;color:#10b981}.indicator-modified{background:#f59e0b1a;color:#f59e0b}.indicator-removed{background:#ef44441a;color:#ef4444}.component-name{flex:1;font-size:var(--text-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.component-stats{display:flex;gap:var(--space-2);font-size:var(--text-xs);font-weight:600;flex-shrink:0}.empty-state-wrapper{display:flex;align-items:center;justify-content:center;min-height:400px;padding:var(--space-12)}.empty-state-content{text-align:center;max-width:400px}.empty-icon{color:var(--text-muted);margin-bottom:var(--space-4)}.empty-state-content h3{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2) 0}.empty-state-content p{font-size:var(--text-base);color:var(--text-secondary);margin:0}@media (max-width: 968px){.upload-grid{grid-template-columns:1fr}.upload-arrow{padding-top:0;transform:rotate(90deg)}.results-header-content{flex-direction:column;align-items:stretch}.results-header-left{flex-direction:column;gap:var(--space-4)}.solution-info{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.stats-pills{justify-content:flex-start}.results-header-actions{flex-wrap:wrap;justify-content:flex-start}.category-grid{grid-template-columns:1fr}}@media (max-width: 640px){.upload-state-header h1{font-size:var(--text-2xl)}.results-header-content{padding:var(--space-3)}.results-main-content{padding:var(--space-4)}.btn-sm{font-size:var(--text-xs);padding:var(--space-2)}.solution-text{font-size:var(--text-xs)}}.info-button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.info-button:hover{background:var(--bg-hover);color:var(--color-primary)}.modal-content-small{max-width:500px}.description-modal-content{padding:var(--space-4) var(--space-6)}.description-modal-content p{margin:0;font-size:var(--text-base);color:var(--text-secondary);line-height:1.6}.components-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-4);padding:0;margin-bottom:var(--space-4);animation:fadeIn .3s ease-out}.component-card{display:grid;grid-template-rows:auto 1fr auto;padding:var(--space-4);background:var(--bg-elevated);border:2px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);position:relative;animation:slideUp .3s ease-out;animation-fill-mode:both;min-height:110px}.component-card:nth-child(1){animation-delay:.05s}.component-card:nth-child(2){animation-delay:.1s}.component-card:nth-child(3){animation-delay:.15s}.component-card:nth-child(4){animation-delay:.2s}.component-card:nth-child(5){animation-delay:.25s}.component-card:nth-child(6){animation-delay:.3s}.component-card:nth-child(7){animation-delay:.35s}.component-card:nth-child(8){animation-delay:.4s}.component-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #6366f126;transform:translateY(-2px)}.component-card-processing{border-color:var(--color-primary);animation:pulse 2s ease-in-out infinite;position:relative;overflow:hidden}.component-card-processing:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(99,102,241,.1),transparent);animation:shimmer 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #6366f166}50%{box-shadow:0 0 0 8px #6366f100}}@keyframes shimmer{0%{left:-100%}to{left:100%}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.component-card-status-icon{position:absolute;top:var(--space-4);right:var(--space-4);display:flex;align-items:center;justify-content:center;line-height:1}.component-card-main{display:flex;align-items:center;gap:var(--space-3);align-self:flex-start;line-height:1}.component-card-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);background:linear-gradient(135deg,#6366f11a,#8b5cf61a);color:var(--color-primary);flex-shrink:0}.component-card-main h4{font-size:var(--text-base);font-weight:600;margin:0;color:var(--text-primary);line-height:1}.component-card-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);align-self:flex-end;width:100%;line-height:1}.component-card-selection{display:flex;align-items:center;line-height:1}.component-card-selection .selected-count{color:var(--color-primary);font-weight:600;font-size:var(--text-xs);white-space:nowrap;line-height:1}.component-card-selection .text-muted{color:var(--text-muted);font-size:var(--text-xs);white-space:nowrap;line-height:1}.component-card-stats{display:flex;gap:var(--space-1-5);align-items:center;line-height:1}.status-icon{flex-shrink:0}.status-icon.status-documented{color:var(--color-success)}.status-icon.status-processing{color:var(--color-primary);animation:spin 1s linear infinite}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.section-header h3{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0}.section-actions{display:flex;gap:var(--space-2)}.results-container{padding:var(--space-6) var(--space-8)}.results-main-content{background:var(--bg-secondary);overflow-y:auto}@media (max-width: 1024px){.components-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width: 768px){.components-grid{grid-template-columns:1fr;gap:var(--space-3)}.component-card{padding:var(--space-4);gap:var(--space-3)}.component-card-icon{width:44px;height:44px}.results-container{padding:var(--space-4)}.section-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.section-actions{width:100%;justify-content:flex-start}.component-card{padding:var(--space-4);gap:var(--space-3);min-height:100px}.component-card-icon{width:36px;height:36px}.component-card-main{gap:var(--space-2)}.component-card-main h4{font-size:var(--text-sm)}.stat-badge{font-size:10px;padding:4px 6px}.component-card-status-icon{top:var(--space-3);right:var(--space-3)}}@media (max-width: 480px){.component-card-main h4{font-size:var(--text-sm)}.component-card-selection .selected-count,.component-card-selection .text-muted{font-size:10px}}.toggle-container{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid transparent;transition:all .2s ease}.toggle-container:hover{background:var(--bg-hover);border-color:var(--border-default)}.toggle-label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary)}.toggle-checkbox{position:absolute;opacity:0;pointer-events:none}.toggle-switch{position:relative;width:36px;height:20px;background:var(--border-default);border-radius:10px;transition:background .2s ease}.toggle-switch:before{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 2px #0000001a}.toggle-checkbox:checked+.toggle-switch{background:var(--color-primary)}.toggle-checkbox:checked+.toggle-switch:before{transform:translate(16px)}.toggle-container:hover .toggle-switch{box-shadow:0 0 0 3px #6366f11a}@media (max-width: 768px){.toggle-container{grid-column:1 / -1;justify-content:center}}.export-panel{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;margin-top:2rem}.export-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.export-title{display:flex;align-items:center;gap:.75rem;margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text-primary, #1a1a1a)}.export-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.export-button{display:flex;align-items:center;gap:1rem;padding:1.25rem;border:2px solid var(--color-border, #ddd);border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;position:relative}.export-button:hover:not(:disabled){border-color:var(--color-primary, #0078d4);background:#f0f8ff;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.export-button:disabled{opacity:.5;cursor:not-allowed}.export-button.export-success{border-color:#388e3c;background:#e8f5e9}.export-button svg{flex-shrink:0;color:var(--color-primary, #0078d4)}.export-button.export-success svg{color:#388e3c}.export-button .button-content{display:flex;flex-direction:column;gap:.25rem;flex:1;text-align:left}.export-button .button-label{font-weight:600;font-size:1rem;color:var(--color-text-primary, #1a1a1a)}.export-button .button-hint{font-size:.75rem;color:var(--color-text-secondary, #666)}.spinner{width:20px;height:20px;border:2px solid var(--color-border, #ddd);border-top-color:var(--color-primary, #0078d4);border-radius:50%;animation:export-spinner-spin .8s linear infinite}@keyframes export-spinner-spin{to{transform:rotate(360deg)}}.export-error{margin-top:1rem;padding:1rem;background:#ffebee;color:#d32f2f;border-radius:6px;border-left:4px solid #d32f2f;font-size:.875rem}.export-disabled-hint{margin-top:1rem;text-align:center;color:var(--color-text-secondary, #666);font-size:.875rem;font-style:italic}.health-check-screen{min-height:100vh;padding:var(--space-8)}.screen-header{max-width:1200px;margin:0 auto var(--space-8)}.screen-header-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--color-primary);vertical-align:middle;margin-right:var(--space-3)}.screen-header-icon svg{width:32px;height:32px}.screen-header h1{display:inline;margin:0;font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);vertical-align:middle}.screen-header p{margin:var(--space-2) 0 0 0;font-size:var(--text-base);color:var(--text-secondary)}.loading-indicator{max-width:800px;margin:0 auto var(--space-4);display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);background:linear-gradient(135deg,#fed7aa,#fdba74);color:#92400e;border:1px solid #fb923c;font-size:var(--text-sm)}.progress-percentage{margin-left:auto;font-weight:600}.rules-list-container{max-width:1400px;width:100%;margin:0 auto var(--space-8);background:var(--bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--border-default);overflow:hidden}.rules-list-header{padding:var(--space-6);border-bottom:1px solid var(--border-default);background:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:baseline;gap:var(--space-3)}.rules-list-header h2{margin:0;font-size:var(--text-2xl);font-weight:700;color:var(--text-primary)}.solution-version{font-size:var(--text-base);color:var(--text-secondary);font-weight:400}.view-toggle{display:flex;gap:var(--space-2);background:var(--bg-elevated);padding:var(--space-1);border-radius:var(--radius-md);border:1px solid var(--border-default)}.view-toggle button{padding:var(--space-2) var(--space-4);border:none;background:transparent;color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-base)}.view-toggle button:hover{background:var(--bg-secondary);color:var(--text-primary)}.view-toggle button.active{background:var(--color-primary);color:#fff}.rules-list{min-height:500px;max-height:none}.rule-item{border-bottom:1px solid var(--border-subtle);transition:all var(--transition-base)}.rule-item:last-child{border-bottom:none}.rule-main{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);cursor:default}.rule-item:hover .rule-main{background:var(--bg-secondary)}.rule-item.has-findings{background:#fef3f2}.rule-item.has-findings .rule-main{background:transparent}.rule-info{display:flex;align-items:center;gap:var(--space-4);flex:1}.rule-category{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;min-width:100px}.rule-name{font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.rule-status-indicator{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary)}.rule-running .rule-status-indicator{color:var(--color-primary)}.rule-complete .check-icon{color:#059669}.findings-badge{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:#fee2e2;color:#dc2626;border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--border-default)}.status-dot.pending{background:var(--border-default)}.rule-findings{padding:var(--space-4) var(--space-6) var(--space-6);background:#fff;border-top:1px solid var(--border-default)}.finding-item{padding:var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-md);border-left:4px solid var(--border-default);margin-bottom:var(--space-3)}.finding-item:last-child{margin-bottom:0}.finding-item.severity-critical{border-left-color:#dc2626;background:#fef2f2}.finding-item.severity-warning{border-left-color:#f59e0b;background:#fffbeb}.finding-item.severity-info{border-left-color:#3b82f6;background:#eff6ff}.finding-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.finding-component{font-weight:600;font-size:var(--text-sm);color:var(--text-primary)}.severity-badge{padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;text-transform:uppercase}.severity-badge.critical{background:#dc2626;color:#fff}.severity-badge.warning{background:#f59e0b;color:#fff}.severity-badge.info{background:#3b82f6;color:#fff}.finding-description{margin:var(--space-2) 0;font-size:var(--text-sm);color:var(--text-primary);line-height:1.6}.finding-remediation{margin:var(--space-2) 0 0;font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6}.finding-remediation strong{color:var(--text-primary);font-weight:600}.ai-analysis-section{margin-top:var(--space-6);border-top:2px solid var(--border-default);padding-top:var(--space-4)}.ai-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.ai-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:#3b82f6;color:#fff;border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm)}.ai-badge:before{content:"🤖"}.ai-count{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.ai-findings-list{display:flex;flex-direction:column;gap:var(--space-3)}.finding-item.ai-finding{border-left-color:#3b82f6;background:#f0f9ff}.ai-icon{margin-right:var(--space-2);font-size:1.2em}.finding-badges{display:flex;gap:var(--space-2);align-items:center}.confidence-badge{padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;text-transform:capitalize}.confidence-badge.confidence-high{background:#22c55e;color:#fff}.confidence-badge.confidence-medium{background:#f59e0b;color:#fff}.confidence-badge.confidence-low{background:#94a3b8;color:#fff}.ai-rationale{margin:var(--space-2) 0;padding:var(--space-3);background:#fff;border-left:3px solid #3b82f6;font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;font-style:italic}.ai-rationale strong{color:var(--text-primary);font-weight:600;font-style:normal}.analyze-button{width:100%;padding:var(--space-4);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;border:none;font-size:var(--text-base);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--space-2);transition:all var(--transition-base)}.analyze-button:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.analyze-button:active{transform:translateY(0)}.upload-zone{max-width:800px;margin:0 auto;border:2px dashed var(--border-default);border-radius:var(--radius-2xl);padding:var(--space-16);text-align:center;cursor:pointer;background:var(--bg-secondary);transition:all var(--transition-base);position:relative;overflow:hidden}.upload-zone:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(99,102,241,.05),transparent 70%);opacity:0;transition:opacity var(--transition-base)}.upload-zone:hover:not(.disabled){border-color:var(--color-primary);background:var(--bg-elevated)}.upload-zone:hover:not(.disabled):before{opacity:1}.upload-zone.disabled{opacity:.6;cursor:not-allowed}.upload-zone-content{position:relative;z-index:1}.file-input{display:none}.upload-icon{width:80px;height:80px;margin:0 auto var(--space-6);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-2xl);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff}.upload-icon svg{width:40px;height:40px}.upload-zone h3{font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.upload-zone p{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-6)}.upload-hint{display:flex;justify-content:center;gap:var(--space-3)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500}.badge-primary{background:var(--color-primary);color:#fff}.error-message{max-width:800px;margin:var(--space-6) auto 0;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;border-radius:var(--radius-lg);border:1px solid #fca5a5}.error-message svg{flex-shrink:0}.health-check-results-section{max-width:1200px;margin:var(--space-8) auto 0}@keyframes healthcheck-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:healthcheck-spin 1s linear infinite}.components-list{min-height:500px}.component-type-group{margin-bottom:var(--space-6)}.component-type-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-6);background:var(--bg-secondary);border-bottom:2px solid var(--border-default);position:sticky;top:0;z-index:1}.component-type-header h3{margin:0;font-size:var(--text-xl);font-weight:600;color:var(--text-primary)}.component-type-stats{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.component-list{display:flex;flex-direction:column}.component-item{border-bottom:1px solid var(--border-subtle);transition:all var(--transition-base)}.component-item:last-child{border-bottom:none}.component-item.has-issues{background:#fef3f2}.component-main{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);cursor:default}.component-item:hover .component-main{background:var(--bg-secondary)}.component-item.has-issues .component-main{background:transparent}.component-info{display:flex;align-items:baseline;gap:var(--space-2);flex:1}.component-name{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.component-logical-name{font-size:var(--text-sm);color:var(--text-secondary);font-weight:400}.component-status{display:flex;align-items:center;gap:var(--space-2)}.component-item.no-issues .check-icon{color:#059669}.component-findings{padding:var(--space-4) var(--space-6) var(--space-6);background:#fff;border-top:1px solid var(--border-default)}.component-findings .finding-item{margin-bottom:var(--space-3)}.component-findings .finding-item:last-child{margin-bottom:0}.finding-rule{font-weight:600;font-size:var(--text-sm);color:var(--text-primary)}.settings-screen{min-height:100vh;padding:var(--space-8);background:var(--bg-secondary)}.settings-screen .screen-header{max-width:900px;margin:0 auto var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-subtle)}.settings-screen .screen-header h1{display:flex;align-items:center;gap:var(--space-3);margin:0 0 var(--space-2) 0;font-size:var(--text-3xl);font-weight:700;color:var(--text-primary)}.settings-screen .screen-header h1 svg{color:var(--color-primary);flex-shrink:0}.settings-screen .screen-header p{margin:0;font-size:var(--text-base);color:var(--text-secondary);line-height:1.5}.settings-container{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-6)}.settings-content{display:flex;flex-direction:column;gap:var(--space-6)}.settings-screen .card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:0 1px 3px #0000000d;transition:all var(--transition-base);overflow:hidden}.settings-screen .card:hover{box-shadow:0 4px 12px #00000014;border-color:var(--border-default)}.settings-section{padding:var(--space-8)}.section-header{display:flex;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6)}.section-header svg{color:var(--color-primary);flex-shrink:0;margin-top:2px}.section-header>div{flex:1;min-width:0}.section-header h3{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-1) 0;line-height:1.3}.section-header p{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1.5}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);gap:var(--space-3)}.loading-state p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.spinner{animation:spin 1s linear infinite;color:var(--color-primary)}.usage-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-5)}.usage-stat-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6);background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all .2s ease}.usage-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014;border-color:var(--color-primary)}.stat-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#fff;border-radius:var(--radius-md);color:var(--color-primary);flex-shrink:0;box-shadow:0 2px 4px #0000000d}.stat-info{flex:1;min-width:0}.stat-label{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-1);font-weight:500}.stat-value{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);line-height:1}.quota-warning-banner{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-6);background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid #ef4444;border-radius:var(--radius-lg);margin-bottom:var(--space-6)}.quota-warning-banner svg{color:#dc2626;flex-shrink:0;margin-top:2px}.quota-warning-banner h3{margin:0 0 var(--space-2) 0;font-size:var(--text-lg);font-weight:600;color:#991b1b}.quota-warning-banner p{margin:0;font-size:var(--text-sm);color:#7f1d1d;line-height:1.5}.quota-section{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-subtle)}.quota-section h4{margin:0 0 var(--space-4) 0;font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.quota-progress-container{display:flex;flex-direction:column;gap:var(--space-3)}.quota-progress-bar{width:100%;height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden}.quota-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:6px;transition:width .3s ease}.quota-progress-fill.quota-exceeded{background:linear-gradient(90deg,#ef4444,#dc2626)}.quota-details{display:flex;justify-content:space-between;align-items:center;font-size:var(--text-sm);color:var(--text-secondary)}.quota-remaining{font-weight:600;color:#10b981}.quota-remaining.quota-exceeded{color:#ef4444}.quota-status{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;margin-top:var(--space-3)}.quota-status svg{flex-shrink:0}.quota-status-success{background:#d1fae5;color:#065f46;border:1px solid #10b981}.quota-status-info{background:#dbeafe;color:#1e40af;border:1px solid #3b82f6}.quota-status-warning{background:#fef3c7;color:#92400e;border:1px solid #f59e0b}.quota-status-error{background:#fee2e2;color:#991b1b;border:1px solid #ef4444}.about-info{display:flex;flex-direction:column;gap:var(--space-3)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:background .2s ease}.info-row:hover{background:#f8fafc}.info-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.info-value{font-size:var(--text-base);color:var(--text-primary);font-weight:600;text-align:right}@media (max-width: 768px){.settings-screen{padding:var(--space-4)}.settings-screen .screen-header{padding-bottom:var(--space-4);margin-bottom:var(--space-6)}.settings-screen .screen-header h1{font-size:var(--text-2xl)}.settings-screen .screen-header h1 svg{width:28px;height:28px}.settings-screen .screen-header p{font-size:var(--text-sm)}.settings-container,.settings-content{gap:var(--space-4)}.settings-section{padding:var(--space-6)}.section-header{gap:var(--space-3)}.section-header svg{width:20px;height:20px}.section-header h3{font-size:var(--text-lg)}.section-header p{font-size:var(--text-xs)}.usage-grid{grid-template-columns:1fr}.usage-stat-card{padding:var(--space-5)}.stat-icon{width:40px;height:40px}.stat-label{font-size:var(--text-xs)}.stat-value{font-size:var(--text-xl)}.info-row{flex-direction:column;align-items:flex-start;gap:var(--space-2);padding:var(--space-3)}.info-label{font-size:var(--text-xs)}.info-value{font-size:var(--text-sm);text-align:left}}@media (max-width: 480px){.settings-screen{padding:var(--space-3)}.settings-section{padding:var(--space-4)}}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative;overflow:hidden}.login-screen:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 50%,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(139,92,246,.08) 0%,transparent 50%);pointer-events:none;z-index:0}.login-container{width:100%;max-width:480px;display:flex;align-items:center;justify-content:center;padding:var(--space-16);background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);z-index:2;position:relative}.login-form-wrapper{width:100%;max-width:400px}.login-header{margin-bottom:var(--space-16);text-align:center}.login-logo{width:100%;max-width:320px;height:auto;margin:0 auto var(--space-6);display:block}.login-header p{margin:0;font-size:var(--text-base);color:var(--text-secondary);line-height:1.5}.login-content h2{margin:0 0 var(--space-8) 0;font-size:var(--text-lg);font-weight:600;color:var(--text-primary);letter-spacing:-.01em;text-align:center}.dev-notice{background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-8);text-align:center}.dev-notice span{display:block;font-weight:600;color:var(--color-warning);margin-bottom:var(--space-1);font-size:var(--text-sm)}.dev-notice small{color:var(--color-warning-light);font-size:var(--text-xs)}.login-buttons{display:flex;flex-direction:column;gap:var(--space-4)}.login-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:0 var(--space-6);height:56px;font-size:var(--text-base);font-weight:500;border:1px solid var(--border-default);border-radius:var(--radius-lg);background:var(--bg-elevated);cursor:pointer;transition:all var(--transition-fast);color:var(--text-primary)}.login-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-strong);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.login-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.btn-icon{width:20px;height:20px;flex-shrink:0}.login-loading{margin-top:var(--space-6);color:var(--text-secondary);text-align:center}.login-loading p{margin:0;font-size:var(--text-sm)}.login-footer{margin-top:var(--space-12);padding-top:var(--space-8);border-top:1px solid var(--border-subtle);text-align:center}.login-footer p{margin:0;font-size:var(--text-sm);color:var(--text-tertiary)}@media (max-width: 640px){.login-container{max-width:100%;margin:var(--space-6);padding:var(--space-10) var(--space-6)}.login-header{margin-bottom:var(--space-10)}.login-footer{margin-top:var(--space-10);padding-top:var(--space-6)}}.landing-page{min-height:100vh;background:#fff;display:flex;flex-direction:column}.landing-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 0;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffffa;box-shadow:0 1px 3px #00000005}.landing-container{max-width:1280px;margin:0 auto;padding:0 2rem}.landing-header-content{display:flex;justify-content:space-between;align-items:center;height:64px}.landing-logo{height:38px;width:auto}.btn-signin{padding:.625rem 1.75rem;background:#1e40af;border:none;color:#fff;font-size:.9375rem;font-weight:600;border-radius:10px;cursor:pointer;transition:all .2s ease;font-family:Inter,sans-serif;box-shadow:0 1px 3px #1e40af33}.btn-signin:hover{background:#1e3a8a;transform:translateY(-1px);box-shadow:0 4px 12px #1e40af4d}.hero-section{padding:5rem 0 7rem;background:linear-gradient(180deg,#fafbff,#fff);position:relative;overflow:hidden}.hero-background-grid{position:absolute;inset:0;background-image:radial-gradient(circle,#cbd5e1 1px,transparent 1px);background-size:24px 24px;opacity:.25;-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%)}.hero-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1}.hero-content{max-width:600px}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#1e40af1a,#3b82f61a);border:1px solid rgba(30,64,175,.2);border-radius:50px;color:#1e40af;font-size:.875rem;font-weight:600;margin-bottom:1.5rem}.hero-badge svg{color:#1e40af}.hero-title{font-size:4rem;font-weight:800;line-height:1.1;color:#0f172a;margin-bottom:1.5rem;letter-spacing:-.03em}.hero-gradient-text{background:linear-gradient(135deg,#1e40af,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-slogan{font-size:1.25rem;line-height:1.7;color:#64748b;margin-bottom:2.5rem;font-weight:400}.hero-cta-group{display:flex;align-items:center;gap:1.5rem}.btn-primary-large{display:inline-flex;align-items:center;gap:.625rem;padding:1.125rem 2.25rem;background:#1e40af;color:#fff;font-size:1.0625rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;font-family:Inter,sans-serif;box-shadow:0 4px 16px #1e40af4d}.btn-primary-large:hover{background:#1e3a8a;transform:translateY(-2px);box-shadow:0 8px 24px #1e40af66}.btn-primary-large svg{transition:transform .2s ease}.btn-primary-large:hover svg{transform:translate(3px)}.hero-trust-badge{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.875rem}.hero-trust-badge svg{color:#10b981}.hero-visual{position:relative;height:400px}.hero-card{position:absolute;background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.5rem;box-shadow:0 8px 24px #0000000f;display:flex;align-items:center;gap:1rem;transition:all .3s ease;min-width:300px}.hero-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000001a}.hero-card-1{top:20px;left:0;animation:floatCard1 6s ease-in-out infinite}.hero-card-2{top:140px;right:0;animation:floatCard2 6s ease-in-out infinite}.hero-card-3{bottom:40px;left:40px;animation:floatCard3 6s ease-in-out infinite}@keyframes floatCard1{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes floatCard2{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}@keyframes floatCard3{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.hero-card-icon{width:48px;height:48px;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.hero-card-content{flex:1}.hero-card-title{font-size:1rem;font-weight:600;color:#0f172a;margin-bottom:.25rem}.hero-card-subtitle{font-size:.875rem;color:#64748b}.hero-card-status{font-size:1.5rem;color:#10b981}.features-section{padding:5rem 0 7rem;background:linear-gradient(180deg,#f8fafc,#fff 50%);position:relative}.features-section:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,#e2e8f0 50%,transparent 100%)}.section-header{margin-bottom:4rem}.section-eyebrow{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#1e40af;margin-bottom:.75rem}.section-title{font-size:2.5rem;font-weight:700;color:#0f172a;margin:0;letter-spacing:-.02em;line-height:1.2;display:flex;align-items:center;gap:1rem}.title-accent{width:4px;height:48px;background:linear-gradient(180deg,#1e40af,#3b82f6);border-radius:2px;flex-shrink:0}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}.feature-card{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:2.5rem;transition:all .3s ease;position:relative;box-shadow:0 1px 3px #00000005}.feature-card:before{content:"";position:absolute;inset:0;border-radius:20px;padding:1px;background:linear-gradient(135deg,#1e40af26,#3b82f614);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s ease}.feature-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px #1e40af1f;border-color:#1e40af33;background:#fff}.feature-card:hover:before{opacity:1}.feature-icon-wrapper{margin-bottom:1.5rem}.feature-icon{width:64px;height:64px;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 16px #1e40af33}.feature-title{font-size:1.375rem;font-weight:700;color:#0f172a;margin-bottom:.875rem;line-height:1.3}.feature-description{font-size:1rem;line-height:1.7;color:#64748b;margin:0}.cta-section{padding:6rem 0;background:linear-gradient(135deg,#1e40af,#1e3a8a);position:relative;overflow:hidden}.cta-section:before{content:"";position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.cta-section:after{content:"";position:absolute;bottom:-30%;left:-10%;width:40%;height:150%;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);pointer-events:none}.cta-content{max-width:700px;margin:0 auto;text-align:center;position:relative;z-index:1}.cta-title{font-size:3rem;font-weight:800;color:#fff;margin-bottom:1.25rem;letter-spacing:-.02em;line-height:1.2}.cta-description{font-size:1.25rem;color:#fffffff2;margin-bottom:2.5rem;line-height:1.7}.btn-cta-white{display:inline-flex;align-items:center;gap:.625rem;padding:1.125rem 2.5rem;background:#fff;color:#1e40af;font-size:1.0625rem;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;font-family:Inter,sans-serif;box-shadow:0 4px 20px #00000026}.btn-cta-white:hover{background:#f8fafc;transform:translateY(-2px);box-shadow:0 8px 28px #00000040}.btn-cta-white svg{transition:transform .2s ease}.btn-cta-white:hover svg{transform:translate(3px)}.landing-footer{padding:3rem 0;background:#0f172a}.footer-content{display:flex;justify-content:space-between;align-items:center}.footer-brand{max-width:400px}.footer-logo{height:32px;width:auto;margin-bottom:.75rem;filter:brightness(0) invert(1);opacity:.9}.footer-tagline{color:#94a3b8;font-size:.875rem;line-height:1.6;margin:0}.footer-legal{text-align:right}.footer-legal p{color:#64748b;font-size:.8125rem;margin:0}@media (max-width: 1200px){.hero-layout{grid-template-columns:1fr;gap:3rem}.hero-visual{display:none}.hero-title{font-size:3.5rem}.features-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.landing-container{padding:0 1.5rem}.landing-header-content{height:56px}.landing-logo{height:32px}.btn-signin{padding:.5rem 1.25rem;font-size:.875rem}.hero-section{padding:3rem 0 4rem}.hero-title{font-size:2.5rem}.hero-slogan{font-size:1.125rem}.hero-cta-group{flex-direction:column;align-items:flex-start}.btn-primary-large{width:100%;justify-content:center}.features-section{padding:3.5rem 0 5rem}.section-header{margin-bottom:3rem}.section-title{font-size:2rem}.title-accent{height:40px}.features-grid{grid-template-columns:1fr;gap:1.5rem}.feature-card{padding:2rem}.cta-section{padding:4rem 0}.cta-title{font-size:2.25rem}.cta-description{font-size:1.125rem}.footer-content{flex-direction:column;gap:2rem;text-align:center}.footer-brand{max-width:100%}.footer-legal{text-align:center}}@media (max-width: 480px){.hero-title{font-size:2rem}.hero-slogan{font-size:1rem}.btn-primary-large{padding:1rem 1.75rem;font-size:1rem}.section-header{margin-bottom:2.5rem}.section-eyebrow{font-size:.75rem}.section-title{font-size:1.625rem;gap:.75rem}.title-accent{width:3px;height:32px}.cta-title{font-size:1.875rem}.feature-card{padding:1.75rem}.feature-title{font-size:1.125rem}}.no-access-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f9fafb;padding:2rem}.no-access-container{background:#fff;border-radius:16px;padding:0;max-width:520px;width:100%;box-shadow:0 4px 6px #0000000d,0 10px 20px #00000014;overflow:hidden}.no-access-header{background:linear-gradient(135deg,#3b82f6,#2563eb);padding:2.5rem 2rem;text-align:center;color:#fff}.no-access-icon{color:#fbbf24;margin-bottom:1rem;display:flex;justify-content:center}.no-access-container h1{font-size:1.75rem;font-weight:700;color:#fff;margin:0}.user-info{background:#f3f4f6;padding:1.25rem 2rem;text-align:center;border-bottom:1px solid #e5e7eb}.user-name{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0 0 .25rem}.user-email{font-size:.875rem;color:#6b7280;margin:0}.message{padding:2rem;color:#4b5563;line-height:1.6;text-align:center;border-bottom:1px solid #e5e7eb}.message p{margin:0}.request-form{padding:2rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-textarea{width:100%;padding:.75rem;font-size:.9375rem;border:1px solid #d1d5db;border-radius:8px;resize:vertical;font-family:inherit;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-textarea:disabled{background:#f3f4f6;cursor:not-allowed}.form-textarea::placeholder{color:#9ca3af}.submit-success{margin-top:1rem;padding:.75rem;background:#d1fae5;color:#065f46;border-radius:6px;font-size:.875rem;line-height:1.4}.submit-error{margin-top:1rem;padding:.75rem;background:#fee2e2;color:#991b1b;border-radius:6px;font-size:.875rem;line-height:1.4}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-primary:disabled{background:#93c5fd;cursor:not-allowed}.btn-submit{width:100%;margin-top:1rem;padding:.875rem 1.5rem;font-size:1rem}.footer-actions{padding:1.5rem 2rem;text-align:center;background:#f9fafb;border-top:1px solid #e5e7eb}.btn-link{display:inline-flex;align-items:center;gap:.375rem;background:none;border:none;color:#6b7280;font-size:.875rem;cursor:pointer;padding:.5rem;transition:color .2s}.btn-link:hover{color:#374151}.help-text{padding:1.5rem 2rem;font-size:.8125rem;color:#6b7280;text-align:center;background:#fafafa}.help-text p{margin:0;line-height:1.5}@media (max-width: 640px){.no-access-screen{padding:1rem}.no-access-header{padding:2rem 1.5rem}.no-access-container h1{font-size:1.5rem}.user-info,.message,.request-form,.footer-actions,.help-text{padding-left:1.5rem;padding-right:1.5rem}}.admin-users-screen{padding:2rem;max-width:1400px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-title{display:flex;align-items:center;gap:.75rem}.admin-title h1{font-size:1.875rem;font-weight:700;color:#1f2937;margin:0}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.stat-value{font-size:2.25rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.stat-label{font-size:.875rem;color:#6b7280;font-weight:500}.users-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;margin-bottom:1.5rem}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.users-table th{padding:1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#6b7280;letter-spacing:.05em}.users-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s}.users-table tbody tr:hover{background:#f9fafb}.users-table tbody tr.inactive-row{opacity:.6}.users-table td{padding:1rem;font-size:.875rem}.user-cell{display:flex;align-items:center;gap:.75rem}.user-avatar-small{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.user-name{font-weight:600;color:#1f2937}.user-email{font-size:.75rem;color:#6b7280}.provider-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;color:#fff}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.role-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.role-badge.admin{background:#fef3c7;color:#92400e}.role-badge.user{background:#e0e7ff;color:#3730a3}.usage-cell{display:flex;flex-direction:column;gap:.25rem}.usage-tokens{font-size:.75rem;color:#6b7280}.access-request-cell{display:flex;align-items:center;gap:.5rem;max-width:250px}.access-request-cell svg{flex-shrink:0;color:#667eea}.request-message{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.875rem;color:#374151}.no-message{color:#9ca3af;font-style:italic}.quota-cell{display:flex;align-items:center;gap:.5rem}.quota-display{flex:1}.quota-display span{font-weight:600;color:#1f2937}.quota-display .quota-exceeded{color:#dc2626;font-weight:700}.quota-edit-cell{display:flex;flex-direction:column;gap:.5rem}.quota-input{width:100px;padding:.375rem .5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;font-family:inherit}.quota-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.quota-input:disabled{background:#f3f4f6;cursor:not-allowed}.quota-edit-buttons{display:flex;gap:.25rem}.action-buttons{display:flex;gap:.5rem}.btn,.btn-icon{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:none;border-radius:6px;cursor:pointer;transition:all .2s;font-weight:500}.btn{padding:.625rem 1rem;font-size:.875rem}.btn-icon{padding:.5rem;width:32px;height:32px}.btn-primary,.btn-icon.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5568d3}.btn-secondary{background:#e5e7eb;color:#374151}.btn-secondary:hover{background:#d1d5db}.btn-success,.btn-icon.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.btn-danger,.btn-icon.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-warning,.btn-icon.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.btn:disabled,.btn-icon:disabled{opacity:.5;cursor:not-allowed}.admin-loading,.admin-error,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#6b7280;gap:1rem}.admin-help{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;color:#92400e}.admin-help p{margin:0;font-size:.875rem;line-height:1.5}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 1024px){.users-table{font-size:.8125rem}.users-table th,.users-table td{padding:.75rem}}@media (max-width: 768px){.admin-users-screen{padding:1rem}.admin-stats{grid-template-columns:1fr}.users-table-container{overflow-x:auto}.users-table{min-width:900px}}.app{display:flex;height:100vh;width:100vw;overflow:hidden;background:var(--bg-primary)}.app-nav{width:280px;height:100vh;background:var(--bg-elevated);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;padding:var(--space-6);flex-shrink:0;overflow:hidden;z-index:100;box-shadow:var(--shadow-sm)}.app-logo{margin:0 0 var(--space-8) 0;padding:var(--space-2) 0;flex-shrink:0}.app-logo img{width:100%;max-width:200px;height:auto;display:block}.app-nav ul{list-style:none;padding:0;margin:0;flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;padding-right:var(--space-2);margin-right:calc(-1 * var(--space-2))}.app-nav ul::-webkit-scrollbar{width:6px}.app-nav ul::-webkit-scrollbar-track{background:transparent}.app-nav ul::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}.app-nav ul::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.app-nav li{margin-bottom:var(--space-2)}.app-nav a{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:var(--text-secondary);text-decoration:none;font-size:var(--text-sm);font-weight:500;transition:all var(--transition-fast);position:relative}.app-nav a svg{width:20px;height:20px;flex-shrink:0}.app-nav a:hover{background:var(--bg-hover);color:var(--text-primary)}.app-nav a.active{background:var(--bg-elevated);color:var(--color-primary)}.app-nav a.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--color-primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.user-info{margin-top:auto;padding-top:var(--space-6);flex-shrink:0}.user-info-content{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;margin-bottom:var(--space-3)}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-xs);color:#fff;flex-shrink:0}.user-details{flex:1;min-width:0}.user-name{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:var(--text-xs);color:var(--text-tertiary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);background:transparent;border:1px solid var(--border-default);color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.logout-btn:hover{background:var(--bg-hover);border-color:var(--border-strong);color:var(--text-primary)}.logout-btn svg{width:16px;height:16px}.app-main{flex:1;height:100vh;overflow-y:auto;overflow-x:hidden;background:var(--bg-primary);position:relative}.screen-container{max-width:1400px;margin:0 auto}.upload-screen,.preview-screen,.asbuilt-screen,.compare-screen,.library-screen,.settings-screen{animation:fadeIn var(--transition-base) ease-out}.card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.card:hover{border-color:var(--border-default)}.card-header{margin-bottom:var(--space-6)}.card-title{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-2)}.card-description{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:0}button{font-family:var(--font-sans);font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.btn{padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;transition:all var(--transition-fast)}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background:var(--color-success-light);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs)}input[type=text],input[type=email],input[type=password],input[type=search],textarea,select{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-sm);font-family:var(--font-sans);transition:all var(--transition-fast)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a}input::placeholder,textarea::placeholder{color:var(--text-muted)}input[type=checkbox]{width:18px;height:18px;border:2px solid var(--border-default);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);appearance:none;background:var(--bg-elevated);position:relative}input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}input[type=checkbox]:checked:after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;background:var(--bg-elevated);color:var(--text-secondary)}.badge-primary{background:#6366f11a;color:var(--color-primary-light)}.badge-success{background:#10b9811a;color:var(--color-success-light)}.badge-warning{background:#f59e0b1a;color:var(--color-warning-light)}.badge-error{background:#ef44441a;color:var(--color-error-light)}.alert{padding:var(--space-4) var(--space-6);border-radius:var(--radius-lg);margin-bottom:var(--space-6);display:flex;align-items:flex-start;gap:var(--space-3);animation:fadeIn var(--transition-base) ease-out}.alert-success{background:#10b9811a;border:1px solid rgba(16,185,129,.2);color:var(--color-success-light)}.alert-error{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:var(--color-error-light)}.alert-warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);color:var(--color-warning-light)}.alert-info{background:#6366f11a;border:1px solid rgba(99,102,241,.2);color:var(--color-primary-light)}progress{width:100%;height:8px;border-radius:var(--radius-full);overflow:hidden;appearance:none;border:none;background:var(--bg-elevated)}progress::-webkit-progress-bar{background:var(--bg-elevated);border-radius:var(--radius-full)}progress::-webkit-progress-value{background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:var(--radius-full);transition:width var(--transition-base)}progress::-moz-progress-bar{background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:var(--radius-full)}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 0%,var(--bg-hover) 50%,var(--bg-elevated) 100%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-text{height:16px;margin-bottom:var(--space-2)}.skeleton-title{height:24px;width:60%;margin-bottom:var(--space-4)}.empty-state{text-align:center;padding:var(--space-16) var(--space-8)}.empty-state-icon{width:64px;height:64px;margin:0 auto var(--space-6);color:var(--text-muted)}.empty-state-title{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-6);max-width:400px;margin-left:auto;margin-right:auto}.mobile-breadcrumb{display:none;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm);color:var(--text-secondary);flex-shrink:0;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000d}.mobile-breadcrumb svg{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.mobile-breadcrumb .breadcrumb-active{color:var(--color-primary);font-weight:600}@media (max-width: 1024px){.app-nav{width:240px}.app-main{padding:var(--space-6)}}@media (max-width: 768px){.app{flex-direction:column}.app-nav{display:none}.mobile-breadcrumb{display:flex!important}.app-main{height:calc(100vh - 57px)}}
