.dashboard{padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.dashboard h2{margin-bottom:20px;color:#333}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.metric-card{padding:15px;background:#f8f9fa;border-radius:6px;border-left:4px solid #007bff}.metric-label{font-size:14px;color:#666;margin-bottom:8px}.metric-value{font-size:24px;font-weight:700;color:#333}.announcements{padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.announcements h2{margin-bottom:20px;color:#333}.no-announcements{padding:20px;text-align:center;color:#999}.announcements-list{display:flex;flex-direction:column;gap:10px;max-height:600px;overflow-y:auto;padding-right:5px}.announcements-list::-webkit-scrollbar{width:8px}.announcements-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.announcements-list::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.announcements-list::-webkit-scrollbar-thumb:hover{background:#555}.announcement{display:flex;align-items:flex-start;padding:15px;border-radius:6px;border-left:4px solid}.announcement-critical{background:#fee;border-left-color:#dc3545}.announcement-warning{background:#fff3cd;border-left-color:#ffc107}.announcement-info{background:#d1ecf1;border-left-color:#17a2b8}.announcement-icon{font-size:20px;margin-right:12px}.announcement-content{flex:1}.announcement-title{font-size:14px;font-weight:600;color:#333;margin-bottom:4px}.announcement-description{font-size:13px;color:#555;margin-bottom:4px}.announcement-message{font-size:14px;color:#333;margin-bottom:4px}.announcement-interval{font-size:12px;color:#666}.announcement-command{background-color:#e3f2fd;border-left:4px solid #2196f3}.announcement-command .announcement-icon{color:#2196f3}.announcement-new{animation:slideIn .3s ease-out;box-shadow:0 2px 8px #2196f34d}.new-badge{display:inline-block;background-color:#2196f3;color:#fff;font-size:.7em;font-weight:700;padding:2px 6px;border-radius:3px;margin-right:8px;vertical-align:middle}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.announcement[data-type=command_failure]{border-left-width:5px}.announcement[data-type=construction_stall],.announcement[data-type=repair_stall]{background:#fff8e1;border-left-color:#ff9800}.announcement[data-type=research_stall_execution]{background:#f3e5f5;border-left-color:#9c27b0}.announcement[data-type=production_failure]{background:#ffebee;border-left-color:#f44336}.announcement[data-type=execution_resumed]{background:#e8f5e9;border-left-color:#4caf50}.advance-controls{padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.advance-controls h3{margin-bottom:15px;color:#333}.advance-buttons{display:flex;gap:10px;flex-wrap:wrap}.advance-btn{padding:12px 24px;background:#007bff;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.advance-btn:hover:not(:disabled){background:#0056b3}.advance-btn:disabled{background:#ccc;cursor:not-allowed}.processing-indicator{margin-top:10px;color:#007bff;font-size:14px}.building-card{background:#f5f5f5;border:1px solid #ddd;border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:16px;position:relative;transition:all .2s ease}.building-card:hover{box-shadow:0 2px 8px #0000001a}.building-card.submitting{opacity:.7;pointer-events:none}.building-info{display:flex;flex-direction:column;gap:12px}.building-header{display:flex;justify-content:space-between;align-items:center}.building-type{font-size:16px;font-weight:600;margin:0;color:#2c3e50}.building-details{display:flex;flex-direction:column;gap:8px}.detail-row{display:flex;justify-content:space-between;align-items:center;font-size:14px}.detail-label{font-weight:500;color:#666}.detail-value{color:#2c3e50;font-weight:600}.storage-value{text-align:right;max-width:60%;word-wrap:break-word}.building-controls{display:flex;flex-direction:column;gap:12px;padding-top:12px;border-top:1px solid #ddd}.control-buttons{display:flex;gap:8px}.control-button{flex:1;padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.control-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 4px #0003}.control-button:active:not(:disabled){transform:translateY(0)}.destroy-button{background:#e74c3c;color:#fff}.destroy-button:hover:not(:disabled){background:#c0392b}.repair-button{background:#95a5a6;color:#fff}.repair-button.active{background:#3498db}.repair-button.active:hover:not(:disabled){background:#2980b9}.repair-button.inactive{background:#bdc3c7;cursor:not-allowed}.production-control{display:flex;flex-direction:column;gap:8px}.production-label{font-size:14px;font-weight:500;color:#666}.production-slider{width:100%;height:6px;border-radius:3px;background:#e0e0e0;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.production-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#3498db;cursor:pointer;transition:all .2s ease}.production-slider::-webkit-slider-thumb:hover{background:#2980b9;transform:scale(1.1)}.production-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#3498db;cursor:pointer;border:none;transition:all .2s ease}.production-slider::-moz-range-thumb:hover{background:#2980b9;transform:scale(1.1)}.production-slider:disabled{opacity:.5;cursor:not-allowed}.production-slider:disabled::-webkit-slider-thumb{cursor:not-allowed}.production-slider:disabled::-moz-range-thumb{cursor:not-allowed}.error-message{background:#fff3cd;border:1px solid #ffc107;border-radius:6px;padding:8px 12px;font-size:13px;color:#856404}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffc;display:flex;align-items:center;justify-content:center;border-radius:8px}.loading-spinner{width:32px;height:32px;border:3px solid #f3f3f3;border-top:3px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.building-card{padding:12px}.control-buttons{flex-direction:column}.control-button{width:100%}}.control-button:focus-visible{outline:2px solid #3498db;outline-offset:2px}.production-slider:focus-visible{outline:2px solid #3498db;outline-offset:2px}.research-allocation-manager{position:relative;padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.allocation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #eee}.allocation-header h3{margin:0;color:#333;font-size:20px;font-weight:600}.total-allocation{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:6px;font-size:18px;font-weight:600;transition:all .3s ease}.total-allocation.valid{background:#d4edda;color:#155724;border:2px solid #c3e6cb}.total-allocation.invalid{background:#f8d7da;color:#721c24;border:2px solid #f5c6cb;animation:pulse-error 1s ease-in-out infinite}@keyframes pulse-error{0%,to{border-color:#f5c6cb}50%{border-color:#dc3545}}.total-label{font-weight:500;font-size:14px}.total-value{font-size:20px;font-weight:700}.validation-warning{font-size:12px;font-weight:500;padding:2px 8px;background:#dc3545;color:#fff;border-radius:4px;margin-left:8px}.validation-info{font-size:12px;font-weight:500;padding:2px 8px;background:#17a2b8;color:#fff;border-radius:4px;margin-left:8px}.domain-sliders{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-bottom:24px}.domain-slider-card{background:#f8f9fa;border:2px solid #dee2e6;border-radius:8px;padding:16px;transition:all .2s ease}.domain-slider-card:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff1a}.domain-slider-card.stalled{border-color:#ff6b6b;background:#fff5f5}.domain-slider-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.domain-info{display:flex;align-items:center;gap:8px;flex:1}.domain-name{margin:0;font-size:16px;font-weight:600;color:#333}.stalled-badge{background:#ff6b6b;color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;text-transform:uppercase}.allocation-value{font-size:18px;font-weight:700;color:#007bff;min-width:60px;text-align:right}.slider-container{margin-bottom:12px}.allocation-slider{width:100%;height:8px;border-radius:4px;background:#dee2e6;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:background .2s ease}.allocation-slider:hover{background:#cbd3da}.allocation-slider:disabled{cursor:not-allowed;opacity:.5}.allocation-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#007bff;cursor:pointer;border:2px solid white;box-shadow:0 2px 4px #0003;transition:all .2s ease}.allocation-slider::-webkit-slider-thumb:hover{background:#0056b3;transform:scale(1.1)}.allocation-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#007bff;cursor:pointer;border:2px solid white;box-shadow:0 2px 4px #0003;transition:all .2s ease}.allocation-slider::-moz-range-thumb:hover{background:#0056b3;transform:scale(1.1)}.domain-progress{display:flex;flex-direction:column;gap:4px}.progress-bar{height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}.domain-slider-card.stalled .progress-fill{background:#ff6b6b}.progress-info{display:flex;justify-content:space-between;align-items:center;font-size:12px}.current-breakthrough{color:#666;font-weight:500}.progress-text{color:#999}.allocation-controls{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:2px solid #eee}.control-button{padding:10px 24px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.control-button:disabled{cursor:not-allowed;opacity:.5}.reset-button{background:#6c757d;color:#fff}.reset-button:hover:not(:disabled){background:#5a6268;transform:translateY(-1px);box-shadow:0 2px 4px #0003}.submit-button{background:#28a745;color:#fff}.submit-button.active:hover:not(:disabled){background:#218838;transform:translateY(-1px);box-shadow:0 2px 4px #0003}.submit-button.inactive{background:#6c757d}.validation-message{padding:12px 16px;border-radius:6px;margin-top:16px;font-size:14px;font-weight:500}.validation-message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.error-message{padding:12px 16px;border-radius:6px;margin-top:16px;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;font-size:14px;font-weight:500}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffc;display:flex;align-items:center;justify-content:center;border-radius:8px;z-index:10}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.domain-sliders{grid-template-columns:1fr}.allocation-header{flex-direction:column;align-items:flex-start;gap:12px}.allocation-controls{flex-direction:column}.control-button{width:100%}}.allocation-slider:focus{outline:2px solid #007bff;outline-offset:2px}.control-button:focus{outline:2px solid #007bff;outline-offset:2px}@media (prefers-contrast: high){.total-allocation.valid,.total-allocation.invalid,.domain-slider-card{border-width:3px}}.query-views{padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.tabs{display:flex;gap:5px;margin-bottom:20px;border-bottom:2px solid #eee}.tabs button{padding:12px 20px;background:none;border:none;border-bottom:3px solid transparent;font-size:14px;font-weight:500;color:#666;cursor:pointer;transition:all .2s}.tabs button:hover{color:#007bff}.tabs button.active{color:#007bff;border-bottom-color:#007bff}.tab-content{padding:10px 0}.tab-content h3{margin-bottom:15px;color:#333}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}thead{background:#f8f9fa}th{padding:12px;text-align:left;font-weight:600;color:#555;border-bottom:2px solid #dee2e6}td{padding:12px;border-bottom:1px solid #dee2e6}tbody tr:hover{background:#f8f9fa}.resource-section{margin-bottom:30px}.resource-section h4{margin-bottom:15px;color:#333;font-size:18px;font-weight:600;border-bottom:2px solid #007bff;padding-bottom:8px}.resource-category{margin-bottom:20px;padding:12px;background:#f8f9fa;border-radius:6px}.category-title{margin:0 0 10px;color:#555;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.resource-list{list-style:none;padding:0;margin:0}.resource-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;margin-bottom:4px;background:#fff;border-radius:4px;transition:background .2s}.resource-item:hover{background:#e9ecef}.resource-name{color:#333;font-weight:500}.resource-amount{color:#007bff;font-weight:600;font-family:Courier New,monospace}.empty-message{color:#999;font-style:italic;padding:20px;text-align:center}.shortfalls{background:#fff3cd;padding:15px;border-radius:6px;border-left:4px solid #ffc107}.shortfalls h4{color:#856404;border-bottom-color:#ffc107}.shortfall-list{list-style:none;padding:0;margin:0}.shortfall-item{padding:8px 12px;margin-bottom:4px;background:#fff;border-radius:4px;color:#856404;font-weight:500}.research-domain{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:6px}.domain-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.domain-name{font-weight:600;color:#333;font-size:16px;margin:0}.domain-position{color:#666;font-size:14px}.progress-bar{height:20px;background:#e0e0e0;border-radius:10px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);transition:width .3s ease}.domain-allocation{font-size:14px;color:#666}.buildings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;padding:16px 0}@media (max-width: 768px){.buildings-grid{grid-template-columns:1fr}}.research-view{padding:16px 0}@media (max-width: 768px){.research-view{padding:8px 0}}.loading-message{text-align:center;padding:40px;color:#666;font-size:16px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;padding:2rem;border-radius:8px;max-width:900px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content h2{margin-top:0;margin-bottom:1.5rem;color:#333}.error-message{background:#ffebee;color:#c62828;padding:.75rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #c62828}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:700;color:#555}.form-group input{width:100%;padding:.75rem;font-size:1rem;border:2px solid #ddd;border-radius:4px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#4caf50}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.era-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1rem}.era-card{border:2px solid #ddd;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s ease;background:#fff}.era-card:hover{border-color:#4caf50;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.era-card.selected{border-color:#4caf50;background:#e8f5e9;box-shadow:0 0 0 3px #4caf5033}.era-card h3{margin:0 0 .5rem;font-size:1.1rem;color:#333}.era-card .population{margin:.25rem 0;font-weight:700;color:#2196f3;font-size:.95rem}.era-card .description{margin:.5rem 0 0;font-size:.85rem;color:#666;line-height:1.4}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1rem;border-top:1px solid #eee}.modal-actions button{padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:4px;cursor:pointer;transition:all .2s;font-weight:500}.modal-actions button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.modal-actions button:disabled{opacity:.5;cursor:not-allowed}.modal-actions button:not(.primary){background:#f5f5f5;color:#666}.modal-actions button:not(.primary):hover:not(:disabled){background:#e0e0e0}.modal-actions button.primary{background:#4caf50;color:#fff}.modal-actions button.primary:hover:not(:disabled){background:#45a049}@media (max-width: 768px){.modal-content{padding:1.5rem;width:95%}.era-grid{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}}.conversation-window{display:flex;flex-direction:column;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000026;overflow:hidden;position:relative;transition:height .2s ease-out}.conversation-window.resizing{transition:none}.conversation-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom:2px solid rgba(255,255,255,.2)}.conversation-header h3{margin:0;font-size:18px;font-weight:600}.header-controls{display:flex;align-items:center;gap:12px}.text-only-toggle-container{position:relative}.text-only-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.toggle-text{font-size:13px;font-weight:500;color:#fff;white-space:nowrap;transition:opacity .2s ease}.text-only-toggle-label:hover .toggle-text{opacity:.9}.text-only-toggle{position:relative;width:44px;height:24px;background:#ffffff4d;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;padding:0;outline:none;flex-shrink:0}.text-only-toggle:hover{background:#fff6}.text-only-toggle.active{background:#ffffffe6}.text-only-toggle.active:hover{background:#fff}.toggle-slider{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003;pointer-events:none}.text-only-toggle.active .toggle-slider{transform:translate(20px);background:#667eea;box-shadow:0 2px 6px #667eea66}.text-only-toggle:focus{box-shadow:0 0 0 3px #ffffff4d}.text-only-toggle:focus:not(:focus-visible){box-shadow:none}.text-only-toggle:focus-visible{box-shadow:0 0 0 3px #ffffff80}.queue-section{display:flex;align-items:center;gap:8px;animation:fadeIn .3s ease-in}.queue-indicator{background:#ffffff40;padding:6px 12px;border-radius:16px;font-size:12px;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap;transition:all .2s ease}.queue-indicator:hover{background:#ffffff59}.skip-all-button{background:#ffffffe6;color:#667eea;border:none;padding:6px 12px;border-radius:16px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;animation:fadeIn .3s ease-in}.skip-all-button:hover{background:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.skip-all-button:active{transform:translateY(0);box-shadow:0 1px 4px #0000001a}.skip-all-button:focus{outline:none;box-shadow:0 0 0 3px #ffffff80}.pending-commands-indicator{background:#ffffff40;padding:6px 12px;border-radius:16px;font-size:12px;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap;transition:all .2s ease;animation:fadeIn .3s ease-in}.pending-commands-indicator:hover{background:#ffffff59}.end-conversation-button{background:#ffffffe6;color:#667eea;border:none;padding:6px 12px;border-radius:16px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;animation:fadeIn .3s ease-in}.end-conversation-button:hover:not(:disabled){background:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.end-conversation-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #0000001a}.end-conversation-button:disabled{opacity:.5;cursor:not-allowed}.end-conversation-button:focus{outline:none;box-shadow:0 0 0 3px #ffffff80}.messages-container{flex:1;overflow-y:auto;padding:20px;background:#f8f9fa;scroll-behavior:smooth}.no-messages{display:flex;align-items:center;justify-content:center;height:100%;color:#999;font-style:italic}.message{display:flex;align-items:flex-start;margin-bottom:16px;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-advisor{flex-direction:row}.message-player{flex-direction:row-reverse}.message-icon{font-size:24px;margin:0 12px;flex-shrink:0}.message-content{max-width:70%;padding:12px 16px;border-radius:12px;background:#fff;box-shadow:0 1px 3px #0000001a}.message-advisor .message-content{background:#fff;border-bottom-left-radius:4px}.message-player .message-content{background:#667eea;color:#fff;border-bottom-right-radius:4px}.message-text{font-size:14px;line-height:1.5;margin-bottom:6px;word-wrap:break-word}.message-timestamp{font-size:11px;opacity:.6;text-align:right}.announcement-critical .message-content{border-left:4px solid #dc3545;background:#fee}.announcement-warning .message-content{border-left:4px solid #ffc107;background:#fff3cd}.announcement-info .message-content{border-left:4px solid #17a2b8;background:#d1ecf1}.conversation-input{padding:16px 20px;background:#fff;border-top:1px solid #e0e0e0}.loading-indicator{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;background:#f0f0f0;border-radius:6px;font-size:13px;color:#666}.rate-limit-message{display:flex;align-items:center;margin-bottom:12px;padding:10px 14px;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;font-size:13px;color:#856404;animation:fadeIn .3s ease-in}.loading-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.input-wrapper{display:flex;gap:10px;margin-bottom:8px;align-items:center}.voice-button-wrapper{display:flex;align-items:center;flex-shrink:0}.message-input{flex:1;padding:12px 16px;border:2px solid #e0e0e0;border-radius:24px;font-size:14px;outline:none;transition:border-color .2s}.message-input:focus{border-color:#667eea}.message-input:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.send-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:24px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.send-button:active:not(:disabled){transform:translateY(0)}.send-button:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.character-counter{text-align:right;font-size:12px;color:#999;margin-top:4px}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:#f1f1f1}.messages-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.messages-container::-webkit-scrollbar-thumb:hover{background:#555}.resize-handle{position:absolute;bottom:0;left:0;right:0;height:12px;cursor:ns-resize;display:flex;align-items:center;justify-content:center;background:transparent;z-index:10;transition:background-color .2s ease;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.resize-handle:hover{background:#667eea1a}.resize-handle.dragging{background:#667eea33;cursor:ns-resize}.resize-handle:focus{outline:none;background:#667eea26}.resize-handle-indicator{width:40px;height:4px;background:#ccc;border-radius:2px;transition:all .2s ease;pointer-events:none}.resize-handle:hover .resize-handle-indicator{background:#667eea;width:50px;height:5px}.resize-handle.dragging .resize-handle-indicator{background:#764ba2;width:60px;height:5px}.resize-handle.at-min .resize-handle-indicator,.resize-handle.at-max .resize-handle-indicator{background:#ffc107}.resize-handle.at-min:hover .resize-handle-indicator,.resize-handle.at-max:hover .resize-handle-indicator{background:#ff9800}.conversation-input{padding:16px 20px 20px;background:#fff;border-top:1px solid #e0e0e0;position:relative;z-index:1}@media (max-width: 768px){.input-wrapper{flex-wrap:wrap}.message-input{flex:1;min-width:0}.voice-button-wrapper{order:2}.send-button{order:3}.conversation-header{flex-wrap:wrap;gap:8px;padding:12px 16px}.conversation-header h3{font-size:16px}.header-controls{flex-wrap:wrap;gap:8px}.toggle-text{font-size:12px}.text-only-toggle{width:40px;height:22px}.toggle-slider{width:18px;height:18px}.text-only-toggle.active .toggle-slider{transform:translate(18px)}.queue-section{flex-wrap:wrap;gap:6px}.queue-indicator,.skip-all-button,.pending-commands-indicator,.end-conversation-button{font-size:11px;padding:5px 10px}.resize-handle{height:16px}.resize-handle-indicator{width:60px;height:5px}.resize-handle:hover .resize-handle-indicator{width:70px}.message-content{max-width:85%}.message-text{font-size:13px}.conversation-input{padding:12px 16px 16px}.send-button{padding:10px 20px;font-size:13px}}@media (max-width: 480px){.conversation-header{padding:10px 12px}.conversation-header h3{font-size:15px}.header-controls{width:100%;justify-content:space-between}.text-only-toggle-container{flex:1}.queue-section{flex:1;justify-content:flex-end}.message-content{max-width:90%}.input-wrapper{gap:8px}.send-button{padding:10px 16px;font-size:12px}}.voice-controls{display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;padding:4px}.voice-button{position:relative;width:48px;height:48px;border-radius:50%;border:2px solid #667eea;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;outline:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.voice-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #667eea4d}.voice-button:active:not(:disabled){transform:scale(.95)}.voice-button-pressed{transform:scale(.95);background:#f0f0f0}.voice-button-recording{border-color:#28a745;border-width:3px;background:#e8f5e9;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 #28a74580}50%{box-shadow:0 0 0 10px #28a74500}}.voice-button-disabled{opacity:.5;cursor:not-allowed;border-color:#ccc}.voice-button-disabled:hover{transform:none;box-shadow:none}.voice-button-icon{font-size:24px;line-height:1}.voice-button-indicator{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:#28a745;display:flex;align-items:center;justify-content:center}.recording-pulse{width:8px;height:8px;border-radius:50%;background:#fff;animation:recordingPulse 1s ease-in-out infinite}@keyframes recordingPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.voice-status{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:16px;font-size:12px;font-weight:500;animation:fadeIn .2s ease-in;transition:all .2s ease}.voice-status-listening{background:#e8f5e9;border:1px solid #28a745;color:#1e7e34}.voice-status-processing{background:#e3f2fd;border:1px solid #2196f3;color:#1565c0;animation:fadeIn .2s ease-in,processingPulse 1s ease-in-out infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes processingPulse{0%,to{opacity:1}50%{opacity:.7}}.status-text{line-height:1}.voice-interim{display:flex;align-items:center;padding:6px 12px;background:#fafafa;border:1px solid #e0e0e0;border-radius:6px;font-size:12px;color:#999;font-style:italic;max-width:300px;animation:fadeIn .2s ease-in;min-height:28px;opacity:.85}.interim-text{line-height:1.4;word-break:break-word;font-weight:400}.voice-final{display:flex;align-items:center;padding:8px 14px;background:#e3f2fd;border:2px solid #2196f3;border-radius:8px;font-size:13px;color:#0d47a1;font-weight:600;max-width:300px;animation:fadeIn .2s ease-in;box-shadow:0 2px 4px #2196f31a}.final-text{line-height:1.4;word-break:break-word}.voice-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fff3cd;border:2px solid #ffc107;border-radius:8px;font-size:12px;color:#856404;max-width:300px;animation:fadeIn .3s ease-in;box-shadow:0 2px 4px #ffc10726}.error-icon{font-size:16px;line-height:1;flex-shrink:0}.error-text{line-height:1.4;font-weight:500}@media (max-width: 768px){.voice-button{width:56px;height:56px}.voice-button-icon{font-size:28px}.voice-interim,.voice-final,.voice-error{max-width:250px;font-size:11px}}@media (hover: none) and (pointer: coarse){.voice-button{width:56px;height:56px}.voice-button:active:not(:disabled){transform:scale(.9)}}.avatar-visualizer{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:400px;margin:0 auto}.avatar-canvas-container{position:relative;width:100%;height:300px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #0000001a}.avatar-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:1rem;color:#fff;font-size:.875rem;z-index:10}.avatar-loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:avatar-spin 1s linear infinite}@keyframes avatar-spin{to{transform:rotate(360deg)}}.avatar-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#fff;font-size:.875rem;z-index:10}.avatar-error-icon{font-size:2rem}.avatar-state-indicator{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:24px;color:#fff;font-weight:500;font-size:.875rem;box-shadow:0 2px 4px #0000001a;min-width:150px}.avatar-state-icon{font-size:1.25rem;line-height:1}.avatar-state-label{line-height:1}@media (max-width: 768px){.avatar-visualizer{max-width:100%}.avatar-canvas-container{height:250px}.avatar-state-indicator{padding:.5rem 1rem;font-size:.8125rem}}@media (prefers-reduced-motion: reduce){.avatar-loading-spinner{animation:none}.avatar-state-indicator{transition:none}}.voice-input-container{display:flex;flex-direction:column;align-items:center;gap:.5rem}.voice-container-error{color:#d32f2f;font-size:.875rem;margin-top:.5rem;padding:.5rem;background-color:#ffebee;border-radius:4px;text-align:center;max-width:400px}.app{min-height:100vh;background:#f5f5f5}.app-header{background:#007bff;color:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.app-header h1{margin:0;font-size:24px}.header-actions{display:flex;gap:10px}.header-actions button{padding:8px 16px;background:#fff;color:#007bff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.header-actions button:hover{background:#f0f0f0}.conversation-btn{background:#28a745!important;color:#fff!important}.conversation-btn:hover{background:#218838!important}.conversation-btn.active{background:#ffc107!important;color:#000!important}.conversation-btn.active:hover{background:#e0a800!important}.new-game-btn{background:#dc3545!important;color:#fff!important}.new-game-btn:hover{background:#c82333!important}.header-actions button:disabled{opacity:.5;cursor:not-allowed;background:#ccc!important;color:#666!important}.header-actions button:disabled:hover{background:#ccc!important}.error-banner{background:#f8d7da;color:#721c24;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f5c6cb}.error-banner button{background:none;border:none;color:#721c24;font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.app-content{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:20px;max-width:2000px;margin:0 auto}.left-column,.right-column{display:flex;flex-direction:column;gap:20px}@media (max-width: 1200px){.app-content{grid-template-columns:1fr}}*{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}#root{min-height:100vh}
