.km-layout{display:grid;grid-template-columns:280px 1fr;height:100vh;overflow:hidden}.km-sidebar{background:var(--bg-primary);border-right:1px solid var(--border-light);display:flex;flex-direction:column;padding:20px 0;overflow-y:auto}.km-sidebar-header{padding:0 20px 20px;border-bottom:1px solid var(--border-light);margin-bottom:8px}.km-sidebar-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.km-sidebar-header h2{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.km-sidebar-header p{font-size:12px;color:var(--text-secondary)}.km-qr-btn{flex-shrink:0;width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--border-medium);background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,border-color .15s,transform .1s;margin-top:2px}.km-qr-btn:hover{background:var(--accent-primary-glow);border-color:var(--accent-primary);color:var(--accent-primary);transform:scale(1.08)}.km-nav{flex:1;display:flex;flex-direction:column;gap:2px;padding:0 8px}.km-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:background .15s,color .15s;border:none;background:none;text-align:left;width:100%}.km-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.km-nav-item.active{background:var(--accent-primary-glow);color:var(--accent-primary);font-weight:500}.km-nav-item.active .nav-icon{filter:none}.km-nav-item .nav-icon{font-size:16px;width:20px;text-align:center;filter:grayscale(1)}.km-sidebar-footer{padding:12px 8px 0;border-top:1px solid var(--border-light);margin-top:auto}.km-main{overflow-y:auto;padding:32px;background:var(--bg-secondary)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header h1{font-size:22px;font-weight:700;color:var(--text-primary)}.page-header-actions{display:flex;gap:10px}.btn{padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:opacity .15s,transform .1s}.btn:hover{opacity:.9}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-light)}.btn-danger{background:#e74c3c;color:#fff}.btn-sm{padding:5px 10px;font-size:12px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.card{background:var(--block-bg);border:1px solid var(--block-border);border-radius:var(--radius-md);padding:20px;transition:transform .2s,box-shadow .2s;cursor:pointer}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.card-meta{font-size:12px;color:var(--text-secondary);display:flex;gap:16px;margin-top:10px}.card-badge{font-size:11px;padding:3px 10px;border-radius:var(--radius-full);font-weight:600}.badge-empty{background:var(--bg-tertiary);color:var(--text-muted)}.badge-in-progress{background:var(--status-editing-bg);color:var(--status-editing-text)}.badge-completed{background:var(--status-complete-bg);color:var(--status-complete-text)}.badge-cleared{background:var(--bg-hover);color:var(--text-muted)}.canvas-list-card{position:relative;overflow:hidden}.canvas-list-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--border-medium);border-radius:var(--radius-md) var(--radius-md) 0 0}.canvas-list-card--in_progress:before{background:linear-gradient(90deg,var(--accent-secondary),var(--accent-primary))}.canvas-list-card--completed:before{background:var(--accent-success)}.canvas-list-card--in_progress{border-color:#b088f940}.canvas-list-card--completed{border-color:#6bcf8e40}.canvas-progress-bar{height:4px;background:var(--bg-hover);border-radius:var(--radius-full);overflow:hidden}.canvas-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:var(--radius-full);transition:width .4s ease;min-width:4px}.progress-widget{margin-bottom:24px}.progress-widget-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.progress-widget-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.progress-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:16px;text-align:center;transition:border-color .2s}.progress-card.active{border-color:var(--accent-primary)}.progress-card.done{border-color:var(--accent-secondary)}.progress-card.locked{opacity:.5}.progress-card-icon{font-size:28px;margin-bottom:8px}.progress-card-label{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.progress-card-status{font-size:12px;color:var(--text-muted)}.progress-card-bar{margin-top:10px;height:4px;background:var(--border-light);border-radius:var(--radius-full);overflow:hidden}.progress-card-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:var(--radius-full);transition:width .4s ease;min-width:2px}@media(max-width:600px){.progress-widget-cards{grid-template-columns:1fr}}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:12px 16px;text-align:left;font-size:13px;border-bottom:1px solid var(--border-light)}.data-table th{color:var(--text-secondary);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.data-table td{color:var(--text-primary)}.data-table tr:hover td{background:var(--bg-hover)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:100;display:flex;align-items:center;justify-content:center}.modal{background:var(--bg-primary);border-radius:var(--radius-lg);padding:24px;width:440px;max-width:95vw;box-shadow:var(--shadow-xl)}.modal h2{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-group input,.form-group select{width:100%;padding:9px 12px;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;outline:none;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:var(--accent-primary)}.km-company-row{display:flex;gap:8px;align-items:center}.km-company-dropdown{position:relative;flex:1}.km-company-trigger{width:100%;padding:8px 14px;border-radius:999px;border:1px solid var(--border-light);background:var(--bg-tertiary);color:var(--text-primary);font-size:13px;line-height:1.3;cursor:pointer;display:flex;align-items:center;justify-content:center;text-align:center;box-shadow:0 2px 6px #0000002e;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .08s ease}.km-company-trigger:hover{background:var(--bg-hover);border-color:var(--border-medium);transform:translateY(-1px)}.km-company-trigger:focus-visible{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary-glow, rgba(130, 94, 255, .55))}.km-company-trigger-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.km-company-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-lg);border:1px solid var(--border-light);padding:4px;max-height:220px;overflow-y:auto;z-index:10}.km-company-menu-item{width:100%;text-align:left;padding:6px 10px;border-radius:8px;border:none;background:transparent;color:var(--text-primary);font-size:13px;cursor:pointer;transition:background .12s ease,color .12s ease;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.km-company-menu-item:hover{background:var(--bg-hover)}.km-company-menu-item.active{background:var(--accent-primary-glow);color:var(--accent-primary);font-weight:500}.km-company-new-btn{padding:8px 14px;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center}select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23999' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state p{font-size:14px;margin-bottom:16px}.canvas-view-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.canvas-view-block{background:var(--block-bg);border:1px solid var(--block-border);border-radius:var(--radius-md);padding:16px}.canvas-view-block.completed{border-color:var(--accent-success)}.canvas-view-block h4{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:8px}.canvas-view-block textarea{width:100%;min-height:80px;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:10px;color:var(--text-primary);font-size:13px;line-height:1.5;resize:vertical;font-family:inherit;outline:none}.canvas-view-block textarea:focus{border-color:var(--accent-primary)}.report-container{background:var(--block-bg);border:1px solid var(--block-border);border-radius:var(--radius-md);padding:28px 32px;font-size:14px;line-height:1.75;color:var(--text-primary)}.report-container>:first-child{margin-top:0}.report-container>:last-child{margin-bottom:0}.report-container h1{font-size:1.5em;font-weight:700;color:var(--text-primary);margin:1.5em 0 .6em;padding-bottom:.3em;border-bottom:1px solid var(--border-light)}.report-container h2{font-size:1.3em;font-weight:600;color:var(--text-primary);margin:1.3em 0 .5em}.report-container h3{font-size:1.1em;font-weight:600;color:var(--text-primary);margin:1.1em 0 .4em}.report-container h4,.report-container h5,.report-container h6{font-size:1em;font-weight:600;color:var(--text-primary);margin:1em 0 .3em}.report-container p{margin:.6em 0}.report-container ul,.report-container ol{padding-left:24px;margin:.6em 0}.report-container li{margin:.3em 0}.report-container li>p{margin:.2em 0}.report-container li>ul,.report-container li>ol{margin:.2em 0}.report-container strong{font-weight:600;color:inherit}.report-container em{font-style:italic}.report-container code{background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;font-family:Courier New,Courier,monospace;font-size:.9em}.report-container pre{background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:16px;overflow-x:auto;margin:.8em 0}.report-container pre code{background:none;padding:0;border-radius:0;font-size:13px}.report-container blockquote{border-left:3px solid var(--accent-primary);padding:.5em 1em;margin:.8em 0;color:var(--text-secondary);background:var(--bg-tertiary);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.report-container blockquote p{margin:.3em 0}.report-container table{border-collapse:collapse;width:100%;margin:.8em 0;font-size:13px}.report-container th,.report-container td{border:1px solid var(--border-light);padding:8px 12px;text-align:left}.report-container th{background:var(--bg-tertiary);font-weight:600}.report-container tr:hover td{background:#ffffff05}.report-container hr{border:none;border-top:1px solid var(--border-light);margin:1.5em 0}.report-container a{color:var(--accent-primary);text-decoration:underline;text-underline-offset:2px}.report-container a:hover{opacity:.8}.stat-card{background:var(--block-bg);border:1px solid var(--block-border);border-radius:var(--radius-md);padding:16px;text-align:center;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-primary);border-radius:var(--radius-md) var(--radius-md) 0 0}.stat-card--secondary:before{background:var(--accent-secondary)}.stat-card--success:before{background:var(--accent-success)}.stat-card--in-progress:before{background:linear-gradient(90deg,var(--accent-secondary),var(--accent-primary))}.stat-card--secondary .stat-value{color:var(--accent-secondary)}.stat-card--success .stat-value{color:var(--accent-success)}.stat-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-value{font-size:32px;font-weight:700;color:var(--accent-primary)}.data-table{width:100%;border-collapse:collapse;background:var(--block-bg);border:1px solid var(--block-border);border-radius:var(--radius-md);overflow:hidden}.data-table thead{background:var(--bg-tertiary)}.data-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:1px solid var(--border-light)}.data-table td{padding:12px 16px;border-bottom:1px solid var(--border-light);font-size:13px;color:var(--text-primary)}.data-table tbody tr:hover{background:var(--bg-tertiary)}.data-table tbody tr:last-child td{border-bottom:none}.km-chats-grid{display:grid;grid-template-columns:280px 1fr;gap:16px;height:calc(100vh - 140px)}.km-chats-users{background:var(--block-bg);border:1px solid var(--block-border);border-radius:var(--radius-md);max-height:100%;overflow-y:auto}.km-chats-area{background:var(--block-bg);border:1px solid var(--block-border);border-radius:var(--radius-md);display:flex;flex-direction:column;height:100%;overflow:hidden}.km-chats-back-btn{display:none;align-items:center;justify-content:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:var(--radius-sm)}.km-chats-back-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.km-mobile-menu-btn{display:none}@media(max-width:768px){.km-layout{grid-template-columns:1fr}.km-sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;z-index:200;transform:translate(-100%);transition:transform .25s ease}.km-sidebar.open{transform:translate(0)}.km-sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:199;animation:fadeIn .2s ease}.km-mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;margin-bottom:16px;flex-shrink:0}.km-main{padding:16px}.card-grid{grid-template-columns:1fr}.km-chats-grid{grid-template-columns:1fr;height:calc(100vh - 120px)}.km-chats-users.has-selection,.km-chats-area{display:none}.km-chats-area.has-selection,.km-chats-back-btn{display:flex}}.canvas-view-block{position:relative}.canvas-view-block-header{margin-bottom:8px;padding-right:36px}.canvas-view-block-header h4{margin:0}.block-critic-btn{position:absolute;top:10px;right:10px;height:24px;padding:0 10px;border-radius:12px;background:transparent;border:1px solid var(--border-medium);color:var(--text-muted);font-size:10px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;cursor:pointer;display:flex;align-items:center;gap:4px;transition:background .15s,border-color .15s,color .15s;z-index:1;white-space:nowrap}.block-critic-btn:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.5;flex-shrink:0}.block-critic-btn:hover:not(:disabled){background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.block-critic-btn:hover:not(:disabled):before{background:#fff;opacity:1}.block-critic-btn:disabled{opacity:.4;cursor:not-allowed}.block-critic-panel{margin-top:10px;border-top:1px solid var(--border-light);padding-top:8px}.block-critic-toggle{background:none;border:none;color:var(--text-secondary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;cursor:pointer;padding:0;display:flex;align-items:center;gap:5px;margin-bottom:8px;transition:color .15s}.block-critic-toggle:hover{color:var(--accent-primary)}.block-critic-report{background:var(--bg-secondary);border:1px solid var(--border-light);border-left:3px solid var(--accent-primary);border-radius:var(--radius-sm);padding:10px 14px;font-size:12px;line-height:1.65;color:var(--text-primary);max-height:360px;overflow-y:auto;animation:blockCriticSlideDown .18s ease}@keyframes blockCriticSlideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.block-critic-report h2,.block-critic-report h3{font-size:12px;font-weight:700;margin:8px 0 3px;color:var(--text-primary)}.block-critic-report p{margin:3px 0}.block-critic-report ul,.block-critic-report ol{padding-left:16px;margin:3px 0}.block-critic-report li{margin:2px 0}.block-critic-report strong{font-weight:600;color:var(--text-primary)}.qr-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:300;display:flex;align-items:center;justify-content:center;animation:qrFadeIn .2s ease}@keyframes qrFadeIn{0%{opacity:0}to{opacity:1}}.qr-modal{position:relative;background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);padding:28px 28px 24px;width:480px;max-width:95vw;box-shadow:0 24px 64px #0009;display:flex;flex-direction:column;align-items:center;gap:14px;animation:qrSlideUp .22s ease}@keyframes qrSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.qr-modal-close{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border-light);background:transparent;color:var(--text-muted);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.qr-modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.qr-modal-header{text-align:center}.qr-modal-title{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.qr-modal-subtitle{font-size:13px;color:var(--text-secondary)}.qr-modal-code-wrap{padding:12px;background:#1a1a1a;border-radius:var(--radius-md);border:1px solid var(--border-medium);box-shadow:0 0 40px #6b9eff14,0 0 80px #b088f90d}.qr-code-container{display:block;line-height:0}.qr-modal-hint{font-size:13px;color:var(--text-muted);text-align:center;margin:0}.qr-modal-link-row{display:flex;align-items:center;gap:8px;width:100%;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:8px 10px}.qr-modal-link-text{flex:1;font-size:11px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:Courier New,Courier,monospace}.qr-modal-actions{width:100%}.qr-download-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;padding:11px 20px}.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);padding:24px}.register-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:40px 36px;width:100%;max-width:420px;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;align-items:center;gap:8px}.register-icon{font-size:40px;margin-bottom:4px}.register-title{font-size:22px;font-weight:700;color:var(--text-primary);text-align:center;margin:0}.register-subtitle{font-size:14px;color:var(--text-secondary);text-align:center;margin:0}.register-form{width:100%;margin-top:8px}.register-error{color:#e74c3c;font-size:13px;margin:4px 0 8px;text-align:center}.register-btn{width:100%;margin-top:8px;padding:12px 20px;font-size:15px}.register-success-creds{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:8px;margin-top:4px}.register-cred-row{display:flex;justify-content:space-between;align-items:center;font-size:14px}.register-cred-label{color:var(--text-secondary)}.register-cred-value{color:var(--text-primary);font-weight:600}.canvas-container{display:grid;grid-template-columns:1fr 420px;grid-template-rows:auto 1fr;height:100vh;overflow:hidden}.chat-panel{display:flex;flex-direction:column;background:var(--bg-primary);border-left:1px solid var(--border-light);height:100%;overflow:hidden;grid-row:2;grid-column:2}.chat-header{padding:20px 24px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.chat-header h2{font-size:16px;font-weight:600;color:var(--text-primary)}.chat-active-block{display:flex;align-items:center;gap:6px;padding:6px 16px;background:var(--status-editing-bg);border-bottom:1px solid var(--border-light);flex-shrink:0}.chat-active-block-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--status-editing-text);opacity:.7}.chat-active-block-name{font-size:12px;font-weight:600;color:var(--status-editing-text)}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-full)}.message{max-width:88%;padding:12px 16px;border-radius:var(--radius-md);font-size:14px;line-height:1.5;animation:messageSlideIn .3s ease;word-wrap:break-word;white-space:pre-wrap}.message.user{align-self:flex-end;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border-bottom-right-radius:4px}.message.assistant{align-self:flex-start;background:var(--bg-tertiary);border:1px solid var(--border-light);color:var(--text-primary);border-bottom-left-radius:4px}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.typing-indicator{padding:10px 16px;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-md);border-bottom-left-radius:4px;align-self:flex-start;min-width:180px;width:fit-content}.thinking-text{font-size:13px;font-weight:500;background:linear-gradient(90deg,var(--text-muted) 0%,var(--accent-primary) 40%,var(--accent-secondary) 60%,var(--text-muted) 100%);background-size:250% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmerFlow 2.2s linear infinite,thinkingFade .4s ease}@keyframes shimmerFlow{0%{background-position:200% center}to{background-position:-200% center}}@keyframes thinkingFade{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.message.assistant.streaming>:last-child:after{content:"▊";color:var(--accent-primary);margin-left:1px;animation:cursorBlink .7s step-end infinite}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.chat-input-area{padding:16px;border-top:1px solid var(--border-light);display:flex;gap:10px;align-items:flex-end;flex-shrink:0}.chat-input-area textarea{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:10px 14px;font-size:14px;color:var(--text-primary);resize:none;max-height:100px;min-height:42px;line-height:1.4;font-family:inherit;outline:none;transition:border-color .2s}.chat-input-area textarea:focus{border-color:var(--accent-primary)}.chat-input-area textarea::placeholder{color:var(--text-muted)}.hint-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border-light);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .2s,color .2s}.hint-btn:hover:not(:disabled){border-color:var(--accent-primary);color:var(--accent-primary)}.hint-btn:disabled{opacity:.5;cursor:not-allowed}.send-btn{width:42px;height:42px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .2s,transform .15s}.send-btn:hover:not(:disabled){transform:scale(1.05)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.send-btn svg{width:18px;height:18px}.canvas-panel{overflow-y:auto;padding:24px 32px;background:var(--bg-secondary);grid-row:2;grid-column:1}.canvas-panel::-webkit-scrollbar{width:6px}.canvas-panel::-webkit-scrollbar-track{background:transparent}.canvas-panel::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-full)}.canvas-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.canvas-header-left h1{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.canvas-header-left p{font-size:13px;color:var(--text-secondary)}.canvas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}@media(min-width:1400px){.canvas-grid{grid-template-columns:repeat(3,1fr)}}.canvas-block{background:var(--block-bg);border:1px solid var(--block-border);border-radius:var(--radius-md);padding:16px;transition:transform .2s,box-shadow .2s,border-color .2s;animation:blockAppear .5s ease forwards}.canvas-block:not(.status-editing):hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--accent-primary)}.canvas-block.status-editing{border-color:var(--accent-secondary);box-shadow:0 0 0 1px var(--status-editing-bg)}.canvas-block.status-completed{border-color:var(--accent-success)}@keyframes blockAppear{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.block-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.block-header h3{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.block-hint-trigger{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;border:1px solid var(--border-medium);font-size:10px;font-weight:600;color:var(--text-muted);cursor:help;position:relative;flex-shrink:0}.block-hint-trigger:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.block-hint-tooltip{background:var(--bg-primary);color:var(--text-secondary);font-size:12px;font-weight:400;text-transform:none;letter-spacing:0;padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--border-light);box-shadow:var(--shadow-md);white-space:normal;word-wrap:break-word;z-index:1000;pointer-events:none}.block-status{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:var(--radius-full)}.block-status.editing{background:var(--status-editing-bg);color:var(--status-editing-text)}.block-status.completed{background:var(--status-complete-bg);color:var(--status-complete-text)}.block-content{font-size:13px;line-height:1.6;color:var(--text-primary);min-height:40px}.block-content.empty{color:var(--text-muted);font-style:italic}.block-content.typing:after{content:"u258B";color:var(--accent-primary);animation:cursorBlink .8s infinite}@keyframes cursorBlink{0%,50%{opacity:1}51%,to{opacity:0}}.circular-progress{position:relative;width:60px;height:60px;flex-shrink:0}.circular-progress svg{width:100%;height:100%;transform:rotate(-90deg)}.circular-progress .bg{fill:none;stroke:var(--border-light);stroke-width:5}.circular-progress .progress-ring{fill:none;stroke:url(#progressGradient);stroke-width:5;stroke-linecap:round;stroke-dasharray:163.4;stroke-dashoffset:163.4;transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1)}.progress-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.progress-number{font-size:18px;font-weight:700;color:var(--text-primary);line-height:1}.progress-total{font-size:9px;color:var(--text-secondary)}.logout-btn{background:none;border:1px solid var(--border-light);color:var(--text-secondary);padding:6px 14px;border-radius:var(--radius-sm);font-size:13px;cursor:pointer;transition:color .2s,border-color .2s}.logout-btn:hover{color:var(--text-primary);border-color:var(--border-medium)}.mobile-nav{display:none}@media(max-width:768px){.canvas-container{display:flex;flex-direction:column;height:100vh}.chat-panel,.canvas-panel{flex:1;overflow-y:auto}.canvas-panel{padding:16px}.canvas-grid{grid-template-columns:1fr}.canvas-container[data-active-tab=chat] .canvas-panel,.canvas-container[data-active-tab=canvas] .chat-panel,.canvas-container[data-active-tab=history] .chat-panel,.canvas-container[data-active-tab=history] .canvas-panel{display:none}.mobile-nav{display:flex;gap:0;background:var(--bg-primary);border-top:1px solid var(--border-light);flex-shrink:0}.mobile-nav button{flex:1;padding:12px 8px;border:none;background:none;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:color .15s,background .15s}.mobile-nav button.active{color:var(--accent-primary);background:var(--accent-primary-glow);font-weight:600}.mobile-nav button:not(.active):hover{background:var(--bg-hover)}}.km-chat-toggle{position:fixed;top:16px;right:16px;width:48px;height:48px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);z-index:20;transition:transform .2s;font-size:24px}.km-chat-toggle:hover{transform:scale(1.1)}.km-chat-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.km-chat-window{width:660px;max-width:95vw;height:900px;max-height:90vh;background:var(--bg-primary);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-xl);animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.km-chat-header{padding:16px 20px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.km-chat-header h3{font-size:15px;font-weight:600;color:var(--text-primary)}.km-chat-close{background:none;border:none;color:var(--text-secondary);font-size:22px;cursor:pointer;padding:0 4px;line-height:1}.km-chat-close:hover{color:var(--text-primary)}.connection-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted)}.connection-dot.online{background:var(--accent-success)}.km-chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}@media(max-width:768px){.km-chat-toggle{top:12px;right:12px;width:40px;height:40px;font-size:20px}}.pitch-preview-modal{width:900px;max-width:95vw;max-height:90vh;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px;animation:fadeIn .2s ease}.pitch-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}.pitch-preview-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px}.pitch-slide{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:32px;min-height:350px;margin-bottom:16px}.pitch-slide h3{color:var(--accent-primary);font-size:22px;margin:0 0 16px}.pitch-slide-content{font-size:15px;line-height:1.7;color:var(--text-primary)}.pitch-slide-content p{margin:0 0 12px}.pitch-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:16px}.pitch-thumbnails{display:flex;gap:8px;overflow-x:auto;padding:4px 0}.pitch-thumb{flex-shrink:0;width:80px;padding:8px 6px;background:var(--bg-tertiary);border-radius:var(--radius-sm);cursor:pointer;text-align:center;border:2px solid transparent;transition:all .2s ease}.pitch-thumb:hover{border-color:var(--border-medium)}.pitch-thumb.active{border-color:var(--accent-primary);background:var(--accent-primary-glow)}.pitch-thumb small{display:block;margin-top:4px;font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.canvas-toast{position:fixed;bottom:24px;right:24px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;padding:14px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;box-shadow:var(--shadow-lg);z-index:200;max-width:300px;animation:toastIn .3s ease,toastOut .4s ease 3.6s forwards;pointer-events:none}@keyframes toastIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(16px)}}.canvas-toast.milestone{animation:toastIn .3s ease,milestonePulse .5s ease .3s,toastOut .4s ease 3.6s forwards}@keyframes milestonePulse{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1)}}.chat-block-divider{display:flex;align-items:center;gap:8px;margin:4px 0 0;color:var(--text-muted);font-size:11px;align-self:stretch}.chat-block-divider:before,.chat-block-divider:after{content:"";flex:1;border-top:1px solid var(--border-light)}.chat-block-tag{background:var(--accent-primary-glow, #eff6ff);color:var(--accent-primary);padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:500;white-space:nowrap}.chat-examples{display:flex;flex-wrap:wrap;gap:8px;margin:4px 0;align-self:flex-start;max-width:88%;animation:messageSlideIn .3s ease}.chat-example-btn{padding:6px 14px;border-radius:var(--radius-full);border:1px solid var(--border-medium);background:var(--bg-tertiary);color:var(--text-secondary);font-size:13px;font-family:inherit;cursor:pointer;transition:all .2s ease;text-align:left;line-height:1.3}.chat-example-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:var(--accent-primary-glow)}.editor-header-btn{padding:6px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-tertiary);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.editor-header-btn:hover:not(:disabled){color:var(--text-primary);border-color:var(--accent-primary);background:#6b9eff14}.editor-header-btn:disabled{opacity:.5;cursor:not-allowed}.block-critic-btn{background:none;border:1px solid var(--border-light);border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;font-size:12px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s ease}.block-critic-btn:hover{color:var(--accent-primary);border-color:var(--accent-primary);background:#6b9eff14}.block-critic-loading{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.block-critic-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-secondary);animation:criticPulse 1.2s ease-in-out infinite}@keyframes criticPulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.quick-fill-progress{display:flex;flex-direction:column;gap:8px}.qf-block{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);background:var(--bg-tertiary);font-size:14px;color:var(--text-secondary);transition:all .3s ease}.qf-block.done{background:#22c55e14;color:var(--text-primary)}.qf-block-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;flex-shrink:0;font-size:14px}.qf-block.done .qf-block-icon{color:#22c55e}.qf-block-spinner{width:14px;height:14px;border:2px solid var(--border-medium);border-top-color:var(--accent-primary);border-radius:50%;animation:qfSpin .8s linear infinite}@keyframes qfSpin{to{transform:rotate(360deg)}}.critic-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.critic-popup{position:relative;width:560px;max-width:95vw;max-height:80vh;background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slideUp .3s ease}.critic-popup-close{position:absolute;top:12px;right:12px;width:28px;height:28px;border:none;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:1}.critic-popup-close:hover{background:var(--bg-hover);color:var(--text-primary)}.critic-popup-header{padding:20px 24px 12px;border-bottom:1px solid var(--border-light)}.critic-popup-title{font-size:16px;font-weight:600;color:var(--text-primary)}.critic-popup-body{padding:16px 24px 24px;overflow-y:auto;flex:1}.critic-popup-loading{display:flex;align-items:center;justify-content:center;padding:40px 0}.critic-popup-error{color:#e57373;padding:16px;background:#e5737314;border-radius:var(--radius-sm);font-size:14px}.critic-popup-content{font-size:14px;line-height:1.6;color:var(--text-secondary)}.critic-popup-content h1,.critic-popup-content h2,.critic-popup-content h3{color:var(--text-primary);margin:16px 0 8px}.critic-popup-content h3{font-size:15px}.critic-popup-content p{margin:0 0 8px}.critic-popup-content ul,.critic-popup-content ol{padding-left:20px;margin:0 0 8px}.critic-popup-content li{margin-bottom:4px}:root{--bg-primary: #1a1a1a;--bg-secondary: #141414;--bg-tertiary: #242424;--bg-hover: #2a2a2a;--accent-primary: #6b9eff;--accent-primary-light: #8bb4ff;--accent-primary-glow: rgba(107, 158, 255, .15);--accent-secondary: #b088f9;--accent-success: #6bcf8e;--text-primary: #e0e0e0;--text-secondary: #a0a0a0;--text-muted: #666666;--border-light: #2a2a2a;--border-medium: #333333;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 2px 4px rgba(0, 0, 0, .25);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .3);--shadow-xl: 0 8px 24px rgba(0, 0, 0, .35);--block-bg: #1e1e1e;--block-border: #2d2d2d;--status-complete-bg: rgba(107, 207, 142, .12);--status-complete-text: #6bcf8e;--status-editing-bg: rgba(176, 136, 249, .12);--status-editing-text: #b088f9;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #ebebeb;--bg-hover: #e0e0e0;--accent-primary: #4a7fd8;--accent-primary-light: #6090e0;--accent-primary-glow: rgba(74, 127, 216, .12);--accent-secondary: #8a5cd0;--accent-success: #4aa06a;--text-primary: #1a1a1a;--text-secondary: #555555;--text-muted: #888888;--border-light: #e5e5e5;--border-medium: #d5d5d5;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 2px 4px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1);--shadow-xl: 0 8px 24px rgba(0, 0, 0, .12);--block-bg: #ffffff;--block-border: #e0e0e0;--status-complete-bg: rgba(74, 160, 106, .1);--status-complete-text: #3d8a5a;--status-editing-bg: rgba(138, 92, 208, .1);--status-editing-text: #7a4cb8}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-secondary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;transition:background .3s ease,color .3s ease}a{color:var(--accent-primary);text-decoration:none}a:hover{color:var(--accent-primary-light)}.message{line-height:1.6}.message h1,.message h2,.message h3,.message h4,.message h5,.message h6{margin-top:1em;margin-bottom:.5em;font-weight:600}.message h1{font-size:1.5em}.message h2{font-size:1.3em}.message h3{font-size:1.1em}.message p{margin:.3em 0;line-height:1.5}.message p:first-child{margin-top:0}.message p:last-child{margin-bottom:0}.message p+p{margin-top:.3em}.message br{display:none}.message ul,.message ol{margin:.5em 0;padding-left:1.5em}.message li{margin:.25em 0}.message strong{font-weight:600;color:inherit}.message em{font-style:italic}.message code{background:#0000000d;padding:.2em .4em;border-radius:3px;font-family:Courier New,Courier,monospace;font-size:.9em}.message pre{background:#0000000d;padding:1em;border-radius:5px;overflow-x:auto;margin:.5em 0}.message pre code{background:none;padding:0}.message blockquote{border-left:3px solid #e0e0e0;padding-left:1em;margin:.5em 0;color:#666}.message a{color:#06c;text-decoration:underline}.message a:hover{color:#0052a3}.message hr{border:none;border-top:1px solid #e0e0e0;margin:1em 0}.message table{border-collapse:collapse;width:100%;margin:.5em 0}.message th,.message td{border:1px solid #e0e0e0;padding:.5em;text-align:left}.message th{background:#0000000d;font-weight:600}.message img{max-width:100%;height:auto;border-radius:5px}
