.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-box h1{font-size:32px;margin-bottom:8px;color:#333;text-align:center}.subtitle{text-align:center;color:#666;margin-bottom:32px;font-size:14px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px;border:1px solid #fcc}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{margin-top:32px;text-align:center;color:#999;font-size:12px}.login-footer p{margin:4px 0}.generation-progress{padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;box-shadow:0 4px 6px #0000001a;margin-bottom:1rem}.progress-content{display:flex;align-items:center;gap:1rem}.progress-icon{font-size:2rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.progress-info{flex:1}.progress-label{font-size:1.1rem;font-weight:600;color:#fff;margin-bottom:.25rem}.progress-message{font-size:.9rem;color:#fffc}.progress-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.progress-note{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.2);font-size:.85rem;color:#ffffffe6;text-align:center;font-style:italic}.prompt-enhancer{background:#f8f9fa;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.prompt-enhancer.analyzing{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem}.enhancer-header{margin-bottom:1.5rem}.enhancer-header h3{margin:0 0 .5rem;font-size:1.25rem;color:#1f2937}.enhancer-subtitle{margin:0;color:#6b7280;font-size:.875rem}.analysis-results{display:flex;flex-direction:column;gap:1rem}.analysis-section{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:1rem}.analysis-section h4{margin:0 0 .75rem;font-size:1rem;color:#374151}.pattern-tags{display:flex;flex-wrap:wrap;gap:.5rem}.pattern-tag{display:inline-block;padding:.25rem .75rem;background:#dbeafe;color:#1e40af;border-radius:12px;font-size:.875rem;font-weight:500}.technical ul{margin:0;padding-left:1.5rem;color:#374151}.technical li{margin:.25rem 0;font-size:.875rem;font-family:Monaco,Courier New,monospace}.enhanced-preview{background:#f9fafb;border-radius:4px;padding:1rem}.prompt-comparison{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:center}.original,.enhanced{padding:.75rem;background:#fff;border-radius:4px;font-size:.875rem}.original strong,.enhanced strong{display:block;margin-bottom:.5rem;color:#6b7280;font-size:.75rem;text-transform:uppercase}.original p,.enhanced p{margin:0;color:#1f2937;line-height:1.5}.enhanced{border-left:3px solid #10b981}.arrow{font-size:1.5rem;color:#10b981;font-weight:700}.questions-note{margin:0 0 1rem;color:#6b7280;font-size:.875rem}.question-list{display:flex;flex-direction:column;gap:1rem}.question-item{display:flex;flex-direction:column;gap:.5rem}.question-item label{font-weight:500;color:#374151;font-size:.875rem}.question-item textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem;font-family:inherit;resize:vertical;transition:border-color .2s}.question-item textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.suggestions ul{margin:0;padding-left:1.5rem;color:#374151}.suggestions li{margin:.5rem 0;font-size:.875rem}.enhancer-actions{display:flex;gap:1rem;margin-top:1.5rem;justify-content:flex-end}.skip-button,.enhance-button{padding:.75rem 1.5rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.skip-button{background:#fff;border:1px solid #d1d5db;color:#6b7280}.skip-button:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.enhance-button{background:#3b82f6;border:none;color:#fff}.enhance-button:hover:not(:disabled){background:#2563eb}.skip-button:disabled,.enhance-button:disabled{opacity:.5;cursor:not-allowed}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@media (max-width: 768px){.prompt-comparison{grid-template-columns:1fr}.arrow{text-align:center;transform:rotate(90deg)}.enhancer-actions{flex-direction:column}.skip-button,.enhance-button{width:100%}}.tile-editor-modal{max-width:900px;max-height:90vh;display:flex;flex-direction:column;padding:0}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.editor-header h2{margin:0;font-size:1.5rem;color:#1f2937}.close-button{background:none;border:none;font-size:2rem;color:#9ca3af;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-button:hover{background:#f3f4f6;color:#374151}.editor-tabs{display:flex;border-bottom:2px solid #e5e7eb;background:#f9fafb}.editor-tabs .tab{flex:1;padding:1rem;background:none;border:none;border-bottom:3px solid transparent;font-size:.95rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s;margin-bottom:-2px}.editor-tabs .tab:hover{color:#374151;background:#f3f4f6}.editor-tabs .tab.active{color:#667eea;border-bottom-color:#667eea;background:#fff}.editor-content{flex:1;overflow-y:auto;padding:1.5rem}.editor-info{display:flex;gap:2rem;padding:1rem;background:#f9fafb;border-radius:8px;margin-bottom:1.5rem}.editor-info p{margin:0;font-size:.875rem;color:#374151}.editor-info strong{color:#1f2937}.code-editor{font-family:Courier New,Courier,monospace;font-size:13px;line-height:1.6;background:#1e1e1e;color:#d4d4d4;padding:1rem;border:1px solid #e5e7eb;border-radius:6px;resize:vertical}.quick-improve{margin:1rem 0;padding:1rem;background:#f0f4ff;border-radius:8px;border:1px solid #c7d2fe}.quick-improve p{margin:0 0 .75rem;font-size:.875rem;font-weight:500;color:#4338ca}.quick-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.quick-buttons button{padding:.5rem 1rem;background:#fff;border:1px solid #c7d2fe;border-radius:6px;font-size:.85rem;color:#4338ca;cursor:pointer;transition:all .2s}.quick-buttons button:hover{background:#e0e7ff;border-color:#a5b4fc}.editor-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.improve-section h3,.versions-section h3{margin:0 0 .5rem;font-size:1.25rem;color:#1f2937}.section-desc{margin:0 0 1.5rem;color:#6b7280;font-size:.95rem}.conversation-history{margin:0 0 1.5rem;padding:1rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;max-height:300px;overflow-y:auto}.conversation-history h4{margin:0 0 1rem;font-size:.9rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em}.conversation-entry{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.conversation-entry:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.conversation-request,.conversation-response{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}.conversation-response{margin-bottom:0}.conversation-label{font-weight:600;color:#1f2937;min-width:40px}.conversation-text{flex:1;color:#374151}.conversation-response .conversation-text{color:#059669}.conversation-time{font-size:.75rem;color:#9ca3af;margin-left:auto}.context-section{margin:1rem 0;padding:1rem;background:#fef3c7;border-radius:8px;border:1px solid #fcd34d}.context-section label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:#92400e;cursor:pointer}.error-preview{margin-top:.75rem;padding:.75rem;background:#fff;border-radius:4px;font-size:.8rem}.error-preview code{color:#dc2626;white-space:pre-wrap;word-break:break-word}.example-improvements{margin:1.5rem 0;padding:1rem;background:#f9fafb;border-radius:8px}.example-improvements p{margin:0 0 .75rem;font-weight:600;color:#374151}.example-improvements ul{list-style:none;padding:0;margin:0}.example-improvements li{padding:.75rem;margin-bottom:.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s;color:#4b5563}.example-improvements li:hover{background:#f3f4f6;border-color:#9ca3af;color:#1f2937}.versions-list{display:flex;flex-direction:column;gap:.75rem}.version-item{padding:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;justify-content:space-between;align-items:center;transition:all .2s}.version-item:hover{border-color:#9ca3af;box-shadow:0 2px 4px #0000000d}.version-header{display:flex;gap:1rem;align-items:center;margin-bottom:.5rem}.version-number{padding:.25rem .75rem;background:#e0e7ff;color:#4338ca;border-radius:12px;font-size:.875rem;font-weight:600}.version-date{font-size:.8rem;color:#9ca3af}.version-details{flex:1}.version-change{margin:0 0 .25rem;color:#374151;font-size:.9rem}.version-author{margin:0;font-size:.8rem;color:#9ca3af}.restore-button{padding:.5rem 1rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:.875rem;transition:all .2s}.restore-button:hover{background:#f9fafb;border-color:#9ca3af}.empty-message{text-align:center;padding:3rem 1rem;color:#9ca3af}.generation-info{padding:1.5rem}.generation-info h3{margin:0 0 1.5rem;font-size:1.25rem;color:#1f2937}.generation-info h4{margin:1rem 0 .5rem;font-size:1rem;color:#374151}.metadata-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:1rem;margin-bottom:1.5rem}.metadata-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-top:.5rem}.metadata-grid>div{padding:.5rem;background:#fff;border-radius:4px;font-size:.875rem}.warnings-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.warnings-section ul{margin:.5rem 0;padding-left:1.5rem}.warnings-section li{color:#f59e0b;margin:.25rem 0;font-size:.875rem}.prompt-section{margin-top:1.5rem}.prompt-note{color:#6b7280;font-size:.875rem;margin:.5rem 0 1rem;font-style:italic}.prompt-viewer{resize:vertical}.dashboard{min-height:100vh;display:flex;flex-direction:column}.dashboard-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:16px 32px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000000d}.header-left{display:flex;align-items:baseline;gap:12px}.header-left h1{font-size:24px;color:#333}.version{font-size:12px;color:#999;background:#f0f0f0;padding:2px 8px;border-radius:4px}.header-right{display:flex;align-items:center;gap:16px}.user-name{font-weight:600;color:#333}.user-email{color:#666;font-size:14px}.admin-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.logout-button{padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.logout-button:hover{background:#f5f5f5;border-color:#ccc}.dashboard-content{flex:1;display:flex}.sidebar{width:250px;background:#fff;border-right:1px solid #e0e0e0;padding:24px 0}.sidebar-section{padding:0 16px}.sidebar-section h3{font-size:12px;text-transform:uppercase;color:#999;margin-bottom:12px;font-weight:600;letter-spacing:.5px}.sidebar-section ul{list-style:none}.sidebar-section li{padding:10px 12px;margin-bottom:4px;border-radius:6px;cursor:pointer;transition:all .2s;color:#666;font-size:14px;display:flex;justify-content:space-between;align-items:center}.sidebar-section li:hover{background:#f5f5f5;color:#333}.sidebar-section li.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:500}.sidebar-section .canvas-list li{font-size:13px;padding:8px 12px}.sidebar-section .public-badge{font-size:10px;opacity:.7}.main-content{flex:1;padding:32px;background:#f8f9fa}.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.content-header h2{font-size:28px;color:#333}.primary-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.primary-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.secondary-button{padding:8px 16px;background:#fff;color:#667eea;border:1px solid #667eea;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.secondary-button:hover{background:#667eea;color:#fff}.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.empty-state p{color:#666;margin-bottom:24px;font-size:16px}.error-banner{background:#fee;color:#c33;padding:16px;border-radius:8px;margin-bottom:24px;border:1px solid #fcc}.tiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.tile-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #00000014;transition:all .3s;border:1px solid transparent}.tile-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#667eea}.tile-card h3{font-size:18px;margin-bottom:8px;color:#333}.tile-description{color:#666;font-size:14px;margin-bottom:16px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-height:4.5em}.tile-meta{display:flex;gap:8px;margin-bottom:16px}.tile-type,.tile-version{font-size:12px;padding:4px 8px;background:#f0f0f0;border-radius:4px;color:#666}.tile-actions{display:flex;gap:8px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;padding:32px;border-radius:12px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal h2{margin-bottom:24px;color:#333}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit}.form-group textarea{resize:vertical}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.llm-modal{max-width:700px}.modal-subtitle{color:#666;margin-bottom:24px;font-size:14px}.llm-examples{background:#f8f9fa;padding:16px;border-radius:8px;margin-bottom:16px}.llm-examples p{margin:0 0 8px;font-size:13px;color:#666}.llm-examples ul{list-style:none;padding:0;margin:0}.llm-examples li{padding:8px 12px;margin:4px 0;background:#fff;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;color:#667eea}.llm-examples li:hover{background:#667eea;color:#fff;transform:translate(4px)}.llm-status{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#e3f2fd;border-radius:8px;margin-bottom:16px;border-left:4px solid #2196F3}.llm-status .spinner{width:20px;height:20px;border:3px solid #e3f2fd;border-top-color:#2196f3;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.llm-status span{color:#1976d2;font-size:14px;font-weight:500}.header-actions{display:flex;gap:12px}.tile-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.sidebar ul li.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600}.tile-container{position:absolute;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .2s}.tile-container.dragging{box-shadow:0 8px 24px #0000004d;cursor:move}.tile-container.executing{border:2px solid #667eea;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 4px 12px #667eea4d}50%{box-shadow:0 4px 24px #667eea99}}.tile-header{background:#667eea;color:#fff;padding:12px 16px;cursor:move;display:flex;justify-content:space-between;align-items:center;-webkit-user-select:none;user-select:none}.tile-header-title{font-weight:600;font-size:14px}.tile-header-actions{display:flex;gap:8px;align-items:center}.tile-type-badge{font-size:10px;padding:2px 6px;background:#fff3;border-radius:3px;text-transform:uppercase}.tile-execute-btn-header{background:#fff3;border:none;color:#fff;width:24px;height:24px;border-radius:4px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .2s}.tile-execute-btn-header:hover:not(:disabled){background:#ffffff4d}.tile-execute-btn-header:disabled{opacity:.6;cursor:not-allowed}.tile-close-btn{background:#fff3;border:none;color:#fff;width:24px;height:24px;border-radius:4px;cursor:pointer;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s}.tile-close-btn:hover{background:#ffffff4d}.tile-body{flex:1;padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.tile-inputs-toggle{margin-bottom:8px}.tile-inputs-toggle-btn{background:#f5f5f5;border:1px solid #e0e0e0;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;color:#666;transition:background .2s;width:100%;text-align:left}.tile-inputs-toggle-btn:hover{background:#ebebeb}.tile-inputs{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.input-group{display:flex;flex-direction:column;gap:4px}.input-group label{font-size:12px;font-weight:600;color:#666}.input-group textarea,.input-group input{padding:8px;border:1px solid #ddd;border-radius:4px;font-size:13px;font-family:monospace;resize:vertical}.tile-execute-btn{padding:10px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:background .2s}.tile-execute-btn:hover:not(:disabled){background:#5568d3}.tile-execute-btn:disabled{opacity:.6;cursor:not-allowed}.tile-result{margin-top:12px;border-top:1px solid #e0e0e0;padding-top:12px}.result-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.result-success{color:#28a745;font-weight:600;font-size:13px}.result-error{color:#dc3545;font-weight:600;font-size:13px}.result-message{color:#666;font-size:13px}.result-data{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;padding:12px;max-height:200px;overflow:auto}.result-data pre{margin:0;font-size:12px;font-family:Monaco,Menlo,Consolas,monospace;white-space:pre-wrap;word-wrap:break-word}.result-error-detail{background:#fff3cd;border:1px solid #ffc107;border-radius:4px;padding:12px;color:#856404;font-size:12px;font-family:monospace;white-space:pre-wrap}.tile-resize-handle{position:absolute;right:0;bottom:0;width:16px;height:16px;cursor:nwse-resize;background:linear-gradient(135deg,transparent 50%,#ccc 50%)}.tile-resize-handle:hover{background:linear-gradient(135deg,transparent 50%,#667eea 50%)}.result-table-container{background:#fff;border:1px solid #e0e0e0;border-radius:4px;overflow:auto;max-height:400px}.result-table{width:100%;border-collapse:collapse;font-size:13px}.result-table thead{background:#f8f9fa;position:sticky;top:0;z-index:1}.result-table th{padding:10px 12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}.result-table td{padding:10px 12px;border-bottom:1px solid #e9ecef;color:#555}.result-table tbody tr:hover{background-color:#f0f4ff;cursor:pointer}.result-table tbody tr.table-row-clickable:active{background-color:#e0e8ff}.result-table tbody tr:last-child td{border-bottom:none}.table-badge{display:inline-block;padding:3px 8px;background:#667eea;color:#fff;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.result-detail{background:#fff;border:1px solid #e0e0e0;border-radius:4px;padding:12px;max-height:400px;overflow:auto}.detail-row{display:grid;grid-template-columns:140px 1fr;gap:12px;padding:8px 0;border-bottom:1px solid #f0f0f0}.detail-row:last-child{border-bottom:none}.detail-label{font-weight:600;color:#555;font-size:13px}.detail-value{color:#333;font-size:13px;word-break:break-word}.result-form{background:#fff;border:1px solid #e0e0e0;border-radius:4px;padding:16px;max-height:450px;overflow:auto}.form-field{margin-bottom:16px}.form-label{display:block;font-weight:600;color:#555;font-size:13px;margin-bottom:6px}.form-label .required{color:#dc3545;margin-left:2px}.form-input,.form-textarea,.form-select{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:13px;font-family:inherit;transition:border-color .2s}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-textarea{resize:vertical;font-family:monospace}.form-checkbox{width:18px;height:18px;cursor:pointer}.form-actions{display:flex;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0}.form-action-btn{padding:8px 16px;border:none;border-radius:4px;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s}.form-action-btn.primary{background:#667eea;color:#fff}.form-action-btn.primary:hover:not(:disabled){background:#5568d3}.form-action-btn.secondary{background:#f0f0f0;color:#555}.form-action-btn.secondary:hover:not(:disabled){background:#e0e0e0}.form-action-btn:disabled{opacity:.6;cursor:not-allowed}.row-action-btn{padding:4px 10px;background:#667eea;color:#fff;border:none;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;transition:background .2s;margin-right:4px}.row-action-btn:hover{background:#5568d3}.row-action-btn:last-child{margin-right:0}.debug-panel{position:fixed;bottom:0;right:0;width:600px;max-width:90vw;height:400px;background:#1e1e1e;color:#d4d4d4;border:1px solid #3e3e3e;border-radius:8px 8px 0 0;box-shadow:0 -4px 12px #0000004d;display:flex;flex-direction:column;z-index:10000;font-family:Monaco,Courier New,monospace;font-size:12px;transition:all .3s ease}.debug-panel.minimized{height:auto}.debug-panel.pinned{position:relative;width:100%;max-width:100%;height:500px;border-radius:8px;margin-top:1rem}.debug-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#252526;border-bottom:1px solid #3e3e3e;border-radius:8px 8px 0 0}.debug-title{font-weight:600;font-size:14px}.debug-controls{display:flex;gap:.5rem}.debug-btn{background:transparent;border:1px solid #3e3e3e;color:#d4d4d4;padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s}.debug-btn:hover{background:#3e3e3e;border-color:#505050}.debug-tabs{display:flex;background:#252526;border-bottom:1px solid #3e3e3e;padding:0 .5rem}.debug-tab{background:transparent;border:none;color:#858585;padding:.5rem 1rem;cursor:pointer;font-size:12px;border-bottom:2px solid transparent;transition:all .2s}.debug-tab:hover{color:#d4d4d4}.debug-tab.active{color:#4ec9b0;border-bottom-color:#4ec9b0}.debug-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.debug-section{flex:1;display:flex;flex-direction:column;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:#2d2d2d;border-bottom:1px solid #3e3e3e;font-size:11px;color:#858585}.clear-btn{background:transparent;border:1px solid #3e3e3e;color:#858585;padding:.25rem .75rem;border-radius:3px;cursor:pointer;font-size:11px;transition:all .2s}.clear-btn:hover{background:#3e3e3e;color:#d4d4d4}.console-output{flex:1;overflow-y:auto;padding:.5rem;background:#1e1e1e}.console-line{display:flex;gap:.5rem;padding:.25rem .5rem;margin-bottom:2px;border-radius:3px;align-items:flex-start}.console-line:hover{background:#2d2d2d}.console-line.log{border-left:3px solid #4ec9b0}.console-line.warn{border-left:3px solid #dcdcaa;background:#dcdcaa0d}.console-line.error{border-left:3px solid #f48771;background:#f487710d}.console-timestamp{color:#858585;font-size:10px;min-width:70px}.console-level{color:#858585;font-size:10px;text-transform:uppercase;min-width:40px}.console-message{color:#d4d4d4;white-space:pre-wrap;word-break:break-word;flex:1}.bus-output{flex:1;overflow-y:auto;padding:.5rem;background:#1e1e1e}.bus-event{background:#252526;border:1px solid #3e3e3e;border-radius:4px;padding:.5rem;margin-bottom:.5rem}.bus-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.bus-timestamp{color:#858585;font-size:10px}.bus-type{padding:.25rem .5rem;border-radius:3px;font-size:10px;font-weight:600;text-transform:uppercase}.bus-type.publish{background:#4ec9b033;color:#4ec9b0}.bus-type.subscribe{background:#569cd633;color:#569cd6}.bus-details{font-size:11px;color:#d4d4d4}.bus-details>div{margin-bottom:.25rem}.bus-details strong{color:#858585;margin-right:.5rem}.bus-data pre{background:#1e1e1e;padding:.5rem;border-radius:3px;margin:.25rem 0 0;overflow-x:auto}.state-output{flex:1;overflow-y:auto;padding:.5rem;background:#1e1e1e}.tile-state{background:#252526;border:1px solid #3e3e3e;border-radius:4px;padding:.75rem;margin-bottom:.75rem}.tile-state-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #3e3e3e}.tile-state-header strong{color:#4ec9b0;font-size:13px}.tile-id{color:#858585;font-size:10px}.state-content{display:flex;flex-direction:column;gap:.75rem}.state-section h4{color:#569cd6;font-size:11px;margin:0 0 .5rem;text-transform:uppercase}.state-section pre{background:#1e1e1e;padding:.5rem;border-radius:3px;margin:0;overflow-x:auto;font-size:11px;color:#ce9178}.empty-message{text-align:center;padding:2rem;color:#858585;font-style:italic}.console-output::-webkit-scrollbar,.bus-output::-webkit-scrollbar,.state-output::-webkit-scrollbar{width:8px}.console-output::-webkit-scrollbar-track,.bus-output::-webkit-scrollbar-track,.state-output::-webkit-scrollbar-track{background:#1e1e1e}.console-output::-webkit-scrollbar-thumb,.bus-output::-webkit-scrollbar-thumb,.state-output::-webkit-scrollbar-thumb{background:#3e3e3e;border-radius:4px}.console-output::-webkit-scrollbar-thumb:hover,.bus-output::-webkit-scrollbar-thumb:hover,.state-output::-webkit-scrollbar-thumb:hover{background:#505050}@media (max-width: 768px){.debug-panel{width:100%;max-width:100%;height:300px}.debug-tabs{overflow-x:auto}}.canvas-container{height:100vh;display:flex;flex-direction:column;background:#f5f5f5}.canvas-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000000d}.canvas-title{display:flex;align-items:center;gap:16px}.canvas-name-section{display:flex;flex-direction:column;gap:4px}.canvas-name-section h2{margin:0;font-size:24px;color:#333}.canvas-desc{margin:0;font-size:13px;color:#666;max-width:400px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unsaved-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:#f59e0b;font-weight:500}.back-button{background:transparent;border:1px solid #ddd;border-radius:4px;padding:6px 12px;font-size:14px;color:#666;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:4px}.back-button:hover{background:#f5f5f5;color:#333;border-color:#999}.canvas-title h2{margin:0;font-size:24px;color:#333}.session-id{font-size:12px;color:#999;font-family:monospace}.canvas-actions{display:flex;gap:12px}.canvas-actions .primary-button:disabled{opacity:.5;cursor:not-allowed;background:linear-gradient(135deg,#9ca3af,#6b7280)}.canvas-settings-modal{max-width:500px}.canvas-info{margin-top:1rem;padding:1rem;background:#f9fafb;border-radius:8px;font-size:.875rem}.canvas-info p{margin:.5rem 0;color:#374151}.canvas-info strong{color:#1f2937}.tile-selector{background:#fff;border-bottom:1px solid #e0e0e0;padding:20px;max-height:300px;overflow-y:auto}.tile-selector h3{margin:0 0 16px;color:#333}.tile-selector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}.tile-selector-item{padding:16px;background:#f8f9fa;border-radius:8px;cursor:pointer;transition:all .2s;border:2px solid transparent}.tile-selector-item:hover{background:#667eea;color:#fff;border-color:#5568d3}.tile-selector-name{font-weight:600;margin-bottom:4px}.tile-selector-desc{font-size:13px;opacity:.8;margin-bottom:8px}.tile-selector-type{font-size:11px;opacity:.6;text-transform:uppercase}.canvas-main{flex:1;display:flex;overflow:hidden}.canvas-workspace{flex:1;position:relative;overflow:auto;background:linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 1px),linear-gradient(rgba(0,0,0,.03) 1px,transparent 1px);background-size:20px 20px;background-position:-1px -1px}.canvas-empty-state{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#999}.canvas-empty-state p{margin:8px 0;font-size:16px}.canvas-sidebar{width:300px;background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column}.bus-log{flex:1;display:flex;flex-direction:column;overflow:hidden}.bus-log h3{margin:0;padding:16px;font-size:16px;color:#333;border-bottom:1px solid #e0e0e0}.bus-messages{flex:1;overflow-y:auto;padding:12px}.bus-empty{text-align:center;color:#999;padding:20px;font-size:14px}.bus-message{background:#f8f9fa;border-radius:6px;padding:10px;margin-bottom:8px;font-size:12px}.bus-message-time{color:#999;font-size:11px;margin-bottom:4px}.bus-message-event{font-weight:600;color:#667eea;margin-bottom:4px}.bus-message-publisher{color:#666;font-size:11px}.bus-message-triggered{margin-top:6px;padding:4px 8px;background:#667eea;color:#fff;border-radius:4px;font-size:11px}.bus-message-compatible{margin-top:4px;color:#28a745;font-size:11px}.canvas-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:all .2s;display:flex;flex-direction:column;gap:1rem}.canvas-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px);border-color:#667eea}.canvas-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.canvas-name{margin:0;font-size:1.25rem;color:#1a1a1a;font-weight:600;flex:1;word-break:break-word}.canvas-badges{display:flex;flex-wrap:wrap;gap:.25rem}.badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;white-space:nowrap}.badge.public{background:#dbeafe;color:#1e40af}.badge.forked{background:#fef3c7;color:#92400e}.badge.owner{background:#d1fae5;color:#065f46}.badge.shared{background:#e0e7ff;color:#4338ca}.canvas-description{margin:0;color:#6b7280;font-size:.95rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.canvas-meta{display:flex;gap:1.5rem;padding-top:.5rem;border-top:1px solid #f3f4f6}.meta-item{display:flex;gap:.5rem;font-size:.875rem}.meta-label{color:#9ca3af;font-weight:500}.meta-value{color:#374151;font-weight:600}.canvas-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{padding:.25rem .75rem;background:#f3f4f6;color:#6b7280;border-radius:12px;font-size:.8rem;font-weight:500}.canvas-actions{display:flex;gap:.5rem;padding-top:.5rem;border-top:1px solid #f3f4f6}.action-button{flex:1;padding:.625rem 1rem;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.action-button:hover{background:#f9fafb;border-color:#9ca3af}.action-button.primary{background:#667eea;color:#fff;border-color:#667eea}.action-button.primary:hover{background:#5568d3;border-color:#5568d3}.action-button.danger{flex:0;padding:.625rem;background:#fff;color:#dc2626;border-color:#fca5a5}.action-button.danger:hover{background:#fee;border-color:#dc2626}.share-dialog{max-width:500px}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:.75rem;border-radius:6px;transition:background .2s}.checkbox-label:hover{background:#f9fafb}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.checkbox-label span{font-size:1rem;font-weight:500;color:#1a1a1a}.field-hint{margin:.5rem 0 0;font-size:.875rem;color:#6b7280;line-height:1.4}.current-shares{margin-top:1rem;padding:1rem;background:#f9fafb;border-radius:8px}.current-shares label{display:block;margin-bottom:.75rem;font-size:.875rem;font-weight:600;color:#374151}.shared-users{display:flex;flex-wrap:wrap;gap:.5rem}.shared-user{padding:.375rem .75rem;background:#fff;border:1px solid #e5e7eb;border-radius:6px;font-size:.875rem;color:#374151}.error-banner{padding:.75rem;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c00;font-size:.9rem;margin-bottom:1rem}.canvas-gallery{padding:2rem;max-width:1400px;margin:0 auto}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.gallery-header .header-left{display:flex;align-items:center;gap:1rem}.gallery-header h1{margin:0;font-size:2rem;color:#1a1a1a}.back-button{padding:.5rem 1rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.back-button:hover{background:#f9fafb;border-color:#9ca3af;transform:translate(-2px)}.gallery-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e5e7eb}.gallery-tabs .tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;font-size:1rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s;margin-bottom:-2px}.gallery-tabs .tab:hover{color:#374151;background:#f9fafb}.gallery-tabs .tab.active{color:#667eea;border-bottom-color:#667eea;background:#f0f4ff}.gallery-content{min-height:400px}.loading-message{text-align:center;padding:3rem;color:#6b7280;font-size:1.1rem}.error-banner{padding:1rem;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c00;margin-bottom:1rem}.empty-state{text-align:center;padding:4rem 2rem;color:#6b7280}.empty-state p{font-size:1.1rem;margin-bottom:1.5rem}.canvases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;padding:.5rem 0}@media (max-width: 768px){.canvas-gallery{padding:1rem}.gallery-header{flex-direction:column;gap:1rem;align-items:flex-start}.gallery-tabs{overflow-x:auto;width:100%}.gallery-tabs .tab{white-space:nowrap;padding:.75rem 1rem;font-size:.9rem}.canvases-grid{grid-template-columns:1fr}}.admin-dashboard{padding:2rem;max-width:1400px;margin:0 auto}.admin-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 4px 20px #667eea4d}.admin-header h1{margin:0 0 .5rem;font-size:2rem}.admin-header p{margin:0;opacity:.9}.status-badge{display:inline-block;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem}.status-badge.healthy{background:#10b981;color:#fff}.status-badge.degraded{background:#f59e0b;color:#fff}.status-badge.error{background:#ef4444;color:#fff}.admin-nav{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #e5e7eb}.admin-nav-item{padding:1rem 1.5rem;border:none;background:none;cursor:pointer;font-size:1rem;font-weight:500;color:#6b7280;border-bottom:3px solid transparent;transition:all .2s}.admin-nav-item:hover{color:#667eea}.admin-nav-item.active{color:#667eea;border-bottom-color:#667eea}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;border-left:4px solid #667eea;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 16px #00000026}.stat-label{color:#6b7280;font-size:.85rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;color:#667eea}.stat-subvalue{font-size:.9rem;color:#9ca3af;margin-top:.5rem}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.action-card{background:#fff;border-radius:12px;padding:1.5rem;text-align:center;cursor:pointer;border:2px solid #e5e7eb;transition:all .3s;text-decoration:none;color:inherit}.action-card:hover{border-color:#667eea;background:#f9fafb;transform:translateY(-3px);text-decoration:none}.action-icon{font-size:2.5rem;margin-bottom:.5rem}.action-card h3{margin:.5rem 0;font-size:1.1rem;color:#1f2937}.action-card p{margin:0;font-size:.9rem;color:#6b7280}.section-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;margin-bottom:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{margin:0;font-size:1.5rem;color:#1f2937}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#e5e7eb;color:#374151}.btn-secondary:hover{background:#d1d5db}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-small{padding:.5rem 1rem;font-size:.9rem}.loading{text-align:center;padding:3rem;color:#6b7280}.error-message{background:#fee2e2;color:#991b1b;padding:1rem;border-radius:8px;margin-bottom:1rem}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#e5e7eb;color:#374151;border:none;border-radius:8px;font-weight:600;cursor:pointer;margin-bottom:1.5rem;transition:all .2s}.back-button:hover{background:#d1d5db;transform:translate(-3px)}.context-inspector{padding:20px;max-width:1200px;margin:0 auto}.context-inspector h2{color:#333;margin-bottom:10px}.context-inspector .description{color:#666;margin-bottom:20px}.error-banner{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:8px;margin-bottom:20px;border-left:4px solid #c62828}.inspector-section{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 2px 8px #00000014}.inspector-section h3{color:#333;margin-bottom:15px;font-size:1.1rem}.inspector-section h4{color:#444;margin:15px 0 10px;font-size:.95rem}.inspector-section p{color:#666;font-size:.9rem;margin-bottom:15px}.input-group textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px;resize:vertical;font-family:inherit}.input-group textarea:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.input-group.inline{display:flex;gap:10px}.input-group.inline input{flex:1;padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-size:14px}.input-group.inline input:focus{outline:none;border-color:#2196f3}.button-row{display:flex;gap:10px;margin-top:12px}.button-row button,.input-group.inline button{padding:10px 20px;background:#2196f3;color:#fff;border:none;border-radius:8px;font-size:14px;cursor:pointer;transition:background .2s}.button-row button:hover:not(:disabled),.input-group.inline button:hover:not(:disabled){background:#1976d2}.button-row button:disabled,.input-group.inline button:disabled{background:#ccc;cursor:not-allowed}.result-box{background:#f8f9fa;border-radius:8px;padding:16px;margin-top:16px;border:1px solid #e9ecef}.result-box h4{margin:0 0 12px;display:flex;align-items:center;gap:8px}.classification-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.classification-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid #e9ecef}.classification-item .label{color:#666;font-size:.85rem}.classification-item .value{font-weight:600;color:#333}.classification-item .value.badge{background:#e3f2fd;color:#1976d2;padding:2px 8px;border-radius:4px;font-size:.8rem}.reasoning{margin-top:12px;padding:12px;background:#fff3e0;border-radius:6px;color:#e65100;font-size:.9rem}.context-preview{display:flex;flex-direction:column;gap:16px}.preview-section h5{margin:0 0 8px;color:#555;font-size:.85rem}.tag-list{display:flex;flex-wrap:wrap;gap:6px}.tag{background:#e3f2fd;color:#1565c0;padding:4px 10px;border-radius:4px;font-size:.8rem}.tag.type-tag{background:#f3e5f5;color:#7b1fa2}.endpoint-list{list-style:none;padding:0;margin:0}.endpoint-list li{padding:4px 0;font-size:.85rem;color:#555;font-family:Monaco,Consolas,monospace}.token-estimate{padding:10px;background:#e8f5e9;border-radius:6px;color:#2e7d32;font-size:.9rem}.token-breakdown{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid #c8e6c9}.token-item{font-size:.85rem;padding:4px 10px;background:#fff;border-radius:4px;color:#1b5e20;border:1px solid #c8e6c9}.source-badge{font-size:.7rem;padding:2px 8px;border-radius:4px;font-weight:400;text-transform:uppercase}.source-badge.stored{background:#e8f5e9;color:#2e7d32}.source-badge.reconstructed{background:#fff3e0;color:#e65100}.note{padding:10px;background:#fff3e0;border-radius:6px;color:#e65100;font-size:.85rem;margin-bottom:12px}.restored-details .detail-item{margin-bottom:16px}.restored-details .detail-item strong{display:block;color:#555;margin-bottom:6px}.restored-details .detail-item p{margin:0;color:#333}.restored-details .detail-item pre{background:#263238;color:#aed581;padding:12px;border-radius:6px;font-size:.8rem;overflow-x:auto;max-height:200px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:20px}.stat-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:16px;text-align:center}.stat-card.success{border-color:#c8e6c9;background:#f1f8e9}.stat-label{font-size:.8rem;color:#666;margin-bottom:4px}.stat-value{font-size:1.8rem;font-weight:700;color:#333}.stat-card.success .stat-value{color:#2e7d32}.no-data{color:#999;text-align:center;padding:20px}.errors-section{margin-top:20px}.errors-table{width:100%;border-collapse:collapse}.errors-table th,.errors-table td{padding:10px 12px;text-align:left;border-bottom:1px solid #e9ecef}.errors-table th{background:#f8f9fa;font-weight:600;color:#555;font-size:.85rem}.errors-table td{font-size:.85rem}.error-example{color:#666;font-family:monospace;font-size:.75rem}.tile-type-breakdown{margin-top:20px}.type-bars{display:flex;flex-direction:column;gap:12px}.type-bar-item{display:grid;grid-template-columns:100px 1fr 80px;align-items:center;gap:12px}.type-label{font-size:.85rem;color:#555;text-transform:capitalize}.bar-container{height:24px;background:#e9ecef;border-radius:4px;position:relative;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);border-radius:4px;transition:width .3s ease}.bar-value{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:.75rem;font-weight:600;color:#333}.type-count{font-size:.75rem;color:#999;text-align:right}.recommendation-box{padding:14px 16px;background:#e3f2fd;border-radius:8px;color:#1565c0;margin-bottom:20px}.effectiveness-section{margin-top:20px}.effectiveness-table{width:100%;border-collapse:collapse}.effectiveness-table th,.effectiveness-table td{padding:10px 12px;text-align:left;border-bottom:1px solid #e9ecef}.effectiveness-table th{background:#f8f9fa;font-weight:600;color:#555;font-size:.85rem}.rate{display:inline-block;padding:2px 8px;border-radius:4px;font-weight:600;font-size:.8rem}.rate.high{background:#e8f5e9;color:#2e7d32}.rate.medium{background:#fff3e0;color:#e65100}.rate.low{background:#ffebee;color:#c62828}.token-ranges{display:flex;gap:12px;flex-wrap:wrap}.token-range-card{flex:1;min-width:120px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:14px;text-align:center}.range-label{font-size:.75rem;color:#666;margin-bottom:6px}.range-rate{font-size:1.4rem;font-weight:700;color:#333}.range-count{font-size:.75rem;color:#999;margin-top:4px}@media (max-width: 768px){.classification-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.type-bar-item{grid-template-columns:80px 1fr}.type-count{display:none}}.app{min-height:100vh;background-color:#f5f5f5}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
