.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}.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[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}.command-forms{padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.command-forms h2{margin-bottom:20px;color:#333}.command-section{margin-bottom:25px;padding-bottom:20px;border-bottom:1px solid #eee}.command-section:last-child{border-bottom:none}.command-section h3{margin-bottom:12px;color:#555;font-size:16px}.form-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.form-row select,.form-row input[type=number]{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-row input[type=range]{flex:1;min-width:150px}.form-row button{padding:8px 16px;background:#28a745;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background .2s}.form-row button:hover:not(:disabled){background:#218838}.form-row button:disabled{background:#ccc;cursor:not-allowed}.slider-row{display:grid;grid-template-columns:200px 1fr 80px;gap:12px;align-items:center;margin-bottom:8px}.slider-row label{font-weight:500;font-size:14px;color:#333}.slider-row input[type=range]{width:100%}.slider-row span{text-align:right;font-family:monospace;font-weight:600;font-size:14px;color:#333}.allocation-summary{display:flex;justify-content:space-between;align-items:center;padding:12px;margin:16px 0;background:#f5f5f5;border-radius:4px}.total-allocation{font-size:16px;font-weight:600}.total-allocation.valid{color:#2ecc71}.total-allocation.invalid{color:#e74c3c}.validation-warning{color:#e74c3c;font-size:14px;font-weight:500}.button-group{display:flex;gap:12px;margin-top:16px}.secondary-button{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-weight:500;font-size:14px;transition:background .2s}.secondary-button:hover:not(:disabled){background:#5a6268}.primary-button{background:#007bff;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-weight:500;font-size:14px;flex:1;transition:background .2s}.primary-button:hover:not(:disabled){background:#0056b3}.primary-button:disabled,.secondary-button:disabled{opacity:.5;cursor:not-allowed}.feedback-message{padding:12px;margin:12px 0;border-radius:4px;font-weight:500;font-size:14px}.feedback-message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.feedback-message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.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:20px}.resource-section h4{margin-bottom:10px;color:#555}.resource-section ul{list-style:none;padding:0}.resource-section li{padding:6px 0;color:#666}.shortfalls{background:#fff3cd;padding:15px;border-radius:6px}.shortfalls li{color:#856404}.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}.research-domain-card{background:#f5f5f5;border:1px solid #ddd;border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:12px}.research-domain-card.stalled{border-color:#ff6b6b;background:#fff5f5}.research-domain-card .domain-header{display:flex;justify-content:space-between;align-items:center}.research-domain-card .domain-name{font-size:16px;font-weight:600;margin:0}.stalled-badge{background:#ff6b6b;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.breakthrough-info{display:flex;flex-direction:column;gap:8px}.current-breakthrough,.next-breakthrough{display:flex;gap:8px}.current-breakthrough .label,.next-breakthrough .label{font-weight:500;color:#666}.current-breakthrough .value{color:#2c3e50;font-weight:600}.next-breakthrough .value{color:#3498db;font-style:italic}.progress-section{display:flex;flex-direction:column;gap:4px}.research-domain-card .progress-bar{height:20px;background:#e0e0e0;border-radius:10px;overflow:hidden}.research-domain-card .progress-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);transition:width .3s ease}.research-domain-card.stalled .progress-fill{background:#ff6b6b}.progress-text{font-size:12px;color:#666;text-align:center}.allocation-info{display:flex;justify-content:space-between;padding-top:8px;border-top:1px solid #ddd}.allocation-info .label{font-weight:500;color:#666}.allocation-info .value{font-weight:600;color:#2c3e50}.research-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:16px}@media (max-width: 768px){.research-view{grid-template-columns:1fr}}.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;height:600px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000026;overflow:hidden}.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}.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)}.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}.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}.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}
