@import"https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&display=swap";*,*:before,*:after{box-sizing:border-box}html{margin:0;padding:0;width:100%}body{margin:0;padding:0;width:100%;background:#0f0f11}#root{width:100%;min-height:100vh;display:block}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.quota-editor-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;overflow-y:auto;padding:40px 20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.quota-editor{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px;max-width:1200px;width:100%;font-family:DM Sans,-apple-system,sans-serif;color:#1a1a2e;margin:auto;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.editor-header{margin-bottom:32px}.editor-header h2{margin:0 0 8px;font-size:28px;font-weight:600;color:#1a1a2e}.editor-header p{margin:0;color:#64748b;font-size:15px}.add-group-section{display:flex;gap:12px;margin-bottom:32px;padding:20px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb}.group-name-input{flex:1;padding:12px 16px;font-size:15px;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#1a1a2e;outline:none;transition:border-color .2s}.group-name-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.group-name-input::placeholder{color:#9ca3af}.btn-add-group{padding:12px 24px;background:#2563eb;border:none;border-radius:6px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-add-group:hover{background:#1d4ed8}.btn-bulk-import{padding:12px 24px;background:#2563eb;border:none;border-radius:6px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-bulk-import:hover{background:#1d4ed8}.bulk-import-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.bulk-modal-content{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px;max-width:700px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.bulk-modal-content h3{margin:0 0 16px;font-size:24px;font-weight:600;color:#1a1a2e}.bulk-modal-content p{margin:0 0 12px;color:#64748b;font-size:14px}.format-help{background:#f8fafc;padding:8px 12px;border-radius:6px;border:1px solid #e5e7eb}.format-help code{color:#16a34a;font-family:Courier New,monospace}.bulk-textarea{width:100%;padding:12px;background:#f8fafc;border:1px solid #d1d5db;border-radius:6px;color:#1a1a2e;font-family:Courier New,monospace;font-size:13px;resize:vertical;outline:none;margin-bottom:16px}.bulk-textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.bulk-example{background:#f8fafc;padding:16px;border-radius:6px;border:1px solid #e5e7eb;margin-bottom:24px}.bulk-example strong{display:block;margin-bottom:8px;color:#16a34a}.bulk-example ol{margin:0;padding-left:20px;color:#64748b;font-size:13px;line-height:1.8}.bulk-actions{display:flex;justify-content:flex-end;gap:12px}.empty-quota-state{text-align:center;padding:60px 20px;background:#f8fafc;border-radius:8px;border:1px dashed #d1d5db}.empty-quota-state p{margin:0;color:#64748b;font-size:15px}.quota-groups-list{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}.quota-group-card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;transition:all .2s}.quota-group-card:hover{border-color:#cbd5e1}.group-card-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:#f1f5f9;border-bottom:1px solid #e5e7eb}.group-card-header h3{margin:0;font-size:18px;font-weight:600;color:#1a1a2e}.group-actions{display:flex;gap:8px}.btn-toggle{padding:8px 16px;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;font-size:14px;cursor:pointer;transition:all .2s}.btn-toggle:hover{background:#f9fafb;border-color:#9ca3af}.btn-delete-group{padding:8px 16px;background:transparent;border:1px solid #fca5a5;border-radius:6px;color:#dc2626;font-size:14px;cursor:pointer;transition:all .2s}.btn-delete-group:hover{background:#dc2626;color:#fff;border-color:#dc2626}.group-details{padding:24px}.group-settings{margin-bottom:24px}.form-row{display:flex;align-items:center;gap:12px}.form-row label{font-size:14px;color:#64748b;font-weight:500}.action-select{padding:8px 12px;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#1a1a2e;font-size:14px;cursor:pointer}.cells-section{margin-top:20px}.cells-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.cells-header h4{margin:0;font-size:16px;font-weight:600;color:#1a1a2e}.btn-add-cell{padding:8px 16px;background:#2563eb;border:none;border-radius:6px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-add-cell:hover{background:#1d4ed8}.no-cells{text-align:center;padding:32px;background:#f8fafc;border-radius:8px;border:1px dashed #d1d5db}.no-cells p{margin:0;color:#64748b}.cell-rows{display:flex;flex-direction:column;gap:8px}.cell-row{display:grid;grid-template-columns:1fr 2fr 100px 40px;gap:8px;align-items:center;padding:8px;background:#fff;border:1px solid #e5e7eb;border-radius:6px}.cell-input{padding:10px 12px;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#1a1a2e;font-size:14px;outline:none;transition:border-color .2s}.cell-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.cell-input::placeholder{color:#9ca3af}.condition-input{font-family:Courier New,monospace;font-size:13px}.target-input{text-align:center;font-weight:600;font-size:16px}.target-field{max-width:100px}.btn-delete-cell{width:36px;height:36px;background:transparent;border:1px solid #fca5a5;border-radius:6px;color:#dc2626;font-size:24px;line-height:1;cursor:pointer;transition:all .2s;padding:0}.btn-delete-cell:hover{background:#dc2626;color:#fff}.helper-section{margin-top:24px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.helper-section summary{font-size:14px;font-weight:600;color:#2563eb;cursor:pointer;-webkit-user-select:none;user-select:none}.helper-section summary:hover{color:#1d4ed8}.helper-content{margin-top:16px;display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.helper-question{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#fff;border-radius:6px;font-size:13px;border:1px solid #e5e7eb}.helper-question code{font-family:Courier New,monospace;color:#16a34a;font-weight:600;min-width:120px}.question-type{color:#2563eb;font-weight:500;min-width:80px}.helper-question .question-text{color:#64748b;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:24px;border-top:1px solid #e5e7eb;margin-bottom:32px}.btn-cancel:hover:not(:disabled){background:#f9fafb}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-save{padding:12px 32px;background:#2563eb;border:none;border-radius:8px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-save:hover:not(:disabled){background:#1d4ed8}.btn-save:disabled{opacity:.5;cursor:not-allowed}.editor-help{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:20px 24px}.editor-help h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#2563eb}.editor-help ul{margin:0;padding-left:20px;color:#64748b;font-size:14px;line-height:1.8}.editor-help ul ul{margin-top:8px}.editor-help code{font-family:Courier New,monospace;background:#fff;padding:2px 6px;border-radius:3px;color:#16a34a;font-size:13px}.editor-help strong{color:#1a1a2e}.btn-export{padding:8px 16px;background:#2563eb;border:none;border-radius:6px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-export:hover{background:#1d4ed8}.btn-export-all{padding:12px 24px;background:#2563eb;border:none;border-radius:6px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-export-all:hover{background:#1d4ed8}.file-upload-section{margin:20px 0;padding:24px;background:#f8fafc;border:2px dashed #d1d5db;border-radius:8px;text-align:center}.file-upload-section p{margin:0 0 8px;color:#64748b}.file-input{display:none}.file-upload-button{display:inline-block;padding:14px 28px;background:#2563eb;color:#fff;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:12px}.file-upload-button:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.file-selected{margin-top:16px;padding:12px;background:#f0fdf4;border:1px solid #16a34a;border-radius:6px;color:#16a34a;font-weight:500}@media(max-width:968px){.add-group-section{flex-wrap:wrap}.group-name-input{width:100%}.cell-row{grid-template-columns:1fr;gap:8px}.group-card-header{flex-direction:column;gap:12px;align-items:flex-start}.group-actions{width:100%;flex-wrap:wrap}}@media(max-width:640px){.quota-editor{padding:20px 16px}.editor-header h2{font-size:22px}.add-group-section,.editor-actions{flex-direction:column}.btn-save,.btn-cancel{width:100%;text-align:center}}.survey-xml-editor{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:#1e1e1e}.editor-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#2d2d2d;border-bottom:1px solid #3e3e3e}.toolbar-left{display:flex;gap:8px}.toolbar-center{flex:1;display:flex;justify-content:center}.toolbar-right{display:flex;align-items:center;gap:12px}.tab-switcher{display:flex;background:#1e1e1e;border:1px solid #3e3e3e;border-radius:4px;overflow:hidden}.tab-btn{padding:6px 16px;background:transparent;border:none;color:#ccc;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;border-right:1px solid #3e3e3e}.tab-btn:last-child{border-right:none}.tab-btn:hover{background:#2d2d2d}.tab-btn.active{background:#0e639c;color:#fff}.btn-toolbar{padding:6px 14px;border:1px solid #3e3e3e;border-radius:4px;background:#3c3c3c;color:#ccc;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.btn-toolbar:hover{background:#4c4c4c;border-color:#4e4e4e}.btn-toolbar.btn-primary{background:#0e639c;border-color:#17b;color:#fff}.btn-toolbar.btn-primary:hover{background:#17b}.btn-toolbar.btn-disabled{opacity:.4;cursor:not-allowed}.btn-toolbar.btn-disabled:hover{background:#3c3c3c}.validation-status{font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;padding:4px 12px;border-radius:4px}.validation-status.valid{color:#89d185;background:#89d1851a}.validation-status.invalid{color:#f48771;background:#f487711a}.editor-content{position:relative}.validation-panel{max-height:300px;overflow-y:auto;background:#252526;border-top:1px solid #3e3e3e}.validation-header{padding:12px 16px;background:#2d2d2d;border-bottom:1px solid #3e3e3e}.validation-header h3{margin:0;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;color:#ccc;text-transform:uppercase;letter-spacing:.05em}.validation-errors,.validation-warnings{padding:8px 0}.validation-error,.validation-warning{display:flex;flex-direction:column;gap:4px;padding:8px 16px;border-left:3px solid transparent;transition:background .15s}.validation-error{border-left-color:#f48771}.validation-error:hover{background:#f487710d}.validation-warning{border-left-color:#cca700}.validation-warning:hover{background:#cca7000d}.error-path,.warning-path{font-family:Fira Code,Courier New,monospace;font-size:12px;color:#569cd6}.error-message,.warning-message{font-family:DM Sans,sans-serif;font-size:13px;color:#ccc}.error-message{color:#f48771}.warning-message{color:#cca700}.validation-panel::-webkit-scrollbar{width:10px}.validation-panel::-webkit-scrollbar-track{background:#1e1e1e}.validation-panel::-webkit-scrollbar-thumb{background:#424242;border-radius:5px}.validation-panel::-webkit-scrollbar-thumb:hover{background:#4e4e4e}.xep-page{min-height:100vh;background:#f5f6f8;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1a1a2e}.xep-container{max-width:1600px;margin:0 auto;padding:20px 28px 0}.xep-loading{display:flex;align-items:center;justify-content:center;height:60vh;font-size:15px;color:#6b7280}.xep-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px;flex-wrap:wrap}.xep-header-left{display:flex;align-items:center;gap:14px;min-width:0}.xep-back-btn{flex-shrink:0;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:7px 13px;font-family:inherit;font-size:13px;font-weight:500;color:#374151;cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap}.xep-back-btn:hover{background:#f9fafb;border-color:#9ca3af}.xep-title{margin:0 0 2px;font-size:22px;font-weight:600;letter-spacing:-.02em;color:#1a1a2e;white-space:nowrap}.xep-survey-id{margin:0;font-size:11px;color:#9ca3af;font-family:Fira Code,Consolas,monospace;letter-spacing:.01em}.xep-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.xep-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 15px;font-family:inherit;font-size:13px;font-weight:500;border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s,transform .15s;white-space:nowrap;text-decoration:none;border:1px solid transparent;line-height:1.4}.xep-btn-ghost{background:#fff;color:#374151;border-color:#d1d5db}.xep-btn-ghost:hover{background:#f9fafb;border-color:#9ca3af}.xep-btn-secondary{background:#fff;color:#2563eb;border-color:#bfdbfe}.xep-btn-secondary:hover{background:#eff6ff;border-color:#93c5fd}.xep-btn-ai{background:linear-gradient(135deg,#1b5e20,#2e7d32);color:#fff;border-color:transparent;font-weight:600;letter-spacing:.01em;box-shadow:0 1px 3px #2e7d3233}.xep-btn-ai:hover{background:linear-gradient(135deg,#2e7d32,#388e3c);box-shadow:0 4px 12px #2e7d324d;transform:translateY(-1px)}.xep-banner{padding:10px 16px;margin-bottom:12px;border-radius:6px;font-size:13px;font-weight:500;border:1px solid transparent}.xep-banner-success{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.xep-banner-error{background:#fef2f2;color:#991b1b;border-color:#fecaca}.xep-examples{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:14px 18px;margin-bottom:12px}.xep-examples-label{margin:0 0 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#9ca3af}.xep-examples-grid{display:flex;flex-wrap:wrap;gap:7px}.xep-example-chip{padding:5px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:20px;font-family:inherit;font-size:12px;font-weight:500;color:#374151;cursor:pointer;transition:background .15s,border-color .15s,color .15s;text-transform:capitalize}.xep-example-chip:hover{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8}.xep-modal-overlay{position:fixed;inset:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.xep-modal-card{background:#fff;border-radius:10px;max-width:1200px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 24px 64px #0000002e}@media(max-width:768px){.xep-container{padding:16px 16px 0}.xep-header{flex-direction:column;align-items:flex-start}.xep-actions{width:100%}.xep-title{font-size:18px}}.quota-dashboard{max-width:1400px;margin:0 auto;padding:40px 20px;min-height:100vh;background:#f5f6f8;font-family:DM Sans,-apple-system,sans-serif;color:#1a1a2e}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.dashboard-header h1{margin:0 0 8px;font-size:32px;font-weight:600;letter-spacing:-.02em;color:#1a1a2e}.back-link{display:inline-block;color:#64748b;text-decoration:none;font-size:14px;margin-bottom:12px;transition:color .2s}.back-link:hover{color:#2563eb}.survey-title{margin:0;color:#64748b;font-size:16px}.header-actions{display:flex;gap:12px;align-items:center}.auto-refresh-toggle{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:14px;color:#374151;cursor:pointer;transition:all .2s}.auto-refresh-toggle:hover{background:#f9fafb}.auto-refresh-toggle input[type=checkbox]{cursor:pointer}.btn-primary{padding:10px 20px;background:#2563eb;color:#fff;text-decoration:none;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover{background:#1d4ed8}.btn-secondary{padding:10px 20px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;text-decoration:none;transition:all .2s}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.empty-state{text-align:center;padding:80px 20px;background:#fff;border-radius:12px;border:1px solid #e5e7eb}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state h2{margin:0 0 12px;font-size:24px;font-weight:600;color:#1a1a2e}.empty-state p{margin:0 0 32px;color:#64748b;font-size:16px}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:40px}.summary-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;transition:all .2s}.summary-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000a}.card-label{font-size:13px;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.card-value{font-size:36px;font-weight:700;margin-bottom:8px;color:#1a1a2e}.card-detail{font-size:14px;color:#64748b}.quota-groups{display:flex;flex-direction:column;gap:32px}.quota-group{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.group-header h2{margin:0;font-size:20px;font-weight:600;color:#1a1a2e}.cell-count{font-size:13px;color:#64748b;background:#f1f5f9;padding:4px 12px;border-radius:12px}.quota-cells{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.quota-cell{background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:20px;transition:all .2s}.quota-cell:hover{border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 4px 12px #0000000f}.quota-cell.over_quota{border-color:#f44336}.cell-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.cell-info{flex:1}.cell-label{font-size:16px;font-weight:600;color:#1a1a2e;margin-bottom:4px}.cell-id{font-size:12px;color:#94a3b8;font-family:monospace}.cell-status{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.cell-progress{margin-bottom:12px}.progress-stats{display:flex;align-items:baseline;gap:4px;margin-bottom:8px}.current-count{font-size:28px;font-weight:700;color:#16a34a}.separator{font-size:18px;color:#94a3b8;margin:0 4px}.target-count{font-size:18px;font-weight:600;color:#64748b}.progress-bar{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#16a34a,#22c55e);border-radius:4px;transition:width .3s ease}.progress-fill.full{background:linear-gradient(90deg,#2563eb,#3b82f6)}.progress-fill.over{background:linear-gradient(90deg,#dc2626,#ef4444)}.progress-percent{font-size:13px;color:#64748b;text-align:right}.over-quota-notice{padding:8px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:13px;font-weight:600;margin-bottom:12px}.cell-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid #e5e7eb}.last-updated{font-size:12px;color:#94a3b8}.btn-reset{padding:6px 12px;background:transparent;color:#64748b;border:1px solid #d1d5db;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.btn-reset:hover{background:#dc2626;border-color:#dc2626;color:#fff}.btn-edit{padding:6px 12px;background:transparent;color:#2563eb;border:1px solid #2563eb;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.btn-edit:hover{background:#2563eb;color:#fff}.modal-backdrop{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9998}.edit-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px;min-width:450px;z-index:9999;box-shadow:0 20px 60px #00000026}.edit-modal h3{margin:0 0 24px;font-size:24px;font-weight:600;color:#1a1a2e}.modal-info{background:#f8fafc;border-radius:8px;padding:16px;margin-bottom:24px}.info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e5e7eb}.info-row:last-child{border-bottom:none}.info-label{font-size:14px;color:#64748b}.info-value{font-size:14px;font-weight:600;color:#1a1a2e}.form-group{margin-bottom:24px}.form-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.target-input{width:100%;padding:12px 16px;font-size:16px;background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#1a1a2e;outline:none;transition:border-color .2s}.target-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.btn-cancel{padding:12px 24px;background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#f9fafb}.btn-save{padding:12px 24px;background:#2563eb;border:none;border-radius:8px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-save:hover{background:#1d4ed8}.loading,.error-state{text-align:center;padding:80px 20px}.error-state h2{margin:0 0 12px;color:#dc2626}.error-state p{margin:0 0 24px;color:#64748b}.dashboard-tabs{display:flex;gap:4px;margin-bottom:28px;border-bottom:1px solid #e5e7eb;padding-bottom:0}.dashboard-tab{font-family:DM Sans,-apple-system,sans-serif;font-size:15px;font-weight:500;color:#64748b;background:none;border:none;border-bottom:2px solid transparent;padding:10px 20px;cursor:pointer;transition:color .2s,border-color .2s;display:flex;align-items:center;gap:8px}.dashboard-tab:hover{color:#374151}.dashboard-tab.active{color:#1a1a2e;border-bottom-color:#2563eb}.tab-badge{font-size:11px;font-weight:600;background:#e5e7eb;color:#64748b;padding:2px 8px;border-radius:10px}.dashboard-tab.active .tab-badge{background:#2563eb1a;color:#2563eb}.overview-cards{grid-template-columns:repeat(4,1fr)}@media(max-width:900px){.overview-cards{grid-template-columns:repeat(2,1fr)}}.overview-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;margin-bottom:20px}.section-title{margin:0 0 20px;font-size:18px;font-weight:600;color:#1a1a2e}.funnel-bars{display:flex;flex-direction:column;gap:12px}.funnel-row{display:grid;grid-template-columns:120px 1fr 60px 50px;align-items:center;gap:12px}.funnel-label{font-size:14px;color:#374151;font-weight:500}.funnel-bar-track{height:24px;background:#e2e8f0;border-radius:4px;overflow:hidden}.funnel-bar-fill{height:100%;border-radius:4px;transition:width .4s ease;min-width:0}.funnel-count{font-size:16px;font-weight:700;color:#1a1a2e;text-align:right}.funnel-pct{font-size:13px;color:#64748b;text-align:right}.screenout-reasons{display:flex;flex-direction:column;gap:12px}.reason-row{display:grid;grid-template-columns:1fr auto 120px;align-items:center;gap:16px;padding:12px 16px;background:#f8fafc;border-radius:8px;border-left:3px solid #dc2626}.reason-label{font-size:14px;color:#1a1a2e;font-weight:500}.reason-page{font-size:11px;color:#94a3b8;margin-top:2px;font-family:monospace}.reason-stats{display:flex;align-items:baseline;gap:8px}.reason-count{font-size:20px;font-weight:700;color:#dc2626}.reason-pct{font-size:13px;color:#64748b}.reason-bar-track{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.reason-bar-fill{height:100%;background:linear-gradient(90deg,#dc2626,#ef4444);border-radius:3px;transition:width .3s ease}.quota-summary-grid{display:flex;flex-direction:column;gap:12px}.quota-summary-row{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:20px;padding:12px 16px;background:#f8fafc;border-radius:8px}.quota-summary-name{font-size:15px;font-weight:600;color:#1a1a2e}.quota-summary-detail{font-size:12px;color:#64748b;margin-top:2px}.quota-summary-progress{display:flex;align-items:center;gap:12px}.quota-summary-progress .progress-bar{flex:1}.quota-summary-pct{font-size:14px;font-weight:600;color:#64748b;min-width:40px;text-align:right}@media(max-width:968px){.dashboard-header{flex-direction:column;gap:16px}.header-actions{flex-wrap:wrap;width:100%}.summary-cards,.quota-cells{grid-template-columns:1fr}.funnel-row{grid-template-columns:100px 1fr 50px 40px;gap:8px}.reason-row{grid-template-columns:1fr;gap:8px}}@media(max-width:640px){.quota-dashboard{padding:24px 16px}.dashboard-header h1{font-size:24px}.header-actions{flex-direction:column}.header-actions .btn-primary,.header-actions .btn-secondary{width:100%;text-align:center}.auto-refresh-toggle{width:100%;justify-content:center}.funnel-row{grid-template-columns:80px 1fr 40px 35px;gap:6px}.funnel-label{font-size:12px}.quota-summary-row{grid-template-columns:1fr;gap:8px}}.data-export-page{max-width:1200px;margin:0 auto;padding:40px 20px;min-height:100vh;background:#f5f6f8}.export-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.header-left{display:flex;flex-direction:column;gap:8px}.btn-back-link{font-family:DM Sans,sans-serif;font-size:14px;color:#718096;text-decoration:none;transition:color .2s}.btn-back-link:hover{color:#2563eb}.export-header h1{font-family:DM Sans,sans-serif;font-size:32px;font-weight:600;color:#1a1a2e;margin:0}.survey-name{font-family:DM Sans,sans-serif;font-size:14px;color:#718096;margin:0}.export-container{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media(max-width:968px){.export-container{grid-template-columns:1fr}}.export-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;transition:box-shadow .2s}.export-card:hover{box-shadow:0 4px 12px #00000014}.export-card-header{display:flex;align-items:center;gap:12px;padding:24px 24px 16px;border-bottom:1px solid #e2e8f0}.export-icon{font-size:32px;line-height:1}.export-card-header h2{font-family:DM Sans,sans-serif;font-size:20px;font-weight:500;color:#1a1a1a;margin:0}.export-card-body{padding:24px}.export-description{font-family:DM Sans,sans-serif;font-size:15px;color:#4a5568;margin:0 0 24px}.export-info{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;padding:16px;background:#f7fafc;border-radius:6px}.info-item{display:flex;justify-content:space-between;align-items:center}.info-label{font-family:DM Sans,sans-serif;font-size:14px;color:#718096}.info-value{font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;color:#2d3748}.column-format-info{margin-bottom:24px;padding:16px;background:#edf2f7;border-radius:6px;border-left:3px solid #2563eb}.column-format-info h3{font-family:DM Sans,sans-serif;font-size:15px;font-weight:500;color:#2d3748;margin:0 0 12px}.column-format-info ul{margin:0;padding-left:20px}.column-format-info li{font-family:DM Sans,sans-serif;font-size:14px;color:#4a5568;margin-bottom:8px}.column-format-info code{background:#fff;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:13px;color:#2563eb}.btn-export{width:100%;font-family:DM Sans,sans-serif;font-size:15px;font-weight:500;padding:14px 24px;background:#2563eb;color:#fff;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .2s,transform .15s}.btn-export:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px)}.btn-export:active:not(:disabled){transform:translateY(0)}.btn-export:disabled{background:#cbd5e0;cursor:not-allowed;opacity:.6}.spinner{width:16px;height:16px;border:2px solid #ffffff40;border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.no-data-message{text-align:center;padding:32px 16px;background:#f7fafc;border-radius:6px;margin-bottom:16px}.no-data-message p{font-family:DM Sans,sans-serif;font-size:15px;color:#4a5568;margin:0 0 8px}.no-data-message .hint{font-size:13px;color:#718096}.error-message-inline{margin-top:16px;padding:12px 16px;background:#fee2e2;border:1px solid #fecaca;border-radius:6px;color:#991b1b;font-family:DM Sans,sans-serif;font-size:14px;display:flex;align-items:center;gap:8px}.error-icon{font-size:16px}.format-example{margin-bottom:24px}.format-example:last-child{margin-bottom:0}.format-example h4{font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;color:#2d3748;margin:0 0 12px}.example-table{width:100%;border-collapse:collapse;font-family:DM Sans,sans-serif;font-size:13px;margin-bottom:8px}.example-table th{background:#f7fafc;color:#4a5568;font-weight:500;text-align:left;padding:8px 12px;border:1px solid #e2e8f0}.example-table td{color:#2d3748;padding:8px 12px;border:1px solid #e2e8f0}.example-table tbody tr:nth-child(2n){background:#f7fafc}.example-note{font-family:DM Sans,sans-serif;font-size:12px;color:#718096;font-style:italic;margin:4px 0 0}.loading,.error-message{text-align:center;padding:48px 24px;font-family:DM Sans,sans-serif;font-size:15px;color:#4a5568}.error-message{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px}.btn-back{display:inline-block;font-family:DM Sans,sans-serif;font-size:14px;padding:10px 20px;background:#fff;color:#2d3748;border:1px solid #e2e8f0;border-radius:6px;text-decoration:none;transition:all .2s}.btn-back:hover{border-color:#cbd5e0;background:#f7fafc}@media(max-width:640px){.data-export-page{padding:24px 16px}.export-header h1{font-size:24px}.export-card-body{padding:16px}.info-item{flex-direction:column;align-items:flex-start;gap:4px}}.reporting-dashboard{max-width:1600px;margin:0 auto;padding:40px 24px;font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;color:#e8e8e8;min-height:100vh}.reporting-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px;color:#aaa}.loading-spinner{width:40px;height:40px;border:3px solid #333;border-top-color:#7c4dff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.reporting-error{text-align:center;padding:80px 20px;background:#1e1e1e;border-radius:12px;border:1px solid #3a3a3a}.reporting-error h2{color:#f44336;margin-bottom:12px}.reporting-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px}.reporting-header-left{flex:1}.btn-back-link{display:inline-block;color:#888;text-decoration:none;font-size:13px;margin-bottom:8px;transition:color .2s}.btn-back-link:hover{color:#7c4dff}.reporting-header h1{margin:0 0 6px;font-size:28px;font-weight:700;letter-spacing:-.02em;color:#fff}.reporting-survey-name{margin:0;color:#888;font-size:14px}.reporting-header-right{display:flex;align-items:center;gap:12px}.test-data-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:#888;cursor:pointer;-webkit-user-select:none;user-select:none}.test-data-toggle input{accent-color:#7C4DFF;cursor:pointer}.test-data-badge{font-size:10px;font-weight:700;padding:3px 8px;background:#ff980033;color:#ffb74d;border-radius:4px;letter-spacing:.5px}.response-count-badge{padding:8px 16px;background:#1e1e1e;border:1px solid #333;border-radius:8px;font-size:13px;color:#aaa;font-variant-numeric:tabular-nums}.filters-bar{display:flex;gap:12px;flex-wrap:wrap;padding:16px 20px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:10px;margin-bottom:16px}.filter-group{display:flex;flex-direction:column;gap:4px;min-width:140px}.filter-group label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#777;font-weight:600}.filter-group select{padding:8px 12px;background:#252525;border:1px solid #3a3a3a;border-radius:6px;color:#ddd;font-size:13px;font-family:inherit;cursor:pointer;transition:border-color .2s}.filter-group select:hover{border-color:#555}.filter-group select:focus{outline:none;border-color:#7c4dff}.reporting-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:2px solid #2a2a2a}.reporting-tab{padding:12px 24px;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:#777;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.reporting-tab:hover{color:#ccc}.reporting-tab.active{color:#fff;border-bottom-color:#7c4dff}.tab-badge{font-size:11px;font-weight:500;padding:2px 8px;background:#7c4dff22;color:#b388ff;border-radius:10px;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.overview-controls{display:flex;justify-content:flex-end;margin-bottom:16px}.overview-table{cursor:default}.overview-row{cursor:pointer}.overview-row:hover{background:#252525!important}.rank-col{width:44px;text-align:center}.overview-company-col{min-width:240px}.rank-cell{text-align:center}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;font-size:12px;font-weight:700;background:#252525;color:#888;font-variant-numeric:tabular-nums}.rank-badge.rank-top{background:#7c4dff33;color:#b388ff}.overview-company-cell{display:flex;flex-direction:column;gap:2px}.overview-company-name{font-weight:600;color:#e0e0e0;font-size:14px}.overview-attr-count{font-size:11px;color:#666}.overview-best-worst{display:flex;flex-direction:column;align-items:center;gap:1px}.overview-attr-label{font-size:10px;color:#666;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.action-col{width:36px;text-align:center}.action-cell{text-align:center}.drill-arrow{color:#555;font-size:16px;font-weight:700;transition:color .2s}.overview-row:hover .drill-arrow{color:#7c4dff}.link-btn{background:none;border:none;color:#7c4dff;font-size:inherit;font-family:inherit;cursor:pointer;text-decoration:underline;padding:0}.link-btn:hover{color:#b388ff}.controls-bar{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:16px}.subject-selector{display:flex;flex-direction:column;gap:4px;flex:1;max-width:400px}.subject-selector label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#777;font-weight:600}.subject-select{padding:10px 14px;background:#1e1e1e;border:1px solid #7C4DFF44;border-radius:8px;color:#fff;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s}.subject-select:hover{border-color:#7c4dff88}.subject-select:focus{outline:none;border-color:#7c4dff;box-shadow:0 0 0 3px #7c4dff26}.view-controls{display:flex;gap:12px;align-items:center}.score-toggle{display:flex;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;overflow:hidden}.score-toggle button{padding:8px 16px;background:transparent;border:none;color:#888;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}.score-toggle button:hover{color:#ccc;background:#252525}.score-toggle button.active{background:#7c4dff;color:#fff}.extra-toggles{display:flex;gap:8px}.toggle-btn{padding:8px 14px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;color:#888;font-size:13px;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}.toggle-btn:hover:not(:disabled){border-color:#444;color:#ccc}.toggle-btn.active{background:#2d1f5e;border-color:#7c4dff66;color:#b388ff}.toggle-btn:disabled{opacity:.4;cursor:not-allowed}.compare-bar{display:flex;gap:20px;align-items:flex-end;flex-wrap:wrap;margin-bottom:24px}.compare-selector,.sort-control{display:flex;flex-direction:column;gap:4px}.compare-selector{min-width:300px}.compare-selector label,.sort-control label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#777;font-weight:600}.compare-selector select,.sort-control select{padding:8px 12px;background:#252525;border:1px solid #3a3a3a;border-radius:6px;color:#ddd;font-size:13px;font-family:inherit;cursor:pointer;transition:border-color .2s}.compare-selector select:focus,.sort-control select:focus{outline:none;border-color:#7c4dff}.summary-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:10px;padding:20px;transition:border-color .2s}.stat-card:hover{border-color:#3a3a3a}.stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#777;margin-bottom:8px;font-weight:600}.stat-value{font-size:28px;font-weight:700;color:#fff;margin-bottom:4px;font-variant-numeric:tabular-nums}.stat-value.accent{color:#4caf50}.stat-value.warn{color:#ff9800}.stat-sub{font-size:12px;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-prompt{text-align:center;padding:80px 20px;background:#1a1a1a;border:1px dashed #333;border-radius:12px;margin-top:20px}.empty-prompt .empty-icon{font-size:56px;margin-bottom:16px}.empty-prompt h2{font-size:22px;margin:0 0 8px;color:#ccc}.empty-prompt p{color:#777;font-size:14px;margin:0}.results-section{margin-bottom:40px}.results-table{width:100%;border-collapse:separate;border-spacing:0;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:10px;overflow:hidden;font-size:13px}.results-table thead th{padding:14px 16px;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#888;font-weight:600;background:#151515;border-bottom:1px solid #2a2a2a;white-space:nowrap;position:sticky;top:0;z-index:1}.results-table tbody tr{transition:background .15s}.results-table tbody tr:hover{background:#222}.results-table tbody td{padding:12px 16px;border-bottom:1px solid #1f1f1f;vertical-align:top}.results-table tbody tr:last-child td{border-bottom:none}.attr-col{min-width:220px}.score-col{width:100px;text-align:center}.n-col,.nc-col{width:50px;text-align:center}.diff-col{width:70px;text-align:center}.trend-col{width:160px}.pct-col{min-width:320px}.attr-cell{color:#ccc;font-weight:500}.score-cell{text-align:center}.score-value{font-weight:700;font-size:15px;font-variant-numeric:tabular-nums}.n-cell,.nc-cell{text-align:center;color:#666;font-size:12px;font-variant-numeric:tabular-nums}.diff-cell{text-align:center;font-weight:600;font-variant-numeric:tabular-nums}.compare-col,.compare-cell{border-left:2px solid #2a2a2a}.no-data{color:#444}.pct-cell{padding:10px 16px}.dist-container{width:100%;display:flex;flex-direction:column;gap:2px}.dist-year-label{font-size:11px;font-weight:700;color:#888;min-width:36px;flex-shrink:0;font-variant-numeric:tabular-nums}.dist-bar{display:flex;height:24px;border-radius:4px;overflow:hidden;background:#252525;flex:1}.dist-bar-compact{height:20px}.dist-segment{min-width:2px;transition:width .3s ease;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.dist-segment-label{font-size:10px;font-weight:700;line-height:1;white-space:nowrap;text-shadow:0 0 3px rgba(0,0,0,.4);font-variant-numeric:tabular-nums}.dist-labels{display:flex;justify-content:space-between;font-size:11px;font-weight:600}.trend-pct-stack{display:flex;flex-direction:column;gap:6px}.trend-pct-row{display:flex;align-items:center;gap:8px}.trend-pct-row .dist-container{flex:1;gap:1px}.trend-pct-row .dist-labels{font-size:10px}.b2b-label{color:#ff7043}.t2b-label{color:#4caf50}.pct-detail{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;font-size:11px}.pct-code{padding:2px 6px;background:#252525;border-radius:3px;color:#aaa;font-variant-numeric:tabular-nums}.pct-box{padding:2px 8px;border-radius:3px;font-weight:600}.pct-box.t3b{background:#4caf5026;color:#66bb6a}.pct-box.b3b{background:#f4433626;color:#ef5350}.pct-n{color:#555;font-style:italic}.trend-container{display:flex;align-items:center;gap:8px}.trend-svg{flex-shrink:0}.trend-diff{font-size:12px;font-weight:700;white-space:nowrap;font-variant-numeric:tabular-nums}.company-breakdown{margin-top:28px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:10px;padding:24px;overflow-x:auto}.company-breakdown h3{margin:0 0 6px;font-size:16px;color:#ccc}.breakdown-note{font-size:12px;color:#666;margin:0 0 16px}.breakdown-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px}.breakdown-table thead th{padding:10px 12px;text-align:center;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:#777;font-weight:600;background:#151515;border-bottom:1px solid #2a2a2a;white-space:nowrap}.breakdown-table thead th:first-child{text-align:left;min-width:200px}.breakdown-table tbody td{padding:8px 12px;border-bottom:1px solid #1f1f1f;text-align:center}.breakdown-table tbody tr:hover{background:#222}.breakdown-cell{font-variant-numeric:tabular-nums}.breakdown-n{color:#555;font-size:10px}.reporting-footer{margin-top:40px;padding-top:20px;border-top:1px solid #2a2a2a}.reporting-footer p{font-size:12px;color:#555;line-height:1.6;max-width:700px}@media(max-width:1024px){.filters-bar{gap:8px}.filter-group{min-width:120px}.controls-bar{flex-direction:column;align-items:stretch}.subject-selector{max-width:100%}.view-controls{flex-wrap:wrap}}@media(max-width:768px){.reporting-header{flex-direction:column;gap:12px}.summary-row{grid-template-columns:1fr 1fr}.results-table{font-size:12px}}.analyst-tab{display:flex;flex-direction:column;min-height:500px;max-height:calc(100vh - 280px)}.analyst-container{display:flex;flex-direction:column;flex:1;background:#0d0d1a;border:1px solid #1e1e3a;border-radius:12px;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:20px;min-height:300px;max-height:calc(100vh - 420px)}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#333;border-radius:3px}.chat-welcome{display:flex;flex-direction:column;align-items:center;text-align:center;padding:40px 20px;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-welcome-icon{font-size:48px;margin-bottom:12px}.chat-welcome h3{font-size:22px;font-weight:700;color:#e0e0e0;margin:0 0 8px}.chat-welcome p{color:#888;font-size:14px;max-width:500px;line-height:1.5;margin:0 0 6px}.chat-welcome-note{color:#666;font-size:13px;margin-top:4px}.chat-welcome-note strong{color:#7c4dff}.chat-suggestions{margin-top:24px;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:600px}.suggestions-label{width:100%;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#555;margin-bottom:4px}.suggestion-chip{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:20px;padding:8px 16px;color:#aaa;font-size:13px;cursor:pointer;transition:all .2s}.suggestion-chip:hover{background:#252545;border-color:#7c4dff;color:#ccc}.chat-message{display:flex;flex-direction:column;gap:8px;animation:msgIn .3s ease}@keyframes msgIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-message.user{align-items:flex-end}.chat-message-header{display:flex;align-items:center;gap:6px}.chat-message.user .chat-message-header{flex-direction:row-reverse}.chat-avatar{font-size:16px}.chat-role{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#666;font-weight:600}.chat-message-body{max-width:85%;line-height:1.6}.chat-message.user .chat-message-body{background:#7c4dff22;border:1px solid #7C4DFF44;border-radius:16px 16px 4px;padding:12px 18px;color:#d0d0d0;font-size:14px}.chat-message.user .chat-message-body p{margin:0}.chat-message.assistant .chat-message-body{background:#12122a;border:1px solid #1e1e3a;border-radius:16px 16px 16px 4px;padding:16px 20px;color:silver;font-size:14px}.chat-message.error .chat-message-body{border-color:#ff6b6b44;background:#1a0a0a}.ai-paragraph{margin:0 0 10px;line-height:1.6}.ai-paragraph:last-child{margin-bottom:0}.ai-paragraph strong{color:#e0e0e0}.ai-list{margin:8px 0;padding-left:20px}.ai-list li{margin-bottom:6px;line-height:1.5}.ai-list li strong{color:#e0e0e0}.chat-typing{display:flex;gap:5px;padding:4px 0}.chat-typing span{width:8px;height:8px;border-radius:50%;background:#7c4dff;animation:typing 1.2s ease-in-out infinite}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}.chat-input-area{border-top:1px solid #1e1e3a;padding:16px 20px;background:#0a0a18}.chat-input-row{display:flex;gap:10px}.chat-input{flex:1;background:#12122a;border:1px solid #2a2a4a;border-radius:10px;padding:12px 16px;color:#e0e0e0;font-size:14px;outline:none;transition:border-color .2s}.chat-input:focus{border-color:#7c4dff}.chat-input::placeholder{color:#555}.chat-input:disabled{opacity:.5}.chat-send-btn{background:#7c4dff;color:#fff;border:none;border-radius:10px;padding:12px 24px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.chat-send-btn:hover:not(:disabled){background:#6a3de8}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-clear-btn{background:none;border:1px solid #333;border-radius:6px;padding:4px 12px;color:#666;font-size:11px;cursor:pointer;align-self:flex-end;margin-bottom:8px;transition:all .2s}.chat-clear-btn:hover{border-color:#ff6b6b;color:#ff6b6b}.chat-disclaimer{font-size:11px;color:#444;margin:8px 0 0;text-align:center}.ai-viz{margin:16px 0 8px;background:#0d0d1a;border:1px solid #1e1e3a;border-radius:10px;padding:16px;overflow-x:auto}.ai-viz-title{font-size:13px;font-weight:700;color:#aaa;text-transform:uppercase;letter-spacing:.5px;margin:0 0 14px;padding-bottom:8px;border-bottom:1px solid #1a1a30}.chart-empty{color:#555;font-style:italic;text-align:center;padding:20px}.chart-hbar{display:flex;flex-direction:column;gap:6px}.hbar-row{display:flex;align-items:center;gap:12px;min-height:28px}.hbar-label{width:180px;min-width:180px;font-size:12px;color:#bbb;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hbar-bars{flex:1;display:flex;flex-direction:column;gap:3px}.hbar-track{height:22px;background:#1a1a2e;border-radius:4px;position:relative;overflow:hidden}.hbar-fill{height:100%;border-radius:4px;transition:width .6s ease;min-width:2px}.hbar-value{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:11px;font-weight:600;color:#ddd;text-shadow:0 0 4px rgba(0,0,0,.8)}.chart-vbar{overflow-x:auto}.vbar-area{display:flex;align-items:flex-end;gap:8px;padding:0 8px;border-bottom:1px solid #2a2a4a}.vbar-group{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;min-width:30px}.vbar-group{display:flex;flex-direction:row;align-items:flex-end;justify-content:center;gap:2px;position:relative;padding-bottom:24px}.vbar-bar{border-radius:4px 4px 0 0;display:flex;align-items:flex-start;justify-content:center;transition:height .6s ease;min-height:4px}.vbar-val{font-size:9px;font-weight:600;color:#ddd;margin-top:4px;text-shadow:0 0 4px rgba(0,0,0,.8)}.vbar-label{position:absolute;bottom:0;font-size:10px;color:#888;text-align:center;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transform:rotate(-30deg);transform-origin:top center}.chart-radar{display:flex;flex-direction:column;align-items:center}.radar-svg{max-width:400px;width:100%}.radar-ring{fill:none;stroke:#1e1e3a;stroke-width:.5}.radar-axis{stroke:#1e1e3a;stroke-width:.5}.radar-polygon{stroke-width:2;fill-opacity:.1}.radar-label{fill:#888;font-size:9px}.chart-line{overflow-x:auto}.line-svg{max-width:100%;width:100%}.grid-line{stroke:#1e1e3a;stroke-width:.5}.axis-label{fill:#888;font-size:10px}.point-label{font-size:9px;font-weight:600}.chart-table-wrap{overflow-x:auto}.chart-table{width:100%;border-collapse:collapse;font-size:13px}.chart-table th{background:#1a1a2e;color:#aaa;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.3px;padding:8px 12px;text-align:left;border-bottom:1px solid #2a2a4a;white-space:nowrap}.chart-table td{padding:7px 12px;border-bottom:1px solid #141428;color:#ccc}.chart-table tbody tr:hover{background:#14142a}.chart-metrics{display:flex;flex-wrap:wrap;gap:12px}.chart-metric-card{flex:1;min-width:120px;max-width:200px;background:#12122a;border:1px solid #1e1e3a;border-left:3px solid;border-radius:8px;padding:14px 16px;text-align:center}.metric-value{font-size:28px;font-weight:800;line-height:1;margin-bottom:4px}.metric-label{font-size:12px;color:#aaa;font-weight:600}.metric-sub{font-size:11px;color:#666;margin-top:4px}.chart-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px;justify-content:center}.legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:#999}.legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.ai-viz-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.ai-viz-header .ai-viz-title{margin:0;padding:0;border:none}.ai-viz-actions{display:flex;gap:6px;flex-shrink:0}.viz-export-btn{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:6px;padding:4px 10px;color:#888;font-size:11px;cursor:pointer;transition:all .2s;white-space:nowrap}.viz-export-btn:hover:not(:disabled){background:#252545;border-color:#7c4dff;color:#ccc}.viz-export-btn:disabled{opacity:.4;cursor:not-allowed}.ai-viz-content{padding:4px;max-width:620px}.ai-viz-content .chart-line,.ai-viz-content .chart-radar,.ai-viz-content .chart-table-wrap,.ai-viz-content .metric-cards-grid{max-width:600px}.ai-message-export{margin-top:14px;padding-top:12px;border-top:1px solid #1a1a30;display:flex;justify-content:flex-end}.pptx-export-btn{background:linear-gradient(135deg,#1a1a2e,#252545);border:1px solid #7C4DFF44;border-radius:8px;padding:8px 18px;color:#bbb;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.pptx-export-btn:hover:not(:disabled){background:linear-gradient(135deg,#252545,#2a2a5a);border-color:#7c4dff;color:#e0e0e0;box-shadow:0 0 12px #7c4dff26}.pptx-export-btn:disabled{opacity:.5;cursor:not-allowed}.breakdown-overall-row{border-bottom:2px solid #7C4DFF44;background:#1a1a2e}.breakdown-overall-row td{padding-top:10px;padding-bottom:10px}.ba-groups-tab{margin-left:auto!important;background:transparent!important;border:1px dashed #3a3a5a!important;color:#888!important;font-size:12px!important;padding:6px 14px!important;cursor:pointer}.ba-groups-tab:hover{border-color:#7c4dff!important;color:#7c4dff!important}.ba-editor-overlay{position:fixed;inset:0;background:#000000b3;z-index:1000;display:flex;align-items:center;justify-content:center}.ba-editor-modal{background:#12122a;border:1px solid #2a2a4a;border-radius:12px;width:90%;max-width:800px;max-height:85vh;display:flex;flex-direction:column}.ba-editor-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #1e1e3a}.ba-editor-header h3{margin:0;color:#ddd;font-size:16px}.ba-close-btn{background:none;border:none;color:#888;font-size:22px;cursor:pointer}.ba-close-btn:hover{color:#fff}.ba-editor-body{padding:16px 20px;overflow-y:auto;flex:1}.ba-group-card{background:#0d0d1a;border:1px solid #1e1e3a;border-radius:8px;padding:14px;margin-bottom:12px}.ba-group-header{display:flex;gap:10px;align-items:center;margin-bottom:10px}.ba-name-input{flex:1;background:#1a1a2e;border:1px solid #2a2a4a;border-radius:6px;color:#ddd;padding:8px 12px;font-size:14px;font-weight:600}.ba-name-input:focus{border-color:#7c4dff;outline:none}.ba-remove-group{background:none;border:1px solid #FF6B6B33;color:#ff6b6b;border-radius:6px;padding:6px 12px;cursor:pointer;font-size:12px}.ba-remove-group:hover{background:#ff6b6b22}.ba-attr-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:4px;max-height:200px;overflow-y:auto;padding:4px 0}.ba-attr-item{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:12px;color:#999}.ba-attr-item:hover{background:#1a1a2e}.ba-attr-item.active{background:#7c4dff15;color:#ddd}.ba-attr-item.used{opacity:.5}.ba-attr-item input[type=checkbox]{accent-color:#7C4DFF}.ba-attr-label{flex:1}.ba-attr-used{font-size:10px;color:#666;font-style:italic}.ba-attr-count{font-size:11px;color:#666;margin-top:6px;text-align:right}.ba-add-group{display:block;width:100%;padding:10px;background:none;border:1px dashed #2a2a4a;border-radius:8px;color:#7c4dff;cursor:pointer;font-size:13px;margin-top:4px}.ba-add-group:hover{border-color:#7c4dff;background:#7c4dff08}.ba-editor-footer{padding:12px 20px;border-top:1px solid #1e1e3a;display:flex;gap:8px;justify-content:flex-end}.ba-save-btn{background:#7c4dff;color:#fff;border:none;border-radius:6px;padding:8px 24px;cursor:pointer;font-weight:600}.ba-save-btn:hover{background:#6a3de8}.ba-save-btn:disabled{opacity:.5}.ba-cancel-btn{background:none;border:1px solid #2a2a4a;color:#888;border-radius:6px;padding:8px 16px;cursor:pointer}.ba-cancel-btn:hover{border-color:#888;color:#ccc}.ba-scores-section{margin-bottom:20px}.ba-scores-title{font-size:13px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.ba-scores-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.ba-score-card{background:#0d0d1a;border:1px solid #1e1e3a;border-radius:10px;padding:14px 16px}.ba-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.ba-card-name{font-weight:700;color:#ddd;font-size:14px}.ba-card-avg{font-weight:700;color:#7c4dff;font-size:20px}.ba-card-attrs{font-size:11px;color:#666;margin-bottom:10px}.ba-mini-ranking{border-top:1px solid #1a1a2e;padding-top:8px}.ba-mini-row{display:flex;align-items:center;gap:6px;padding:2px 0;font-size:12px}.ba-mini-rank{color:#555;width:18px;text-align:right}.ba-mini-name{flex:1;color:#aaa;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ba-mini-score{color:#7c4dff;font-weight:600;min-width:40px;text-align:right}.ba-mini-more{font-size:11px;color:#555;text-align:center;margin-top:4px}.ba-tab{padding:0 0 20px}.ba-section-title{font-size:13px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px;margin:20px 0 12px;padding-bottom:6px;border-bottom:1px solid #1e1e3a}.ba-crosstab-wrap{overflow-x:auto;margin-bottom:8px}.ba-crosstab .ba-col-header{font-size:11px;max-width:120px;white-space:normal;line-height:1.3}.ba-crosstab .alt-row{background:#0a0a18}.ba-breakdown-section{margin-top:10px}.ba-breakdown-card{background:#0d0d1a;border:1px solid #1e1e3a;border-radius:10px;margin-bottom:10px;overflow:hidden}.ba-breakdown-card.expanded{border-color:#7c4dff40}.ba-breakdown-header{display:flex;align-items:center;gap:12px;padding:14px 18px;cursor:pointer}.ba-breakdown-header:hover{background:#12122a}.ba-breakdown-info{flex:1}.ba-breakdown-name{font-weight:700;color:#ddd;font-size:15px;display:block}.ba-breakdown-meta{font-size:11px;color:#666;margin-top:2px;display:block}.ba-breakdown-score{font-size:22px;font-weight:700;min-width:60px;text-align:right}.ba-expand-arrow{color:#555;font-size:12px;width:20px;text-align:center}.ba-breakdown-body{padding:0 18px 18px}.ba-detail-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px}.ba-detail-cols h4{font-size:12px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.3px;margin:0 0 8px}.ba-ranking-table,.ba-attrs-table{font-size:13px}.ba-ranking-table .rank-cell{width:30px}.highlighted-row{background:#7c4dff15!important}.highlighted-row td{color:#ddd!important}.primary-btn{background:#7c4dff;color:#fff;border:none;border-radius:8px;padding:10px 24px;cursor:pointer;font-weight:600;font-size:14px;margin-top:12px}.primary-btn:hover{background:#6a3de8}.builder-tab{padding:0}.builder-layout{display:grid;grid-template-columns:340px 1fr;gap:0;min-height:700px}.builder-sidebar{border-right:1px solid #1e1e3a;padding:16px;overflow-y:auto;max-height:800px}.builder-section-title{font-size:12px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px;margin:0 0 10px}.builder-textarea{width:100%;background:#0a0a18;border:1px solid #1e1e3a;border-radius:8px;color:#ddd;padding:10px;font-size:13px;resize:vertical;font-family:inherit}.builder-textarea:focus{border-color:#7c4dff;outline:none}.builder-conversation{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;margin-bottom:10px;padding:8px;background:#0a0a18;border-radius:8px;border:1px solid #1e1e3a}.builder-msg{padding:8px 12px;border-radius:8px;font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.builder-msg-user{background:#7c4dff30;color:#c8b0ff;align-self:flex-end;max-width:85%;border-bottom-right-radius:2px}.builder-msg-assistant{background:#12122a;color:#ddd;align-self:flex-start;max-width:90%;border:1px solid #1e1e3a;border-bottom-left-radius:2px}.builder-msg-system{background:transparent;color:#4caf50;font-size:12px;text-align:center;align-self:center;padding:4px 8px}.builder-msg-text{display:block}.builder-image-upload{margin:10px 0;display:flex;align-items:center;gap:10px}.builder-image-thumb{position:relative;width:60px;height:60px;border-radius:6px;overflow:hidden;border:1px solid #1e1e3a}.builder-image-thumb img{width:100%;height:100%;object-fit:cover}.builder-remove-img{position:absolute;top:2px;right:2px;background:#ff6b6b;color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:10px;cursor:pointer}.builder-actions{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.builder-generate-btn{min-width:160px}.builder-error{background:#ff6b6b20;border:1px solid #FF6B6B40;border-radius:8px;padding:10px;color:#ff6b6b;font-size:13px;margin:8px 0}.builder-refine{background:#7c4dff10;border:1px solid #7C4DFF30;border-radius:8px;padding:10px;margin:8px 0}.builder-refine-hint{font-size:12px;color:#aaa;margin:0}.builder-saved-section{margin-top:20px;border-top:1px solid #1e1e3a;padding-top:16px}.builder-empty-saved{color:#555;font-size:13px}.builder-saved-list{display:flex;flex-direction:column;gap:6px}.builder-saved-card{display:flex;align-items:center;justify-content:space-between;background:#0a0a18;border:1px solid #1e1e3a;border-radius:8px;padding:8px 12px}.builder-saved-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.builder-saved-title{font-size:13px;color:#ddd;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.builder-saved-date{font-size:11px;color:#555}.builder-saved-actions{display:flex;gap:4px;flex-shrink:0}.builder-mini-btn{background:#1e1e3a;border:1px solid #2e2e4a;border-radius:4px;color:#aaa;padding:3px 8px;font-size:11px;cursor:pointer}.builder-mini-btn:hover{background:#2e2e4a;color:#ddd}.builder-mini-btn.danger:hover{background:#ff6b6b30;color:#ff6b6b}.builder-preview{display:flex;flex-direction:column;min-height:0}.builder-preview-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;flex:1}.builder-preview-placeholder h3{color:#ddd;margin:10px 0 6px}.builder-preview-placeholder p{color:#666;font-size:14px;max-width:500px}.builder-preview-header{display:flex;align-items:center;padding:8px 12px;border-bottom:1px solid #1e1e3a}.builder-title-input{flex:1;background:transparent;border:1px solid transparent;color:#ddd;font-size:15px;font-weight:700;padding:4px 8px;border-radius:4px}.builder-title-input:focus{border-color:#7c4dff;outline:none;background:#0a0a18}.builder-iframe{flex:1;border:none;width:100%;min-height:650px;background:#0d0d1a}.builder-suggestions{margin-top:16px}.tpl-section{display:flex;flex-direction:column;height:calc(100vh - 160px);min-height:0}.tpl-toolbar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#0d0d1a;border-bottom:1px solid #1e1e3a;flex-shrink:0;flex-wrap:wrap}.tpl-spacer{flex:1}.tpl-btn{padding:7px 14px;background:#1a1a2e;border:1px solid #2a2a4a;border-radius:6px;color:#ccc;font-size:13px;cursor:pointer;white-space:nowrap;transition:all .15s}.tpl-btn:hover:not(:disabled){background:#252545;border-color:#7c4dff;color:#fff}.tpl-btn:disabled{opacity:.4;cursor:not-allowed}.tpl-btn-primary{background:#7c4dff;border-color:#7c4dff;color:#fff;font-weight:600}.tpl-btn-primary:hover:not(:disabled){background:#6a3de8;border-color:#6a3de8}.tpl-btn-export{background:#1a3a1a;border-color:#2ecc71;color:#2ecc71;font-weight:600}.tpl-btn-export:hover:not(:disabled){background:#2ecc71;color:#000}.tpl-error{font-size:12px;color:#ff6b6b;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tpl-chart-prompt-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#0a0a1f;border-bottom:1px solid #2a2a4a;flex-shrink:0}.tpl-prompt-label{font-size:13px;color:#aaa;white-space:nowrap}.tpl-prompt-input{flex:1;background:#13132a;border:1px solid #2a2a4a;border-radius:6px;color:#fff;padding:7px 12px;font-size:13px;font-family:inherit;min-width:0}.tpl-prompt-input:focus{outline:none;border-color:#7c4dff}.tpl-body{display:flex;flex:1;min-height:0;overflow:hidden}.tpl-sidebar{width:190px;flex-shrink:0;background:#07071a;border-right:1px solid #1e1e3a;overflow-y:auto;padding:10px 8px;display:flex;flex-direction:column;gap:6px}.tpl-sidebar-label{font-size:10px;font-weight:700;letter-spacing:1px;color:#555;padding:4px 6px}.tpl-empty-pages{text-align:center;padding:20px 8px;color:#555;font-size:13px}.tpl-empty-pages p{margin:0 0 12px}.tpl-page-thumb{display:flex;align-items:center;gap:8px;padding:8px;border-radius:6px;cursor:pointer;border:1px solid transparent;transition:all .15s}.tpl-page-thumb:hover{background:#13132a;border-color:#2a2a4a}.tpl-page-thumb.active{background:#1a1040;border-color:#7c4dff}.tpl-thumb-number{width:22px;height:22px;border-radius:4px;background:#2a2a4a;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#aaa;flex-shrink:0}.tpl-page-thumb.active .tpl-thumb-number{background:#7c4dff;color:#fff}.tpl-thumb-info{flex:1;min-width:0}.tpl-thumb-title{font-size:12px;color:#ddd;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tpl-thumb-count{font-size:10px;color:#666;margin-top:1px}.tpl-thumb-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s}.tpl-page-thumb:hover .tpl-thumb-actions{opacity:1}.tpl-icon-btn{background:none;border:none;color:#888;font-size:11px;cursor:pointer;padding:2px 4px;border-radius:3px;line-height:1}.tpl-icon-btn:hover:not(:disabled){background:#2a2a4a;color:#fff}.tpl-icon-btn:disabled{opacity:.3;cursor:not-allowed}.tpl-icon-btn-del:hover:not(:disabled){background:#4a1a1a;color:#ff6b6b}.tpl-canvas-area{flex:1;min-width:0;overflow-y:auto;padding:20px 24px;background:#050510;display:flex;align-items:flex-start;justify-content:center}.tpl-canvas-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#444;gap:12px}.tpl-canvas-empty-icon{font-size:48px}.tpl-canvas-empty p{font-size:15px;margin:0}.tpl-canvas-wrapper{width:100%;max-width:1100px;display:flex;flex-direction:column;gap:12px}.tpl-page-title-row{display:flex;align-items:center;gap:10px}.tpl-page-title-input{flex:1;background:#13132a;border:1px solid #2a2a4a;border-radius:6px;color:#fff;padding:7px 12px;font-size:15px;font-weight:600;font-family:inherit}.tpl-page-title-input:focus{outline:none;border-color:#7c4dff}.tpl-page-counter{font-size:13px;color:#666;white-space:nowrap;padding:0 4px}.tpl-canvas{width:100%;aspect-ratio:16 / 9;background:#fff;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 4px 32px #00000080}.tpl-canvas-titlebar{background:#0d0d1a;border-bottom:2px solid #7C4DFF;padding:8px 16px;font-size:14px;font-weight:600;color:#fff;flex-shrink:0}.tpl-canvas-hint{color:#aaa;font-size:13px;padding:20px;text-align:center}.tpl-elements-grid{flex:1;min-height:0;display:flex;flex-wrap:wrap;align-content:flex-start;gap:2px;padding:6px;background:#f5f5f5;overflow-y:auto}.tpl-element{background:#fff;border:1px solid #e0e0e0;border-radius:4px;overflow:hidden;display:flex;flex-direction:column;position:relative}.tpl-element-full{width:100%}.tpl-element-half{width:calc(50% - 1px)}.tpl-elem-controls{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#f0f0f0;border-bottom:1px solid #e0e0e0;flex-shrink:0}.tpl-elem-type-badge{font-size:10px;font-weight:700;letter-spacing:.5px;color:#7c4dff;text-transform:uppercase;margin-right:4px}.tpl-elem-controls .tpl-icon-btn{color:#999}.tpl-elem-controls .tpl-icon-btn:hover:not(:disabled){background:#e0e0e0;color:#333}.tpl-elem-controls .tpl-icon-btn-del:hover:not(:disabled){background:#ffeaea;color:#c33}.tpl-elem-img{width:100%;height:auto;display:block;object-fit:contain;background:#fafafa}.tpl-elem-chart{padding:8px;background:#fff}.tpl-elem-chart-title{font-size:13px;font-weight:600;color:#333;margin-bottom:6px;padding:0 4px}.tpl-elem-text{width:100%;min-height:80px;border:none;resize:vertical;padding:10px;font-size:13px;font-family:inherit;color:#333;background:#fff;box-sizing:border-box}.tpl-elem-text:focus{outline:none}.tpl-btn-save{background:#1a2a3a;border-color:#4a9eff;color:#4a9eff;font-weight:600}.tpl-btn-save:hover:not(:disabled){background:#4a9eff;color:#000}.tpl-save-ok{font-size:12px;color:#2ecc71;font-weight:600}.tpl-main-split{display:flex;gap:16px;width:100%;min-height:0;align-items:flex-start}.tpl-canvas-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}.tpl-chat-panel{width:340px;flex-shrink:0;display:flex;flex-direction:column;background:#0d0d1a;border:1px solid #1e1e3a;border-radius:10px;height:calc(100vh - 220px);min-height:500px;overflow:hidden}.tpl-chat-header{padding:12px 14px;border-bottom:1px solid #1e1e3a;display:flex;flex-direction:column;gap:2px;flex-shrink:0}.tpl-chat-header span:first-child{font-size:13px;font-weight:700;color:#fff}.tpl-chat-hint{font-size:11px!important;color:#555!important;font-weight:400!important}.tpl-chat-history{flex:1;overflow-y:auto;padding:12px 12px 8px;display:flex;flex-direction:column;gap:10px}.tpl-chat-welcome{display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px 8px;text-align:center}.tpl-chat-welcome-icon{font-size:32px}.tpl-chat-welcome p{font-size:13px;color:#888;margin:0;line-height:1.5}.tpl-chat-suggestions{display:flex;flex-direction:column;gap:6px;width:100%}.tpl-suggestion{background:#13132a;border:1px solid #2a2a4a;border-radius:6px;color:#aaa;font-size:12px;padding:7px 10px;cursor:pointer;text-align:left;transition:all .15s;line-height:1.4}.tpl-suggestion:hover{background:#1a1a40;border-color:#7c4dff;color:#fff}.tpl-chat-msg{display:flex}.tpl-chat-msg-user{justify-content:flex-end}.tpl-chat-msg-assistant{justify-content:flex-start}.tpl-chat-bubble{max-width:90%;padding:8px 11px;border-radius:10px;font-size:13px;line-height:1.5;white-space:pre-wrap}.tpl-chat-msg-user .tpl-chat-bubble{background:#7c4dff;color:#fff;border-bottom-right-radius:3px}.tpl-chat-msg-assistant .tpl-chat-bubble{background:#13132a;color:#ddd;border:1px solid #2a2a4a;border-bottom-left-radius:3px}.tpl-chat-thinking{display:flex;align-items:center;gap:5px;padding:12px 14px}.tpl-typing-dot{width:7px;height:7px;background:#7c4dff;border-radius:50%;display:inline-block;animation:tplTyping 1.2s infinite ease-in-out}.tpl-typing-dot:nth-child(2){animation-delay:.2s}.tpl-typing-dot:nth-child(3){animation-delay:.4s}@keyframes tplTyping{0%,80%,to{transform:scale(.7);opacity:.5}40%{transform:scale(1);opacity:1}}.tpl-chat-mutations{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.tpl-mutation-badge{background:#1a3a1a;border:1px solid #2ecc71;color:#2ecc71;font-size:11px;padding:2px 7px;border-radius:10px}.tpl-chat-input-row{display:flex;gap:6px;padding:10px;border-top:1px solid #1e1e3a;flex-shrink:0}.tpl-chat-input{flex:1;background:#13132a;border:1px solid #2a2a4a;border-radius:8px;color:#fff;padding:8px 10px;font-size:13px;font-family:inherit;resize:none;line-height:1.4}.tpl-chat-input:focus{outline:none;border-color:#7c4dff}.tpl-chat-input:disabled{opacity:.5}.tpl-chat-send{background:#7c4dff;border:none;border-radius:8px;color:#fff;font-size:16px;width:40px;cursor:pointer;flex-shrink:0;transition:background .15s;align-self:flex-end;height:40px}.tpl-chat-send:hover:not(:disabled){background:#6a3de8}.tpl-chat-send:disabled{opacity:.4;cursor:not-allowed}.decipher-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.decipher-modal{background:#1a1a1d;border-radius:12px;border:1px solid #2a2a2f;width:90%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080}.decipher-modal-header{padding:24px;border-bottom:1px solid #2a2a2f;display:flex;justify-content:space-between;align-items:center}.decipher-modal-header h2{margin:0;font-size:20px;font-weight:500;color:#e8e6e1}.close-btn{background:none;border:none;color:#888;font-size:32px;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-btn:hover{background:#2a2a2f;color:#e8e6e1}.decipher-modal-content{padding:24px;overflow-y:auto;flex:1}.upload-section{margin-bottom:24px}.help-text{color:#999;margin-bottom:16px;line-height:1.5}.file-input-wrapper{margin-bottom:12px}.file-input-wrapper input[type=file]{display:none}.file-label{display:block;padding:16px 20px;background:#2a2a2f;border:2px dashed #444;border-radius:8px;text-align:center;cursor:pointer;color:#bbb;transition:all .2s}.file-label:hover{background:#32323a;border-color:#555;color:#e8e6e1}.file-info{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#2a2a2f;border-radius:6px;color:#999;font-size:14px}.file-size{color:#666}.error-message{padding:16px;background:#3a1a1a;border:1px solid #661a1a;border-radius:8px;color:#ff6b6b;margin-bottom:24px}.error-message strong{color:#ff8787}.success-section{text-align:center}.success-icon{width:64px;height:64px;border-radius:50%;background:#1a3a2a;border:2px solid #2a5a3a;color:#4ade80;font-size:36px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.success-section h3{margin:0 0 8px;font-size:18px;font-weight:500;color:#e8e6e1}.success-section p{color:#999;margin:0 0 24px}.preview-section{text-align:left;margin-top:20px}.preview-section h4{margin:0 0 12px;font-size:14px;font-weight:500;color:#bbb}.xml-preview{background:#0f0f11;border:1px solid #2a2a2f;border-radius:6px;padding:16px;font-family:Courier New,monospace;font-size:12px;color:#aaa;overflow-x:auto;max-height:200px;overflow-y:auto}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px;border-top:1px solid #2a2a2f}.btn-secondary,.btn-primary{padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-secondary{background:#2a2a2f;color:#bbb}.btn-secondary:hover{background:#32323a;color:#e8e6e1}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.btn-primary:disabled{background:#2a2a2f;color:#555;cursor:not-allowed}
