@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Fira+Code:wght@400;500&display=swap";:root{--brand: #0ea5e9;--brand-light: #38bdf8;--brand-dark: #0284c7;--brand-glow: rgba(14, 165, 233, .2);--bg-base: #0f0f12;--bg-surface: #16161a;--bg-elevated: #1e1e24;--bg-hover: #26262e;--bg-active: #2e2e38;--border: #2a2a32;--border-light: #3a3a44;--border-focus: var(--brand);--text: #f0f0f2;--text-secondary: #9898a4;--text-muted: #6a6a76;--text-inverse: #0f0f12;--success: #22c55e;--success-bg: rgba(34, 197, 94, .12);--warning: #eab308;--warning-bg: rgba(234, 179, 8, .12);--error: #ef4444;--error-bg: rgba(239, 68, 68, .12);--conf-high: #22c55e;--conf-high-bg: rgba(34, 197, 94, .15);--conf-medium: #eab308;--conf-medium-bg: rgba(234, 179, 8, .15);--conf-low: #f97316;--conf-low-bg: rgba(249, 115, 22, .15);--conf-manual: rgba(255, 255, 255, .6);--conf-manual-bg: rgba(255, 255, 255, .08);--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 12px 32px rgba(0,0,0,.5);--shadow-glow: 0 0 40px var(--brand-glow);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--sidebar-width: 260px;--text-tertiary: #505058;--danger: #ef4444}[data-theme=light]{--bg-base: #f8f9fa;--bg-surface: #ffffff;--bg-elevated: #ffffff;--bg-hover: #f0f1f3;--bg-active: #e8e9eb;--border: #e0e2e5;--border-light: #d0d2d5;--border-focus: var(--brand);--text: #1a1a1f;--text-secondary: #52525b;--text-muted: #71717a;--text-tertiary: #a1a1aa;--text-inverse: #f0f0f2;--success: #16a34a;--success-bg: rgba(22, 163, 74, .1);--warning: #ca8a04;--warning-bg: rgba(202, 138, 4, .1);--error: #dc2626;--error-bg: rgba(220, 38, 38, .1);--conf-high: #16a34a;--conf-high-bg: rgba(22, 163, 74, .12);--conf-medium: #ca8a04;--conf-medium-bg: rgba(202, 138, 4, .12);--conf-low: #ea580c;--conf-low-bg: rgba(234, 88, 12, .12);--conf-manual: rgba(0, 0, 0, .5);--conf-manual-bg: rgba(0, 0, 0, .06);--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 12px 32px rgba(0,0,0,.12);--shadow-glow: 0 0 40px rgba(14, 165, 233, .15);--brand-glow: rgba(14, 165, 233, .15)}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-base);color:var(--text);line-height:1.5;font-size:14px;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:20px;border-bottom:1px solid var(--border)}.sidebar-logo{display:flex;align-items:center;gap:10px}.sidebar-logo.clickable{cursor:pointer;padding:6px 10px;margin:-6px -10px;border-radius:var(--radius-md);transition:background .15s ease}.sidebar-logo.clickable:hover{background:var(--bg-hover)}.logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-light) 100%);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:var(--shadow-glow)}.logo-name{font-size:18px;font-weight:700;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-section{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:16px 12px}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;padding:0 8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.btn-icon-sm{width:22px;height:22px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s}.btn-icon-sm:hover{background:var(--brand);border-color:var(--brand);color:#fff}.project-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.project-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);cursor:pointer;transition:background .1s;position:relative}.project-item:hover{background:var(--bg-elevated)}.project-item.active{background:var(--brand-glow);border:1px solid rgba(14,165,233,.3)}.project-icon{font-size:16px;opacity:.7}.project-info{flex:1;min-width:0}.project-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-name-input{width:100%;background:var(--bg-base);border:1px solid var(--brand);border-radius:4px;padding:4px 8px;font-size:13px;color:var(--text);outline:none}.project-meta{font-size:11px;color:var(--text-muted);margin-top:2px}.project-menu-wrapper{position:relative}.project-menu-btn{width:24px;height:24px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:4px;opacity:0;transition:all .1s}.project-item:hover .project-menu-btn{opacity:1}.project-menu-btn:hover{background:var(--bg-active);color:var(--text)}.project-menu{position:absolute;top:100%;right:0;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:6px;min-width:120px;z-index:100;box-shadow:var(--shadow-lg)}.project-menu button{display:block;width:100%;padding:8px 12px;background:transparent;border:none;color:var(--text);font-size:12px;text-align:left;cursor:pointer;border-radius:4px}.project-menu button:hover{background:var(--bg-hover)}.project-menu button.danger:hover{background:var(--error-bg);color:var(--error)}.sidebar-footer{padding:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:0}.avatar{width:32px;height:32px;background:var(--bg-elevated);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--text-secondary)}.user-info{flex:1}.user-name{font-size:13px;font-weight:500}.user-plan{font-size:11px;color:var(--text-muted)}.btn-upgrade{width:100%;padding:10px;background:linear-gradient(135deg,var(--brand) 0%,#8b5cf6 100%);border:none;border-radius:var(--radius-md);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.btn-upgrade:hover:not(.disabled){transform:translateY(-1px);box-shadow:0 4px 16px #0ea5e94d}.btn-upgrade.disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}.btn-guide{width:100%;padding:10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;margin-top:8px;transition:all .15s}.btn-guide:hover{background:var(--bg-hover);color:var(--text);border-color:var(--brand)}.btn-theme-toggle{width:100%;padding:10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;margin-top:8px;transition:all .2s}.btn-theme-toggle:hover{background:var(--bg-hover);color:var(--text);border-color:var(--warning)}.main-area{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.header-left{display:flex;align-items:center;gap:16px}.project-title{font-size:16px;font-weight:600}.header-status{display:flex;align-items:center;gap:6px;padding:5px 12px;background:var(--bg-elevated);border-radius:999px;font-size:12px;color:var(--text-secondary)}.status-dot{width:6px;height:6px;border-radius:50%}.header-actions{display:flex;align-items:center;gap:10px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-md);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;border:none;outline:none;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-light) 100%);color:#fff;box-shadow:0 2px 8px var(--brand-glow)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px var(--brand-glow)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.parse-glow{animation:parseGlow 1.5s ease-in-out infinite;position:relative}@keyframes parseGlow{0%,to{box-shadow:0 0 5px var(--brand),0 0 10px var(--brand),0 0 15px var(--brand-light)}50%{box-shadow:0 0 10px var(--brand),0 0 20px var(--brand),0 0 30px var(--brand-light)}}.parse-glow:after{content:"← Click to extract fields";position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:8px;font-size:10px;color:var(--brand-light);white-space:nowrap;animation:fadeInOut 2s ease-in-out infinite}@keyframes fadeInOut{0%,to{opacity:.5}50%{opacity:1}}.automap-glow{animation:automapGlow 2s ease-in-out infinite}@keyframes automapGlow{0%,to{box-shadow:0 0 3px var(--brand),0 0 6px #0ea5e94d}50%{box-shadow:0 0 8px var(--brand),0 0 16px #0ea5e980}}.btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--brand)}.btn-danger{background:#ef444426;color:var(--error);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444440;border-color:var(--error)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:6px 10px}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text)}.btn-sm{padding:6px 12px;font-size:12px}.workspace-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px}.workspace-content{display:flex;flex-direction:column;gap:16px;min-height:min-content}.collapsible-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.collapsible-section.resizing{-webkit-user-select:none;user-select:none}.section-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-elevated);border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.section-header:hover{background:var(--bg-hover)}.section-header-left{display:flex;align-items:center;gap:10px}.collapse-icon{font-size:10px;color:var(--text-muted);transition:transform .2s}.collapse-icon.expanded{transform:rotate(90deg)}.section-header h3{font-size:13px;font-weight:600;margin:0}.section-badge{padding:3px 10px;background:var(--brand-glow);border:1px solid rgba(14,165,233,.3);border-radius:999px;font-size:11px;font-weight:500;color:var(--brand-light)}.section-content{overflow:auto;padding:12px}.resize-handle{height:8px;background:var(--bg-elevated);border-top:1px solid var(--border);cursor:ns-resize;display:flex;align-items:center;justify-content:center;transition:background .15s}.resize-handle:hover{background:var(--bg-hover)}.resize-bar{width:40px;height:3px;background:var(--border-light);border-radius:2px}.collapsible-section.collapsed .section-header{border-bottom:none}.input-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;height:100%;min-height:0}.input-row>*{min-height:0;display:flex;flex-direction:column}.config-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;height:100%}.config-row.config-row-3{grid-template-columns:1.5fr 1fr 1fr}@media(max-width:1200px){.config-row.config-row-3{grid-template-columns:1fr}}.mapping-section-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.mapping-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.mapping-card.mapping-card-warning{border-color:#eab3084d}.mapping-card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-base);border-bottom:1px solid var(--border)}.mapping-card-header h4{margin:0;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px}.mapping-badge{background:var(--brand);color:#fff;padding:3px 8px;border-radius:10px;font-size:11px;font-weight:600;min-width:20px;text-align:center}.mapping-badge.warning{background:var(--warning);color:var(--text-inverse)}.mapping-card-body{padding:12px 16px;max-height:280px;overflow-y:auto}.output-config-section{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px}.config-panel{display:flex;flex-direction:column;background:var(--bg-base);border-radius:var(--radius-md);overflow:hidden}.config-panel-header{padding:8px 12px;background:var(--bg-elevated);border-bottom:1px solid var(--border)}.config-panel-header h4{font-size:12px;font-weight:600;margin:0;color:var(--text-secondary)}.config-panel-body{flex:1;overflow-y:auto;padding:10px}.mapping-content{display:flex;flex-direction:column;height:100%}.mapping-stats-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg-base);border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary);margin-bottom:10px;flex-shrink:0}.mapping-stats-left{display:flex;gap:20px;flex-wrap:wrap}.mapping-stats-right{display:flex;gap:8px;align-items:center}.mapping-stats-bar strong{color:var(--brand-light)}.card{display:flex;flex-direction:column;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;height:100%;min-height:0;box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(135deg,var(--bg-elevated),var(--bg-surface));border-bottom:1px solid var(--border);flex-shrink:0}.card-title{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;letter-spacing:-.01em}.badge{padding:3px 8px;border-radius:999px;font-size:10px;font-weight:600;text-transform:uppercase}.badge-source{background:var(--success-bg);color:var(--success)}.badge-target{background:var(--brand-glow);color:var(--brand-light)}.badge-docs{background:var(--warning-bg);color:var(--warning)}.card-body{display:flex;flex-direction:column;flex:1;padding:14px;min-height:0;overflow:visible;gap:0}.card-controls{display:flex;gap:8px;align-items:center}.format-select{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 10px;color:var(--text);font-size:12px;cursor:pointer}.format-select:focus{outline:none;border-color:var(--brand)}.code-input{width:100%;flex:1;min-height:100px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;color:var(--text);font-family:Fira Code,monospace;font-size:12px;line-height:1.6;resize:none;transition:border-color .2s,box-shadow .2s}.code-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}.code-input::placeholder{color:var(--text-muted);font-style:italic}.upload-zone{margin-top:10px;border:1px dashed var(--border-light);border-radius:var(--radius-md);padding:12px 16px;text-align:center;cursor:pointer;font-size:12px;color:var(--text-muted);transition:all .2s;flex-shrink:0;background:var(--bg-base)}.upload-zone:hover{border-color:var(--brand);background:var(--brand-glow);color:var(--text-secondary)}.upload-zone input{display:none}.upload-zone span{color:var(--brand-light);font-weight:500}.anonymize-toast{margin-top:10px;padding:10px 14px;background:linear-gradient(135deg,#22c55e26,#22c55e14);border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-sm);color:#22c55e;font-size:12px;font-weight:500;animation:fadeIn .3s ease-out}.error-msg{margin-top:10px;padding:10px 12px;background:linear-gradient(135deg,var(--error-bg),rgba(239,68,68,.08));border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);color:var(--error);font-size:12px;flex-shrink:0;line-height:1.4}.format-hint{margin-top:10px;padding:10px 12px;background:linear-gradient(135deg,var(--brand-glow),rgba(14,165,233,.08));border:1px solid rgba(14,165,233,.2);border-radius:var(--radius-sm);color:var(--brand-light);font-size:11px;flex-shrink:0;line-height:1.4}.format-hint.ai-hint{display:flex;align-items:center;gap:10px}.ai-badge{background:var(--brand);color:#fff;padding:3px 8px;border-radius:4px;font-weight:600;font-size:10px;white-space:nowrap}.supporting-docs-section{margin-top:12px;border-top:1px solid var(--border);padding-top:12px;flex-shrink:0}.docs-toggle{display:flex;align-items:center;gap:8px;background:transparent;border:none;color:var(--text-secondary);font-size:12px;cursor:pointer;padding:6px 10px;margin:-6px -10px;border-radius:var(--radius-sm);transition:all .15s;width:calc(100% + 20px)}.docs-toggle:hover{color:var(--text);background:var(--bg-hover)}.toggle-icon{font-size:9px;transition:transform .2s;opacity:.6}.toggle-icon.open{transform:rotate(90deg)}.docs-count{background:var(--brand);color:var(--text-inverse);font-size:9px;font-weight:700;padding:2px 7px;border-radius:10px;margin-left:auto}.docs-content{margin-top:10px;padding:12px;background:linear-gradient(135deg,var(--bg-base),rgba(14,165,233,.03));border:1px solid var(--border);border-radius:var(--radius-md)}.docs-hint{font-size:11px;color:var(--text-muted);margin-bottom:12px;line-height:1.5;padding:0 2px}.doc-upload-zone{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border:1px dashed var(--border-light);border-radius:var(--radius-sm);color:var(--text-muted);font-size:12px;cursor:pointer;transition:all .2s;background:var(--bg-surface)}.doc-upload-zone:hover{border-color:var(--brand);color:var(--brand-light);background:var(--brand-glow);border-style:solid}.doc-upload-zone input{display:none}.doc-error{padding:10px 12px;background:linear-gradient(135deg,var(--error-bg),rgba(239,68,68,.08));border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);color:var(--error);font-size:12px;margin-bottom:10px;line-height:1.4}.docs-list{display:flex;flex-direction:column;gap:6px;max-height:140px;overflow-y:auto;margin-bottom:12px}.doc-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-surface);border-radius:var(--radius-sm);font-size:12px;border:1px solid var(--border);transition:all .15s}.doc-item:hover{border-color:var(--border-light);background:var(--bg-elevated)}.doc-type{font-size:10px;color:var(--text-secondary);white-space:nowrap;background:var(--bg-base);padding:3px 6px;border-radius:4px}.doc-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;color:var(--text)}.doc-size{font-size:10px;color:var(--text-muted);font-family:Fira Code,monospace;background:var(--bg-base);padding:2px 6px;border-radius:4px}.doc-remove{background:transparent;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;padding:4px 6px;line-height:1;transition:all .15s;border-radius:4px}.doc-remove:hover{color:var(--error);background:var(--error-bg)}.doc-icon{font-size:14px}.doc-name-old{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-remove{width:20px;height:20px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:4px;opacity:0;transition:all .1s}.doc-item:hover .doc-remove{opacity:1}.doc-remove:hover{background:var(--error);color:#fff}.add-doc-btn{margin-top:8px;width:100%}.mapping-section{flex:1;display:flex;flex-direction:column;min-height:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.mapping-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-elevated);border-bottom:1px solid var(--border);flex-shrink:0}.mapping-toolbar-left{display:flex;align-items:center;gap:20px}.mapping-toolbar h2{font-size:14px;font-weight:600}.mapping-stats{display:flex;gap:16px;font-size:12px;color:var(--text-secondary)}.mapping-stats strong{color:var(--brand-light)}.mapping-canvas-wrapper{display:flex;flex-direction:column;flex:1;min-height:0;height:100%}.canvas-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 12px;background:var(--bg-elevated);border-bottom:1px solid var(--border);flex-shrink:0}.coverage-stats{display:flex;align-items:center;gap:10px;font-size:12px}.coverage-label{color:var(--text-secondary);font-weight:500}.coverage-bar{width:100px;height:6px;background:var(--bg-base);border-radius:3px;overflow:hidden}.coverage-fill{height:100%;background:linear-gradient(90deg,var(--success),var(--brand));transition:width .3s ease}.coverage-text{font-weight:600;color:var(--text)}.coverage-detail{color:var(--text-muted);font-size:11px}.toolbar-actions{display:flex;gap:6px}.toolbar-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .15s}.toolbar-btn:hover{background:var(--bg-hover);color:var(--text)}.toolbar-btn.active{background:var(--brand-glow);border-color:var(--brand);color:var(--brand-light)}.toolbar-btn.help-btn{width:28px;padding:4px;justify-content:center}.mapping-canvas{flex:1;display:flex;min-height:0;height:100%;background:var(--bg-base);position:relative;border-radius:var(--radius-md);overflow:hidden}.field-panel{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-surface)}.field-panel-header{padding:10px 12px;background:var(--bg-elevated);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:8px;flex-shrink:0}.panel-header-top{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.field-search{width:100%;padding:6px 10px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:11px;color:var(--text)}.field-search:focus{outline:none;border-color:var(--brand)}.field-search::placeholder{color:var(--text-muted)}.panel-dot{width:8px;height:8px;border-radius:50%}.panel-dot-source{background:var(--success)}.panel-dot-target{background:var(--brand)}.field-scroll{flex:1;overflow-y:auto;padding:8px}.arrow-zone{width:240px;flex-shrink:0;position:relative;background:linear-gradient(90deg,var(--bg-surface) 0%,var(--bg-base) 15%,var(--bg-base) 85%,var(--bg-surface) 100%);border-left:1px solid var(--border);border-right:1px solid var(--border)}.arrow-svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}.arrow-path{fill:none;stroke-width:2;stroke-linecap:round;transition:stroke .2s}.arrow-path.conf-high{stroke:var(--conf-high)}.arrow-path.conf-medium{stroke:var(--conf-medium)}.arrow-path.conf-low{stroke:var(--conf-low)}.arrow-path.conf-manual{stroke:var(--conf-manual)}.arrow-path.animated{stroke-dasharray:6 4;animation:arrowFlow .5s linear infinite}@keyframes arrowFlow{to{stroke-dashoffset:-10}}.arrow-labels{position:absolute;inset:0;overflow:visible}.arrow-label{position:absolute;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px 6px;display:flex;align-items:center;gap:4px;box-shadow:var(--shadow-sm);transition:all .15s;z-index:10}.arrow-label.conf-high{border-color:var(--conf-high)}.arrow-label.conf-medium{border-color:var(--conf-medium)}.arrow-label.conf-low{border-color:var(--conf-low)}.arrow-label.conf-manual{border-color:var(--conf-manual)}.arrow-label:hover{box-shadow:var(--shadow-md);z-index:20}.arrow-label input{background:transparent;border:none;color:var(--text);font-size:11px;width:90px;text-align:center;outline:none}.arrow-label input::placeholder{color:var(--text-muted)}.arrow-label .del-btn{width:16px;height:16px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:3px;font-size:10px;opacity:0;transition:all .1s;display:flex;align-items:center;justify-content:center}.arrow-label:hover .del-btn{opacity:1}.arrow-label .del-btn:hover{background:var(--error);color:#fff}.field-row{display:flex;align-items:center;gap:8px;padding:8px 10px;margin:2px 0;border-radius:var(--radius-sm);cursor:pointer;transition:all .1s;position:relative;border:1px solid transparent}.field-row:hover{background:var(--bg-hover)}.field-row.selected{background:var(--brand-glow);border-color:var(--brand)}.field-row.mapped{background:var(--success-bg);border-color:#22c55e4d}.field-row.mapped.conf-medium{background:var(--warning-bg);border-color:#eab3084d}.field-row.mapped.conf-low{background:var(--conf-low-bg);border-color:#f973164d}.field-row.mapped.conf-manual{background:var(--conf-manual-bg);border-color:#fff3}.field-row.enriched{background:#8b5cf626;border-color:#8b5cf666}.field-row.unmapped-target{border-left:3px solid rgba(239,68,68,.5)}.field-row.unmapped-target:hover .enrich-btn{opacity:1}.enrich-btn{padding:2px 6px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:10px;cursor:pointer;opacity:.5;transition:all .15s ease;flex-shrink:0}.enrich-btn:hover{opacity:1;background:var(--brand);border-color:var(--brand)}.enrich-btn.active{opacity:1;background:#8b5cf64d;border-color:#8b5cf680}.field-row.highlighted{animation:highlightPulse 2s ease-out;box-shadow:0 0 0 2px var(--brand),0 0 12px var(--brand-glow)}@keyframes highlightPulse{0%{box-shadow:0 0 0 3px var(--brand),0 0 20px var(--brand-glow)}to{box-shadow:0 0 0 2px var(--brand),0 0 12px var(--brand-glow)}}.field-row .handle{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--brand);border:2px solid var(--bg-surface);z-index:5}.field-row.source-field .handle{right:-5px}.field-row.target-field .handle{left:-5px}.field-row.not-mappable{opacity:.5;background:#ef444414;border-color:#ef444433;cursor:not-allowed!important}.field-row.not-mappable:hover{background:#ef44441f}.not-mappable-indicator{font-size:12px;color:var(--error);margin-left:auto;font-weight:700}.field-icon{width:22px;height:22px;background:var(--bg-elevated);border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text-muted);font-weight:600;flex-shrink:0}.field-details{flex:1;min-width:0}.field-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field-path{font-size:10px;color:var(--text-muted);font-family:Fira Code,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mandatory-badge{color:#f59e0b;font-weight:700;margin-left:4px;font-size:12px;background:#f59e0b33;padding:1px 4px;border-radius:3px}.field-row.mandatory-field{border-left:3px solid #f59e0b;background:#f59e0b14}.field-row.mandatory-field:hover{background:#f59e0b1f}.field-meta-indicators{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.meta-tag{font-size:9px;padding:2px 5px;border-radius:4px;font-family:Fira Code,monospace;display:inline-flex;align-items:center;gap:3px;cursor:help;position:relative;transition:all .15s}.meta-tag:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000004d}.meta-tag .meta-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:8px 12px;font-size:11px;font-family:Inter,sans-serif;color:var(--text);white-space:pre-wrap;max-width:280px;min-width:150px;z-index:1000;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;pointer-events:none;line-height:1.5}.meta-tag .meta-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--border-light)}.meta-tag:hover .meta-tooltip{opacity:1;visibility:visible}.meta-tooltip-title{font-weight:600;color:var(--text);margin-bottom:4px;display:block}.meta-tooltip-content{color:var(--text-secondary)}.meta-tag.format{background:#6366f133;color:#818cf8;border:1px solid rgba(99,102,241,.3)}.meta-tag.length{background:#0ea5e933;color:#38bdf8;border:1px solid rgba(14,165,233,.3)}.meta-tag.enum{background:#8b5cf633;color:#a78bfa;border:1px solid rgba(139,92,246,.3)}.meta-tag.rules{background:#f59e0b33;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.field-type{padding:2px 6px;background:var(--bg-elevated);border-radius:4px;font-size:9px;font-weight:600;text-transform:uppercase;color:var(--text-muted);flex-shrink:0}.selection-hint{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background:var(--brand);color:#fff;padding:10px 20px;border-radius:var(--radius-lg);font-size:13px;font-weight:600;box-shadow:var(--shadow-lg);z-index:100;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:var(--shadow-lg),0 0 0 0 var(--brand-glow)}50%{box-shadow:var(--shadow-lg),0 0 0 8px transparent}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:var(--text-muted);padding:32px}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state h3{font-size:16px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.empty-state p{font-size:13px;max-width:300px}.bottom-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;flex-shrink:0}.panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-elevated);border-bottom:1px solid var(--border)}.panel-header h3{font-size:13px;font-weight:600}.panel-body{padding:12px;max-height:140px;overflow-y:auto}.mappings-empty{text-align:center;padding:16px;color:var(--text-muted);font-size:12px}.mapping-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-base);border-radius:var(--radius-sm);margin-bottom:6px;border-left:3px solid var(--conf-manual)}.mapping-row.conf-high{border-left-color:var(--conf-high)}.mapping-row.conf-medium{border-left-color:var(--conf-medium)}.mapping-row.conf-low{border-left-color:var(--conf-low)}.mapping-row:last-child{margin-bottom:0}.mapping-group{margin-bottom:8px}.mapping-group.multi-source{background:var(--bg-elevated);border-radius:var(--radius);padding:8px;border:1px solid var(--border)}.mapping-group.multi-source .mapping-row{margin-left:8px;background:var(--bg-base)}.mapping-group-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border)}.group-badge{font-size:10px;font-weight:600;background:var(--brand-glow);color:var(--brand-light);padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}.group-target{font-family:Fira Code,monospace;font-size:11px;color:var(--text-secondary)}.mapping-row.grouped{border-left-width:2px}.mapping-source{color:var(--text-primary);font-weight:500}.mapping-target{color:var(--text-secondary)}.mapping-fields{display:flex;align-items:center;gap:6px;flex-shrink:0;font-size:11px;font-family:Fira Code,monospace;color:var(--text-secondary);min-width:160px}.mapping-arrow{color:var(--brand-light)}.mapping-comment{flex:1;background:transparent;border:1px solid var(--border);border-radius:4px;padding:5px 8px;color:var(--text);font-size:11px;min-width:0}.mapping-comment:focus{outline:none;border-color:var(--brand)}.mapping-del{width:24px;height:24px;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:10px;transition:all .1s}.mapping-del:hover{background:var(--error);border-color:var(--error);color:#fff}.mapping-list-container{display:flex;flex-direction:column;height:100%}.mapping-list-toolbar{display:flex;align-items:center;padding:6px 10px;background:var(--bg-base);border-bottom:1px solid var(--border);flex-shrink:0}.filter-checkbox{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary);cursor:pointer}.filter-checkbox input{accent-color:var(--brand)}.filter-checkbox:hover{color:var(--text)}.mapping-list{flex:1;overflow-y:auto;padding:8px}.mapping-row.clickable{cursor:pointer;transition:all .15s}.mapping-row.clickable:hover{background:var(--bg-hover);transform:translate(2px)}.options-grid{display:flex;flex-direction:column;gap:12px}.option-row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.option-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.options-section{padding:12px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm)}.options-section-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;display:flex;align-items:center;gap:8px}.format-badge{font-size:9px;padding:2px 5px;background:var(--brand-glow);color:var(--brand-light);border-radius:4px;font-weight:600}.option-checks-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.option-check.hint-only{display:flex;align-items:center;gap:6px;background:var(--bg-elevated);padding:6px 10px;border-radius:var(--radius-sm)}.option-check.hint-only .hint-icon{font-size:14px}.option-check.hint-only .hint-text{font-size:11px;color:var(--text-muted)}.instructions-footer{display:flex;justify-content:flex-end;margin-top:4px}.option-field{display:flex;flex-direction:column;gap:4px}.option-field-full{grid-column:1 / -1}.option-checks{display:flex;flex-wrap:wrap;gap:12px}.label-hint{font-weight:400;color:var(--text-tertiary);margin-left:6px}.instructions-input{width:100%;padding:10px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:12px;resize:vertical;min-height:60px;font-family:inherit}.instructions-input:focus{outline:none;border-color:var(--brand)}.instructions-input.has-error{border-color:var(--danger)}.option-error{font-size:11px;color:var(--danger)}.option-field label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.option-field select{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 10px;color:var(--text);font-size:12px}.option-field select:focus{outline:none;border-color:var(--brand)}.option-check{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;grid-column:span 2}.option-check input{width:16px;height:16px;accent-color:var(--brand)}.code-section{display:flex;flex-direction:column;height:100%;overflow:hidden}.code-output-container{display:flex;flex-direction:column;height:100%}.code-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-base);border-bottom:1px solid var(--border);flex-shrink:0}.code-lang-indicator{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg-elevated);border:1px solid;border-radius:999px;font-size:11px}.lang-icon{font-size:12px}.lang-name{font-weight:500;color:var(--text)}.code-actions{display:flex;gap:6px}.code-body{flex:1;overflow:auto;background:#0d1117;border-radius:var(--radius-md)}.code-body pre{margin:0;padding:14px;font-family:Fira Code,monospace;font-size:12px;line-height:1.6;min-height:100%}.code-empty{padding:40px;text-align:center;color:var(--text-muted);font-size:13px;height:100%;display:flex;align-items:center;justify-content:center}.loading-overlay{position:fixed;inset:0;background:#0f0f12d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.loading-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px 48px;text-align:center;box-shadow:var(--shadow-lg)}.popup-overlay{position:fixed;inset:0;background:#0f0f12bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1001;animation:fadeIn .2s ease-out}.popup-content{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:500px;width:90%;animation:slideUp .25s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.popup-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.popup-header h3{margin:0;font-size:16px;font-weight:600}.popup-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);font-size:16px}.popup-close:hover{background:var(--bg-hover);color:var(--text)}.popup-body{padding:20px}.popup-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border)}.help-popup{max-width:450px}.help-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.help-item:last-child{border-bottom:none}.help-color{width:24px;height:24px;border-radius:var(--radius-sm);flex-shrink:0;border:1px solid rgba(255,255,255,.1)}.help-text{flex:1}.help-text strong{display:block;font-size:13px;margin-bottom:2px}.help-text p{margin:0;font-size:12px;color:var(--text-secondary)}.conf-high-bg{background:var(--conf-high)}.conf-medium-bg{background:var(--conf-medium)}.conf-low-bg{background:var(--conf-low)}.conf-manual-bg{background:#ffffff4d;border:1px solid var(--border)}.not-mappable-bg{background:#ef444466}.mandatory-bg{background:#f59e0b80}.confirm-popup .popup-body{text-align:center;padding:24px 20px}.confirm-popup .confirm-icon{font-size:40px;margin-bottom:12px}.confirm-popup .confirm-message{font-size:14px;color:var(--text-secondary);margin:0}.unmapped-warning-popup{max-width:560px;width:90%}.unmapped-warning-popup .popup-body{padding:0}.warning-section{display:flex;gap:16px;padding:20px;border-bottom:1px solid var(--border)}.warning-section:last-child{border-bottom:none}.warning-mandatory{background:#ef44440d}.warning-optional{background:#0ea5e90d}.warning-icon{font-size:24px;flex-shrink:0}.warning-content{flex:1}.warning-content h4{font-size:14px;font-weight:600;margin:0 0 8px;color:var(--text)}.warning-content p{font-size:13px;color:var(--text-secondary);margin:0 0 12px;line-height:1.5}.warning-note{padding:10px 12px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-sm);color:#f59e0b!important;font-size:12px!important}.unmapped-list{list-style:none;padding:0;margin:0 0 12px;max-height:150px;overflow-y:auto;background:var(--bg-base);border-radius:var(--radius-sm);border:1px solid var(--border)}.unmapped-list li{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border);font-size:12px}.unmapped-list li:last-child{border-bottom:none}.unmapped-list .field-name{font-weight:500;color:var(--text)}.unmapped-list .field-path{font-family:Fira Code,monospace;font-size:10px;color:var(--text-muted)}.unmapped-list .more-fields{color:var(--text-muted);font-style:italic;justify-content:center}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.btn-warning:hover{background:linear-gradient(135deg,#d97706,#b45309)}.unmapped-list{display:flex;flex-direction:column;gap:6px;max-height:180px;overflow-y:auto}.unmapped-empty{padding:16px;text-align:center;color:var(--success);font-size:12px}.unmapped-field-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;cursor:pointer;transition:all .15s}.unmapped-field-item:hover{border-color:var(--warning);background:#f59e0b0d}.unmapped-field-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.unmapped-field-item .field-name{font-weight:500;color:var(--text)}.unmapped-field-item .field-path{font-family:Fira Code,monospace;font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unmapped-field-item .enrich-btn-sm{padding:4px 8px;font-size:10px;background:var(--brand);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .15s}.unmapped-field-item .enrich-btn-sm:hover{background:var(--brand-dark)}.unmapped-field-item.clickable{cursor:pointer;transition:background .15s,transform .1s}.unmapped-field-item.clickable:hover{background:#f59e0b26;transform:translate(2px)}.ai-restriction-popup{max-width:480px}.ai-restriction-body{text-align:center;padding:24px}.ai-restriction-icon{font-size:48px;margin-bottom:16px}.ai-restriction-body h4{font-size:18px;color:var(--text);margin-bottom:12px}.ai-restriction-body p{color:var(--text-secondary);font-size:14px;line-height:1.6;margin-bottom:20px}.ai-restriction-benefits{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:20px;text-align:left}.benefit-item{padding:8px 0;color:var(--text);font-size:14px;border-bottom:1px solid var(--border)}.benefit-item:last-child{border-bottom:none}.ai-restriction-cta{font-weight:600;color:var(--brand)!important}.test-runner{display:flex;flex-direction:column;gap:16px;padding:16px}.test-runner-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.test-runner-header h4{margin:0;font-size:16px;color:var(--text)}.guest-badge{font-size:12px;padding:4px 10px;background:var(--surface);border:1px solid var(--border);border-radius:20px;color:var(--text-secondary)}.test-runner-content{display:flex;flex-direction:column;gap:16px}.test-input-section{display:flex;flex-direction:column;gap:8px}.test-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.test-section-header label{font-size:14px;font-weight:600;color:var(--text)}.test-hint{font-size:12px;color:var(--text-secondary)}.test-input-textarea{width:100%;min-height:150px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;resize:vertical;transition:border-color .2s,box-shadow .2s}.test-input-textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #8b5cf626}.test-input-textarea:disabled{opacity:.6;cursor:not-allowed}.test-actions{display:flex;gap:10px}.test-actions .btn-locked{opacity:.8}.test-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#f87171;font-size:14px}.test-output-section{display:flex;flex-direction:column;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px}.output-meta{display:flex;align-items:center;gap:12px}.status-badge{font-size:12px;padding:4px 10px;border-radius:20px;font-weight:500}.status-badge[data-status=success]{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.status-badge[data-status=error]{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}.meta-item{font-size:12px;color:var(--text-secondary)}.compile-output,.stderr-output{background:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:12px}.compile-output label,.stderr-output label{display:block;font-size:12px;font-weight:600;color:#f87171;margin-bottom:8px}.compile-output pre,.stderr-output pre{margin:0;font-size:12px;color:#fca5a5;white-space:pre-wrap;word-break:break-word}.stdout-output{display:flex;flex-direction:column;gap:8px}.stdout-header{display:flex;align-items:center;justify-content:space-between}.stdout-header label{font-size:14px;font-weight:600;color:var(--text)}.output-code-wrapper{background:#011627;border-radius:8px;overflow:auto;max-height:400px}.output-code-wrapper pre{padding:16px;font-size:13px;line-height:1.5}.output-code-wrapper .line-number{display:inline-block;width:40px;padding-right:16px;color:#ffffff4d;text-align:right;-webkit-user-select:none;user-select:none}.no-output{padding:24px;text-align:center;color:var(--text-secondary);font-size:14px}.test-runner-info{display:flex;align-items:flex-start;gap:8px;padding:12px 16px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:8px}.test-runner-info .info-icon{flex-shrink:0}.test-runner-info p{margin:0;font-size:13px;color:var(--text-secondary);line-height:1.5}.test-runner-locked{display:flex;flex-direction:column;align-items:center;text-align:center;padding:40px 24px;background:linear-gradient(135deg,#8b5cf60d,#3b82f60d);border:1px dashed var(--border);border-radius:12px}.test-runner-locked .locked-icon{font-size:48px;margin-bottom:16px}.test-runner-locked h4{font-size:18px;color:var(--text);margin:0 0 8px}.test-runner-locked>p{color:var(--text-secondary);font-size:14px;max-width:400px;margin:0 0 20px;line-height:1.6}.locked-benefits{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:24px}.locked-benefits .benefit{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:8px 14px;font-size:13px;color:var(--text)}.test-runner-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:40px 24px;background:var(--surface);border:1px dashed var(--border);border-radius:12px}.test-runner-empty .empty-icon{font-size:48px;margin-bottom:16px;opacity:.6}.test-runner-empty h4{font-size:18px;color:var(--text);margin:0 0 8px}.test-runner-empty>p{color:var(--text-secondary);font-size:14px;max-width:400px;margin:0 0 20px;line-height:1.6}.test-steps{text-align:left;margin:0;padding-left:24px;color:var(--text-secondary);font-size:13px;line-height:2}.test-steps li{padding-left:8px}.test-ready-badge{font-size:12px;padding:4px 10px;background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3);border-radius:20px}.header-tabs{display:flex;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:4px}.tab-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.tab-btn:hover{color:var(--text);background:#ffffff0d}.tab-btn.active{background:var(--brand);color:#fff;box-shadow:0 2px 8px #8b5cf64d}.testing-tab-content{flex:1;display:flex;flex-direction:column;padding:24px;overflow:auto}.testing-tab-content .test-runner{flex:1;max-width:1000px;margin:0 auto;width:100%}.testing-tab-content .test-runner-locked,.testing-tab-content .test-runner-empty{min-height:400px;justify-content:center}.testing-tab-content .test-input-textarea{min-height:250px}.testing-tab-content .output-code-wrapper{max-height:500px}.error-boundary-fallback{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;background:var(--bg-base);color:var(--text)}.error-content{text-align:center;max-width:500px;padding:40px;background:var(--surface);border-radius:16px;border:1px solid var(--border);box-shadow:0 20px 40px #0000004d}.error-content .error-icon{font-size:64px;margin-bottom:20px}.error-content h2{font-size:24px;margin:0 0 12px}.error-content p{color:var(--text-secondary);margin:0 0 20px}.error-details{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px;font-size:12px;text-align:left;overflow:auto;max-height:150px;margin-bottom:20px;color:#f87171}.empty-unmapped{padding:20px;text-align:center;color:var(--text-muted);font-size:12px}.new-project-popup{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;width:380px;max-width:90vw;box-shadow:var(--shadow-lg)}.new-project-popup h3{margin:0 0 20px;font-size:18px;color:var(--text)}.new-project-popup .form-field{margin-bottom:20px}.new-project-popup .form-field label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:6px}.new-project-popup .form-field input{width:100%;padding:10px 12px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;transition:border-color .15s}.new-project-popup .form-field input:focus{outline:none;border-color:var(--brand)}.new-project-popup .form-field input.has-error{border-color:var(--error)}.new-project-popup .field-error{display:block;font-size:11px;color:var(--error);margin-top:6px}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.loading-box p{font-size:14px;color:var(--text-secondary)}@media(max-width:1200px){.input-row{grid-template-columns:1fr 1fr}}@media(max-width:900px){.sidebar{display:none}.input-row,.bottom-row{grid-template-columns:1fr}}.sidebar-logo-icon{width:32px;height:32px;object-fit:contain}.header-logo{width:32px;height:32px;object-fit:contain;border-radius:var(--radius-sm)}.header-logo.clickable{cursor:pointer;transition:transform .15s ease,opacity .15s ease}.header-logo.clickable:hover{transform:scale(1.1);opacity:.85}.header-tabs{display:flex;gap:4px;background:var(--bg-base);border-radius:var(--radius-md);padding:4px}.tab-btn{padding:8px 16px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.tab-btn:hover:not(:disabled){color:var(--text);background:var(--bg-elevated)}.tab-btn.active{background:var(--brand);color:#fff}.tab-btn:disabled{opacity:.4;cursor:not-allowed}.option-hint{font-size:10px;color:var(--text-muted);margin-top:2px}.welcome-screen{flex:1;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,var(--brand-glow) 0%,transparent 50%),var(--bg-base);padding:40px}.welcome-content{text-align:center;max-width:1100px;width:100%;padding:0 24px}.welcome-logo-container{width:280px;height:200px;margin:40px auto 32px;overflow:hidden;display:flex;align-items:center;justify-content:center}.welcome-logo{width:100%;height:auto;object-fit:contain;filter:drop-shadow(0 0 60px var(--brand-glow))}.welcome-subtitle{font-size:16px;color:var(--text-secondary);line-height:1.6;margin-bottom:32px}.welcome-actions{margin-bottom:48px}.btn-lg{padding:14px 32px;font-size:16px}.welcome-hint{margin-top:16px;font-size:13px;color:var(--text-muted)}.welcome-features{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.feature{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;transition:all .2s}.feature:hover{border-color:var(--brand);transform:translateY(-4px);box-shadow:var(--shadow-md)}.feature-icon{font-size:28px;margin-bottom:12px}.feature h3{font-size:14px;font-weight:600;margin-bottom:4px}.feature p{font-size:12px;color:var(--text-muted)}.testing-section{flex:1;display:flex;flex-direction:column;min-height:0}.testing-layout{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:16px;min-height:0}.testing-code-panel,.testing-runner-panel{display:flex;flex-direction:column;min-height:0;overflow:hidden}.testing-code-panel .code-section{flex:1;display:flex;flex-direction:column}.testing-code-panel .code-body{flex:1;max-height:none}.code-lang-badge{padding:4px 10px;background:var(--brand-glow);border:1px solid var(--brand);border-radius:999px;font-size:11px;font-weight:600;color:var(--brand-light);text-transform:uppercase}.test-runner{display:flex;flex-direction:column;height:100%;overflow:hidden}.test-runner-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-base);border-bottom:1px solid var(--border);flex-shrink:0}.test-runner-header h3{font-size:13px;font-weight:600}.test-tabs{display:flex;gap:4px}.test-error{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--error-bg);border-bottom:1px solid rgba(239,68,68,.2);color:var(--error);font-size:12px}.test-content{flex:1;display:flex;flex-direction:column;min-height:0}.test-input-section,.test-output-section,.test-validation-section{flex:1;display:flex;flex-direction:column;padding:16px}.input-controls{display:flex;align-items:center;gap:12px;margin-bottom:12px}.file-upload-btn{padding:8px 16px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:13px;cursor:pointer;transition:all .15s}.file-upload-btn:hover{border-color:var(--brand);background:var(--brand-glow)}.or-text{color:var(--text-muted);font-size:12px}.test-textarea{flex:1;width:100%;min-height:150px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;color:var(--text);font-family:Fira Code,monospace;font-size:12px;line-height:1.5;resize:none}.test-textarea:focus{outline:none;border-color:var(--brand)}.test-actions{margin-top:12px;display:flex;gap:8px}.output-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:12px}.icon-btn{width:32px;height:32px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.icon-btn:hover{border-color:var(--brand);background:var(--brand-glow)}.test-output-code{flex:1;background:#0d1117;border-radius:var(--radius-md);padding:12px;overflow:auto;margin:0}.test-output-code code{font-family:Fira Code,monospace;font-size:12px;line-height:1.5;color:var(--text);white-space:pre-wrap;word-break:break-word}.validation-status{display:flex;align-items:center;gap:12px;padding:20px;border-radius:var(--radius-lg);margin-bottom:16px}.validation-status.valid{background:var(--success-bg);border:1px solid rgba(34,197,94,.3)}.validation-status.invalid{background:var(--error-bg);border:1px solid rgba(239,68,68,.3)}.validation-icon{font-size:28px}.validation-text{font-size:16px;font-weight:600}.validation-status.valid .validation-text{color:var(--success)}.validation-status.invalid .validation-text{color:var(--error)}.validation-errors{list-style:none;padding:0;margin:0}.validation-errors li{padding:10px 12px;background:var(--bg-base);border-radius:var(--radius-sm);margin-bottom:6px;font-size:13px;color:var(--text-secondary)}@media(max-width:768px){.welcome-features{grid-template-columns:repeat(2,1fr)}.welcome-title{font-size:32px}.testing-layout{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.enrichment-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:500px;max-width:90vw;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.modal-header h3{margin:0;font-size:16px}.modal-close{background:transparent;border:none;font-size:18px;cursor:pointer;color:var(--text-muted);padding:4px 8px;border-radius:var(--radius-sm)}.modal-close:hover{background:var(--bg-hover);color:var(--text)}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-top:1px solid var(--border);background:var(--bg-elevated)}.modal-footer-right{display:flex;gap:10px}.enrichment-target{margin-bottom:20px}.enrichment-target label{display:block;font-size:11px;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase}.target-field-display{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm)}.target-field-display .field-path{font-family:var(--font-mono);font-size:12px;color:var(--text)}.target-field-display .field-type{font-size:11px;color:var(--text-muted);background:var(--bg-elevated);padding:2px 8px;border-radius:999px}.enrichment-types{margin-bottom:20px}.enrichment-types label{display:block;font-size:11px;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase}.type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.type-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.type-btn:hover{background:var(--bg-hover);border-color:var(--brand)}.type-btn.active{background:#6366f126;border-color:var(--brand)}.type-icon{font-size:18px}.type-label{font-size:10px;color:var(--text-secondary);text-align:center}.enrichment-config{margin-bottom:20px}.config-field{margin-bottom:16px}.config-field label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:6px}.config-field input,.config-field select,.config-field textarea{width:100%;padding:10px 12px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--text)}.config-field input:focus,.config-field select:focus,.config-field textarea:focus{outline:none;border-color:var(--brand)}.config-field textarea{font-family:var(--font-mono);resize:vertical}.config-field .hint{font-size:11px;color:var(--text-muted);margin-top:6px}.config-info{padding:12px;background:var(--bg-base);border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary)}.config-info p{margin:0}.source-field-picker{max-height:200px;overflow-y:auto;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px}.source-field-option{display:flex;align-items:center;gap:8px;padding:6px 8px;cursor:pointer;border-radius:var(--radius-sm)}.source-field-option:hover{background:var(--bg-hover)}.source-field-option input{flex-shrink:0}.source-field-option span{font-size:12px}.field-path-small{color:var(--text-muted);font-size:10px!important;font-family:var(--font-mono);margin-left:auto}.no-fields-hint{font-size:12px;color:var(--text-muted);text-align:center;padding:12px}.enrichment-description{margin-bottom:10px}.enrichment-description label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:6px}.enrichment-description input{width:100%;padding:10px 12px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--text)}.enrichment-description input:focus{outline:none;border-color:var(--brand)}.btn-danger{background:var(--error);border-color:var(--error);color:#fff}.btn-danger:hover{background:#dc2626}.guide-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1100;animation:fadeIn .2s ease}.guide-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:700px;max-width:90vw;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000080;animation:slideUp .3s ease}.guide-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);background:var(--bg-elevated);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.guide-header-left{display:flex;align-items:center;gap:12px}.guide-logo{width:36px;height:36px}.guide-header h2{margin:0;font-size:20px;font-weight:600}.guide-close{background:transparent;border:none;font-size:20px;cursor:pointer;color:var(--text-muted);padding:8px;border-radius:var(--radius-sm);transition:all .15s}.guide-close:hover{background:var(--bg-hover);color:var(--text)}.guide-content{flex:1;overflow-y:auto;padding:24px}.guide-section{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border)}.guide-section:last-child{border-bottom:none;margin-bottom:0}.guide-section h3{font-size:16px;font-weight:600;margin:0 0 12px;color:var(--text)}.guide-section p{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0 0 16px}.guide-flow{display:flex;align-items:center;justify-content:center;gap:16px;padding:20px;background:var(--bg-base);border-radius:var(--radius-md)}.flow-step{display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md)}.flow-number{width:28px;height:28px;background:var(--brand);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.flow-text{font-size:13px;font-weight:500}.flow-arrow{color:var(--text-muted);font-size:20px}.guide-steps{display:flex;flex-direction:column;gap:16px}.guide-step{display:flex;gap:16px;padding:16px;background:var(--bg-base);border-radius:var(--radius-md);border:1px solid var(--border)}.step-icon{font-size:24px;flex-shrink:0}.step-content h4{margin:0 0 4px;font-size:14px;font-weight:600}.step-content p{margin:0;font-size:13px;color:var(--text-secondary)}.guide-btn{display:inline-block;padding:2px 8px;background:var(--brand);color:#fff;border-radius:var(--radius-sm);font-size:11px;font-weight:500}.guide-visual{display:flex;align-items:center;justify-content:center;gap:12px;padding:20px;background:var(--bg-base);border-radius:var(--radius-md);margin-bottom:16px}.visual-panel{width:140px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.visual-header{padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-muted);background:var(--bg-surface);border-bottom:1px solid var(--border)}.visual-field{padding:8px 12px;font-size:12px;font-family:var(--font-mono);border-bottom:1px solid var(--border)}.visual-field:last-child{border-bottom:none}.visual-field.selected{background:#6366f133;border-left:3px solid var(--brand)}.visual-field.mapped{background:#22c55e26}.visual-arrows{display:flex;align-items:center}.guide-tips{display:flex;flex-direction:column;gap:10px}.tip{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--text-secondary)}.tip-icon{flex-shrink:0}.color-legend{display:flex;flex-direction:column;gap:12px}.color-item{display:flex;align-items:center;gap:12px}.color-swatch{width:32px;height:20px;border-radius:var(--radius-sm);flex-shrink:0}.color-info{display:flex;flex-direction:column}.color-info strong{font-size:13px}.color-info span{font-size:12px;color:var(--text-muted)}.enrichment-types-guide{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.enrich-type{display:flex;gap:12px;padding:12px;background:var(--bg-base);border-radius:var(--radius-sm);border:1px solid var(--border)}.enrich-icon{font-size:20px}.enrich-type strong{font-size:13px;display:block;margin-bottom:2px}.enrich-type p{margin:0;font-size:12px;color:var(--text-muted)}.guide-tip-box{display:flex;gap:12px;padding:14px 16px;background:#6366f11a;border:1px solid rgba(99,102,241,.3);border-radius:var(--radius-md)}.guide-tip-box p{margin:0;font-size:13px}.guide-example{padding:16px;background:var(--bg-base);border-radius:var(--radius-md);margin-bottom:12px}.example-mapping{display:flex;align-items:center;gap:12px;margin-bottom:10px;font-family:var(--font-mono);font-size:13px}.example-source{color:var(--brand-light)}.example-arrow{color:var(--text-muted)}.example-target{color:var(--success)}.example-note input{width:100%;padding:8px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary)}.guide-note{font-size:12px;color:var(--text-muted);font-style:italic}.guide-note code{background:var(--bg-elevated);padding:2px 6px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-style:normal}.options-grid-guide{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.option-guide{padding:14px;background:var(--bg-base);border-radius:var(--radius-sm);border:1px solid var(--border)}.option-guide h4{margin:0 0 6px;font-size:13px;font-weight:600}.option-guide p{margin:0;font-size:12px}.guide-list{margin:0;padding:0;list-style:none}.guide-list li{padding:10px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--text-secondary)}.guide-list li:last-child{border-bottom:none}.shortcuts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.shortcut{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px;background:var(--bg-base);border-radius:var(--radius-sm);text-align:center}.key{padding:6px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-weight:600}.shortcut span:last-child{font-size:11px;color:var(--text-muted)}.guide-code{padding:14px 16px;background:var(--bg-base);border-radius:var(--radius-sm);margin-bottom:12px}.guide-code code{font-family:var(--font-mono);font-size:13px;color:var(--brand-light)}.guide-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:center}.guide-footer .btn{min-width:120px}.loading-full{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;background:var(--bg-base)}.auth-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.auth-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:420px;padding:32px;box-shadow:var(--shadow-lg),0 0 60px #0ea5e91a;position:relative;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.auth-close{position:absolute;top:16px;right:16px;width:32px;height:32px;background:transparent;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;border-radius:var(--radius-sm);transition:all .15s}.auth-close:hover{background:var(--bg-hover);color:var(--text)}.auth-header{text-align:center;margin-bottom:24px}.auth-logo{width:48px;height:48px;margin-bottom:16px}.auth-header h2{font-size:24px;font-weight:700;margin:0 0 8px}.auth-header p{color:var(--text-secondary);margin:0}.auth-error{background:var(--error-bg);border:1px solid var(--error);color:var(--error);padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:13px}.auth-info{background:var(--bg-elevated);border:1px solid var(--border);padding:20px;border-radius:var(--radius-sm);text-align:center}.auth-info p{margin:0 0 8px;font-size:13px;color:var(--text-secondary)}.auth-info p:first-child{color:var(--text);margin-bottom:12px}.auth-social{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.btn-social{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;border:1px solid var(--border)}.btn-google{background:#fff;color:#333}.btn-google:hover{background:#f5f5f5}.btn-facebook{background:#1877f2;color:#fff;border-color:#1877f2}.btn-facebook:hover{background:#166fe5}.btn-social:disabled{opacity:.6;cursor:not-allowed}.btn-social svg{flex-shrink:0}.auth-divider{display:flex;align-items:center;gap:16px;margin-bottom:24px;color:var(--text-muted);font-size:12px;text-transform:uppercase}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:500;color:var(--text-secondary)}.form-group input{padding:12px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text);transition:all .15s}.form-group input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}.form-group input::placeholder{color:var(--text-muted)}.btn-auth-submit{width:100%;padding:12px;font-size:14px;font-weight:600;margin-top:8px}.auth-footer{margin-top:24px;text-align:center;padding-top:20px;border-top:1px solid var(--border)}.auth-footer p{color:var(--text-secondary);margin:0;font-size:14px}.auth-footer button{background:none;border:none;color:var(--brand);font-weight:600;cursor:pointer;transition:color .15s}.auth-footer button:hover{color:var(--brand-light)}.guest-banner{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:linear-gradient(135deg,#0ea5e91a,#0ea5e90d);border-bottom:1px solid var(--brand);gap:16px}.guest-banner-content{display:flex;align-items:center;gap:12px}.guest-icon{font-size:18px}.guest-text{font-size:13px;color:var(--text-secondary)}.guest-text strong{color:var(--text);font-weight:600}.btn-sign-in-banner{padding:8px 16px;background:var(--brand);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-sign-in-banner:hover{background:var(--brand-dark)}.user-menu-guest{display:flex;align-items:center}.btn-sign-in{padding:8px 16px;background:var(--brand);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.btn-sign-in:hover{background:var(--brand-dark)}.user-menu{position:relative}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--brand);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;overflow:hidden}.user-avatar:hover{box-shadow:0 0 0 3px var(--brand-glow)}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-letter{color:#fff;font-weight:600;font-size:14px}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);min-width:200px;box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;animation:fadeIn .15s ease}.user-info{padding:14px 16px}.user-dropdown .user-name{font-weight:600;font-size:14px;margin-bottom:2px}.user-dropdown .user-email{font-size:12px;color:var(--text-muted)}.dropdown-divider{height:1px;background:var(--border)}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:none;border:none;color:var(--text);font-size:14px;cursor:pointer;transition:background .15s;text-align:left}.dropdown-item:hover{background:var(--bg-hover)}.dropdown-icon{font-size:16px}.btn-sign-in-sidebar{width:100%;padding:10px 16px;background:var(--brand);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;margin-bottom:8px}.btn-sign-in-sidebar:hover{background:var(--brand-dark)}.btn-logout{background:none;border:none;font-size:16px;cursor:pointer;padding:4px;opacity:.6;transition:opacity .15s}.btn-logout:hover{opacity:1}.project-list-empty{padding:24px 16px;text-align:center}.project-list-empty p{color:var(--text-muted);margin-bottom:12px}.user-section{display:flex;align-items:center;gap:12px;cursor:pointer;padding:10px;margin-bottom:12px;border-radius:var(--radius-sm);transition:background .15s;background:var(--bg-elevated);border:1px solid var(--border)}.user-section:hover{background:var(--bg-hover);border-color:var(--border-light)}.user-section.clickable{cursor:pointer}.user-settings-icon{font-size:16px;opacity:.5;transition:opacity .15s}.user-section:hover .user-settings-icon{opacity:1}.sidebar-buttons{display:flex;flex-direction:column;gap:8px}.btn-logout-sidebar{width:100%;padding:10px 16px;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.btn-logout-sidebar:hover{background:var(--bg-hover);color:var(--text);border-color:var(--border-light)}.sidebar-footer .avatar{overflow:hidden}.sidebar-footer .avatar img{width:100%;height:100%;object-fit:cover}.account-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.account-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:800px;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);position:relative;animation:slideUp .3s ease;overflow:hidden}.account-close{position:absolute;top:16px;right:16px;width:32px;height:32px;background:transparent;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;border-radius:var(--radius-sm);transition:all .15s;z-index:10}.account-close:hover{background:var(--bg-hover);color:var(--text)}.account-header{padding:20px 24px;border-bottom:1px solid var(--border)}.account-header h2{margin:0;font-size:20px;font-weight:600}.account-layout{display:flex;flex:1;overflow:hidden}.account-sidebar{width:220px;background:var(--bg-base);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.account-user-card{padding:20px;display:flex;flex-direction:column;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.account-avatar{width:64px;height:64px;border-radius:50%;background:var(--brand);display:flex;align-items:center;justify-content:center;overflow:hidden}.account-avatar img{width:100%;height:100%;object-fit:cover}.account-avatar span{color:#fff;font-size:24px;font-weight:600}.account-user-info{text-align:center}.account-user-name{font-weight:600;font-size:14px;margin-bottom:2px}.account-user-email{font-size:12px;color:var(--text-muted);word-break:break-all}.account-nav{padding:12px 8px;display:flex;flex-direction:column;gap:4px}.account-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;border-radius:var(--radius-sm);transition:all .15s;text-align:left;width:100%}.account-nav-item:hover{background:var(--bg-hover);color:var(--text)}.account-nav-item.active{background:var(--brand-glow);color:var(--brand)}.account-nav-item.coming-soon{opacity:.6}.nav-icon{font-size:16px}.nav-label{flex:1}.nav-badge{font-size:10px;padding:2px 6px;background:var(--bg-elevated);border-radius:10px;color:var(--text-muted)}.account-content{flex:1;padding:24px;overflow-y:auto}.account-section h3{margin:0 0 8px;font-size:18px;font-weight:600}.section-description{color:var(--text-secondary);margin:0 0 24px;font-size:14px}.account-message{padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:14px}.account-message.success{background:var(--success-bg);border:1px solid var(--success);color:var(--success)}.account-message.error{background:var(--error-bg);border:1px solid var(--error);color:var(--error)}.account-form{display:flex;flex-direction:column;gap:20px;max-width:400px}.account-form .form-group input.disabled{background:var(--bg-base);color:var(--text-muted);cursor:not-allowed}.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.form-actions{padding-top:8px}.security-notice{display:flex;gap:16px;padding:20px;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border)}.notice-icon{font-size:32px}.notice-content h4{margin:0 0 8px;font-size:16px}.notice-content p{margin:0;color:var(--text-secondary);font-size:14px}.notice-content a{color:var(--brand)}.notice-content a:hover{text-decoration:underline}.danger-zone{margin-top:40px;padding-top:24px;border-top:1px solid var(--border)}.danger-zone h4{color:var(--error);margin:0 0 8px;font-size:16px}.danger-zone p{color:var(--text-secondary);margin:0 0 16px;font-size:14px}.coming-soon-section{position:relative}.coming-soon-overlay{position:absolute;top:80px;left:0;right:0;display:flex;justify-content:center;z-index:10}.coming-soon-badge{background:var(--bg-elevated);border:1px solid var(--border);padding:8px 20px;border-radius:20px;font-size:14px;font-weight:600;color:var(--text-secondary)}.disabled-content{opacity:.4;pointer-events:none;filter:blur(1px)}.billing-content{display:flex;flex-direction:column;gap:24px}.plan-card{padding:20px;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border)}.plan-card.current{border-color:var(--brand)}.plan-card.pro{background:linear-gradient(135deg,var(--bg-elevated),rgba(14,165,233,.1))}.plan-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.plan-header h4{margin:0;font-size:18px}.plan-badge{font-size:11px;padding:3px 8px;background:var(--brand);color:#fff;border-radius:10px}.plan-badge-pro{font-size:11px;padding:3px 8px;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;border-radius:10px}.plan-price{margin-bottom:16px}.plan-price .price{font-size:32px;font-weight:700}.plan-price .period{color:var(--text-muted)}.plan-features{list-style:none;padding:0;margin:0 0 16px}.plan-features li{padding:6px 0;font-size:14px;color:var(--text-secondary)}.payment-methods,.billing-history{padding:20px;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border)}.payment-methods h4,.billing-history h4{margin:0 0 12px;font-size:16px}.no-payment,.no-history{color:var(--text-muted);font-size:14px;margin:0 0 12px}.usage-content{display:flex;flex-direction:column;gap:16px}.usage-card{padding:20px;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border)}.usage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.usage-header h4{margin:0;font-size:14px}.usage-period{font-size:12px;color:var(--text-muted)}.usage-stat{margin-bottom:8px}.stat-value{font-size:28px;font-weight:700;color:var(--brand)}.stat-limit{font-size:14px;color:var(--text-muted)}.usage-bar{height:6px;background:var(--bg-base);border-radius:3px;overflow:hidden}.usage-fill{height:100%;background:var(--brand);border-radius:3px;transition:width .3s ease}.confirm-title{margin:0 0 8px;font-size:18px;font-weight:600}.contact-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease;padding:20px}.contact-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);position:relative;animation:slideUp .3s ease}.contact-close{position:absolute;top:16px;right:16px;width:32px;height:32px;background:transparent;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;border-radius:var(--radius-sm);transition:all .15s;z-index:10}.contact-close:hover{background:var(--bg-hover);color:var(--text)}.contact-header{padding:32px 32px 24px;text-align:center;border-bottom:1px solid var(--border)}.contact-icon{font-size:48px;margin-bottom:16px}.contact-header h2{margin:0 0 8px;font-size:24px;font-weight:700}.contact-header p{color:var(--text-secondary);font-size:14px;max-width:400px;margin:0 auto}.contact-form{padding:24px 32px 32px;display:flex;flex-direction:column;gap:20px}.contact-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.contact-form .form-group{display:flex;flex-direction:column;gap:6px}.contact-form label{font-size:13px;font-weight:500;color:var(--text-secondary)}.contact-form input,.contact-form textarea,.contact-form select{padding:12px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text);font-family:inherit;transition:all .15s;resize:vertical}.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--text-muted)}.category-grid{display:flex;flex-wrap:wrap;gap:8px}.category-option{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:20px;cursor:pointer;font-size:13px;transition:all .15s}.category-option:hover{border-color:var(--border-light);background:var(--bg-hover)}.category-option.selected{border-color:var(--brand);background:var(--brand-glow);color:var(--brand)}.category-option input{display:none}.priority-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.priority-option{display:flex;flex-direction:column;gap:4px;padding:12px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.priority-option:hover{border-color:var(--border-light);background:var(--bg-hover)}.priority-option.selected{border-color:var(--brand);background:var(--brand-glow)}.priority-option input{display:none}.priority-label{font-size:14px;font-weight:500}.priority-desc{font-size:11px;color:var(--text-muted)}.priority-option.selected .priority-desc{color:var(--text-secondary)}.bug-info-note{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border)}.bug-info-note .info-icon{font-size:16px;flex-shrink:0}.bug-info-note p{margin:0;font-size:12px;color:var(--text-secondary);line-height:1.5}.contact-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:8px}.contact-success{padding:48px 32px;text-align:center}.success-icon{font-size:64px;margin-bottom:20px}.contact-success h2{margin:0 0 12px;font-size:24px;font-weight:700}.contact-success p{margin:0 0 8px;color:var(--text-secondary);font-size:14px}.success-note{margin-top:20px!important;padding:16px;background:var(--bg-elevated);border-radius:var(--radius-sm)}.success-note a{color:var(--brand);font-weight:600}.success-note a:hover{text-decoration:underline}.contact-success .btn{margin-top:24px}.sidebar-help-links{display:flex;align-items:center;justify-content:center;gap:8px;padding-top:12px;margin-top:8px;border-top:1px solid var(--border)}.help-link{background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all .15s}.help-link:hover{color:var(--text);background:var(--bg-hover)}.help-divider{color:var(--border-light);font-size:10px}.ai-confirm-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out}.ai-confirm-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:440px;width:90%;box-shadow:var(--shadow-lg);animation:slideUp .2s ease-out}.ai-confirm-header{display:flex;align-items:center;gap:12px;padding:20px 24px;border-bottom:1px solid var(--border)}.ai-confirm-icon{font-size:28px}.ai-confirm-header h3{margin:0;font-size:18px;font-weight:600}.ai-confirm-body{padding:20px 24px}.ai-confirm-desc{margin:0 0 16px;color:var(--text-secondary);font-size:14px;line-height:1.5}.ai-confirm-info{display:flex;flex-direction:column;gap:10px}.ai-confirm-info .info-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--bg-elevated);border-radius:var(--radius-sm);font-size:13px;color:var(--text-secondary)}.ai-confirm-info .info-item.highlight{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border:1px solid rgba(34,197,94,.2);color:var(--text)}.ai-confirm-info .info-icon{font-size:16px;flex-shrink:0}.ai-confirm-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid var(--border);background:var(--bg-elevated);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.dont-ask-again{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);cursor:pointer}.dont-ask-again input{cursor:pointer}.ai-confirm-actions{display:flex;gap:10px}.iteration-context-editor{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px}.iteration-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.iteration-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13px}.iteration-icon{font-size:16px}.iteration-count{background:var(--brand);color:#fff;font-size:10px;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.iteration-empty{text-align:center;padding:16px;color:var(--text-muted);font-size:12px}.iteration-empty .hint{margin-top:4px;font-size:11px;color:var(--text-tertiary)}.iteration-form{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;margin-bottom:10px}.iteration-form .form-row{display:flex;align-items:flex-end;gap:8px;margin-bottom:10px}.iteration-form .form-field{flex:1;display:flex;flex-direction:column;gap:4px}.iteration-form .form-field.full-width{margin-bottom:10px}.iteration-form label{font-size:11px;color:var(--text-muted);text-transform:uppercase}.iteration-form select,.iteration-form input{padding:8px 10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:12px}.iteration-form .form-arrow{font-size:16px;color:var(--text-muted);padding-bottom:8px}.iteration-form .form-actions{display:flex;justify-content:flex-end;gap:8px}.iteration-list{display:flex;flex-direction:column;gap:8px}.iteration-item{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);position:relative}.iteration-mapping{display:flex;align-items:center;gap:8px;font-size:12px}.iteration-mapping .path{padding:3px 8px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:11px}.iteration-mapping .source-path{background:#8b5cf626;color:var(--brand-light)}.iteration-mapping .target-path{background:#22c55e26;color:#22c55e}.iteration-mapping .arrow{color:var(--text-muted)}.iteration-desc{font-size:11px;color:var(--text-muted);flex:1}.iteration-item .btn-remove{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:4px;opacity:0;transition:opacity .15s}.iteration-item:hover .btn-remove{opacity:1}.iteration-item .btn-remove:hover{color:var(--danger)}
