*{box-sizing:border-box;margin:0;padding:0}body{color:#2d3a2d;background:#f5f7f5;font-family:"Source Sans 3",-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;overflow:hidden}.source-sans-3-400{font-optical-sizing:auto;font-family:"Source Sans 3",sans-serif;font-style:normal;font-weight:400}.source-sans-3-600{font-optical-sizing:auto;font-family:"Source Sans 3",sans-serif;font-style:normal;font-weight:600}.source-sans-3-800{font-optical-sizing:auto;font-family:"Source Sans 3",sans-serif;font-style:normal;font-weight:800}#root{width:100vw;height:100vh}.app{background:linear-gradient(#e8f0e8 0%,#d4e4d4 100%);flex-direction:column;height:100vh;display:flex}.header{background:#fff;border-bottom:1px solid #c8d8c8;justify-content:space-between;align-items:center;padding:12px 20px;display:flex;box-shadow:0 1px 4px #0000000d}.header h1{color:#3a5a3a;font-size:1.4rem;font-weight:600}.header-controls{align-items:center;gap:8px;display:flex}.header-stats{color:#5a7a5a;gap:16px;margin-right:16px;font-size:.85rem;display:flex}.header-stat{align-items:center;gap:4px;display:flex}.btn{cursor:pointer;border:none;padding:8px 16px;font-size:.85rem;font-weight:500;transition:all .15s}.btn-primary{color:#fff;background:#5a8a5a}.btn-primary:hover{background:#4a7a4a}.btn-secondary{color:#3a5a3a;background:#e8f0e8;border:1px solid #c8d8c8}.btn-secondary:hover{background:#d8e8d8}.btn-icon{background:0 0;border:1px solid #c8d8c8;justify-content:center;align-items:center;padding:8px;display:flex}.btn-icon:hover{background:#e8f0e8}.main-content{flex:1;display:flex;overflow:hidden}.map-container{background:linear-gradient(#b8d4b8 0%,#98c498 50%,#88b888 100%);flex:1;position:relative;overflow:hidden}.map-canvas{width:100%;height:100%;position:relative}.grass-pattern{opacity:.5;pointer-events:none;background-image:radial-gradient(circle at 20% 30%,#9fca9f 1px,#0000 1px),radial-gradient(circle at 80% 60%,#8aba8a 1px,#0000 1px),radial-gradient(circle at 40% 80%,#a5cfa5 1px,#0000 1px);background-size:40px 40px;position:absolute;inset:0}.location{cursor:pointer;transition:transform .2s;position:absolute;transform:translate(-50%,-50%)}.location:hover{transform:translate(-50%,-50%)scale(1.05)}.location-node{background:linear-gradient(135deg,#fff 0%,#f0f8f0 100%);border:3px solid #8ab88a;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.6rem;display:flex;box-shadow:0 4px 12px #00000026}.location-label{color:#3a5a3a;white-space:nowrap;background:#fffffff2;border-radius:6px;margin-top:6px;padding:3px 8px;font-size:.75rem;font-weight:600;position:absolute;top:100%;left:50%;transform:translate(-50%);box-shadow:0 2px 4px #0000001a}.agent{cursor:pointer;z-index:10;transition:all .5s;position:absolute;transform:translate(-50%,-50%)}.agent:hover{z-index:20}.agent-sprite{background:#fff;border:3px solid;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:all .15s;display:flex;box-shadow:0 2px 8px #0003}.agent:hover .agent-sprite{transform:scale(1.2);box-shadow:0 4px 12px #00000040}.agent-selected .agent-sprite{box-shadow:0 0 0 3px #5a8a5a,0 4px 12px #00000040}.agent-moving .agent-sprite{animation:.5s ease-in-out infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.agent-action-indicator{background:#fff;border:1px solid #c8d8c8;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.65rem;display:flex;position:absolute;top:-6px;right:-6px}.agent-label{color:#3a5a3a;white-space:nowrap;background:#fffffff2;margin-top:4px;padding:2px 6px;font-size:.7rem;font-weight:600;position:absolute;top:100%;left:50%;transform:translate(-50%);box-shadow:0 1px 3px #0000001a}.sidebar{background:#fff;border-left:1px solid #c8d8c8;flex-direction:column;flex-shrink:0;width:340px;min-width:340px;max-width:340px;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid #e8f0e8;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.sidebar-header h2{color:#3a5a3a;font-size:1rem;font-weight:600}.sidebar-tabs{border-bottom:1px solid #e8f0e8;display:flex}.sidebar-tab{cursor:pointer;color:#7a9a7a;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px;font-size:.8rem;font-weight:500;transition:all .15s}.sidebar-tab:hover{background:#f8fcf8}.sidebar-tab.active{color:#3a5a3a;border-bottom-color:#5a8a5a}.sidebar-content{flex-direction:column;flex:1;min-height:0;padding:12px;display:flex;overflow:hidden}.events-full-height{flex:1;height:100%;min-height:0;max-height:100%;overflow-y:auto}.panel{background:#f8fcf8;margin-bottom:12px;padding:12px}.panel-header{color:#5a7a5a;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.75rem;font-weight:600}.stat-row{justify-content:space-between;padding:4px 0;font-size:.85rem;display:flex}.stat-label{color:#5a7a5a}.stat-value{color:#3a5a3a;font-weight:500}.inventory-grid{grid-template-columns:repeat(4,1fr);gap:4px;display:grid}.inventory-item{text-align:center;background:#fff;border:1px solid #e8f0e8;padding:6px 4px;font-size:.7rem}.inventory-item-icon{margin-bottom:2px;font-size:1rem}.inventory-item-count{color:#3a5a3a;font-weight:600}.need-bar-container{margin-bottom:8px}.need-bar-label{justify-content:space-between;margin-bottom:2px;font-size:.75rem;display:flex}.need-bar{background:#e8f0e8;height:6px;overflow:hidden}.need-bar-fill{height:100%;transition:width .3s}.event-list{overflow-y:auto}.event-item{border-bottom:1px solid #e8f0e8;padding:8px;font-size:.8rem}.event-item:last-child{border-bottom:none}.event-header{justify-content:space-between;margin-bottom:4px;display:flex}.event-agent{color:#3a5a3a;font-weight:500}.event-tick{color:#7a9a7a;font-size:.7rem}.event-action{margin-right:4px;padding:1px 6px;font-size:.7rem;font-weight:500;display:inline-block}.event-action.MOVE{color:#2a5a9a;background:#d4e8ff}.event-action.HARVEST{color:#2a7a2a;background:#d4f0d4}.event-action.CRAFT{color:#7a5a2a;background:#f0e8d4}.event-action.TRADE_PROPOSAL{color:#7a2a7a;background:#f0d4f0}.event-action.MESSAGE{color:#2a7a7a;background:#d4f0f0}.event-action.IDLE{color:#5a5a5a;background:#e8e8e8}.event-message{color:#5a7a5a;word-break:break-word}.event-reasoning{color:#5a7a5a;background:#fff;margin-top:4px;padding:6px;font-size:.75rem;font-style:italic}.stats-overlay,.settings-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.settings-modal{background:#fff;width:400px;max-width:90vw;padding:24px;box-shadow:0 10px 40px #0003}.settings-modal h2{color:#3a5a3a;margin:0 0 20px;font-size:1.25rem}.settings-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#5a7a5a;font-size:.85rem;font-weight:500}.form-group input{background:#f8faf8;border:1px solid #c8d8c8;padding:10px 12px;font-size:.9rem;transition:border-color .2s}.form-group input:focus{background:#fff;border-color:#5a8a5a;outline:none}.settings-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.status-connected{color:#5a8a5a}.status-disconnected{color:#b85a5a}.stats-modal{background:#fff;flex-direction:column;width:90%;max-width:1000px;max-height:90vh;display:flex;overflow:hidden}.stats-modal-header{border-bottom:1px solid #e8f0e8;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.stats-modal-header h2{color:#3a5a3a;font-size:1.2rem}.stats-modal-close{cursor:pointer;color:#7a9a7a;background:0 0;border:none;font-size:1.5rem}.stats-modal-content{flex:1;padding:20px;overflow-y:auto}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}.stats-card{background:#f8fcf8;padding:16px}.stats-card h3{color:#5a7a5a;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:.85rem;font-weight:600}.chart-container{height:200px}.agent-types-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.agent-type-item{background:#fff;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.agent-type-label{align-items:center;gap:6px;font-size:.85rem;display:flex}.agent-type-dot{border-radius:50%;width:10px;height:10px}.agent-type-count{color:#3a5a3a;font-size:1.1rem;font-weight:600}.groups-list{max-height:200px;overflow-y:auto}.group-item{background:#fff;justify-content:space-between;margin-bottom:6px;padding:8px;display:flex}.group-name{color:#3a5a3a;font-weight:500}.group-members{color:#7a9a7a;font-size:.8rem}.loading{color:#7a9a7a;justify-content:center;align-items:center;height:100%;font-size:1.1rem;display:flex}.setup-screen{background:linear-gradient(#e8f0e8 0%,#d4e4d4 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.setup-container{background:#fff;width:100%;max-width:480px;padding:40px;box-shadow:0 10px 40px #0000001a}.setup-header{text-align:center;margin-bottom:32px}.setup-header h1{color:#3a5a3a;margin-bottom:8px;font-size:2rem;font-weight:700}.setup-header p{color:#7a9a7a;font-size:1rem}.setup-form{flex-direction:column;gap:20px;display:flex}.setup-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;padding:12px 16px;font-size:.9rem}.setup-actions{gap:12px;margin-top:12px;display:flex}.setup-actions .btn{flex:1}.setup-divider{text-align:center;color:#9a9a9a;align-items:center;margin:24px 0;font-size:.85rem;display:flex}.setup-divider:before,.setup-divider:after{content:"";border-bottom:1px solid #e0e0e0;flex:1}.setup-divider span{padding:0 16px}.demo-section{text-align:center}.demo-section .btn-demo{color:#fff;background:linear-gradient(135deg,#6b7280 0%,#4b5563 100%);border:none;width:100%}.demo-section .btn-demo:hover{background:linear-gradient(135deg,#5b6270 0%,#3b4553 100%)}.demo-hint{color:#7a7a7a;margin-top:12px;font-size:.8rem;line-height:1.5}.demo-hint strong{color:#5a5a5a}.demo-badge{color:#78350f;background:linear-gradient(135deg,#fbbf24 0%,#f59e0b 100%);flex-direction:column;align-items:center;margin-left:16px;padding:6px 16px;display:flex}.demo-badge span{letter-spacing:.5px;font-size:.75rem;font-weight:700}.demo-badge small{opacity:.8;font-size:.65rem}.btn-large{padding:14px 24px;font-size:1rem}.setup-info{border-top:1px solid #e8f0e8;margin-top:32px;padding-top:24px}.setup-info h3{color:#5a7a5a;margin-bottom:8px;font-size:.9rem;font-weight:600}.setup-info p{color:#7a9a7a;font-size:.85rem;line-height:1.6}.form-hint{color:#9a9a9a;margin-top:4px;font-size:.75rem}.status-running{color:#5a8a5a;font-weight:500}.status-stopped{color:#9a7a5a}.speed-control{border-right:1px solid #e8f0e8;align-items:center;gap:8px;margin-right:8px;padding:0 12px;display:flex}.speed-control label{color:#5a7a5a;font-size:.8rem}.speed-control input[type=range]{width:80px}.docs-link{text-align:center;margin-top:24px}.btn-link{color:#5a8a5a;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;transition:color .15s;display:inline-flex}.btn-link:hover{color:#3a6a3a;text-decoration:underline}.docs-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:flex-start;padding:20px;display:flex;position:fixed;inset:0;overflow-y:auto}.docs-container{background:#fefefe;border-radius:8px;width:100%;max-width:900px;max-height:calc(100vh - 40px);overflow-y:auto;box-shadow:0 8px 32px #0003}.docs-header{z-index:10;background:#fefefe;border-bottom:1px solid #e8e8e8;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:sticky;top:0}.docs-header h1{color:#2d3a2d;margin:0;font-size:1.5rem;font-weight:600}.docs-content{padding:24px}.docs-section{border:1px solid #e8e8e8;border-radius:6px;margin-bottom:24px;overflow:hidden}.docs-section-title{color:#3a5a3a;cursor:pointer;-webkit-user-select:none;user-select:none;background:#f8f8f8;border:none;align-items:center;gap:8px;margin:0;padding:14px 16px;font-size:1rem;font-weight:600;display:flex}.docs-section-title:hover{background:#f0f4f0}.docs-section-content{padding:16px 20px}.docs-section-content p{color:#4a4a4a;margin:0 0 12px;font-size:.9rem;line-height:1.6}.docs-section-content h3{color:#3a5a3a;margin:20px 0 10px;font-size:1rem;font-weight:600}.docs-section-content h3:first-child{margin-top:0}.docs-section-content h4{color:#5a7a5a;margin:16px 0 8px;font-size:.9rem;font-weight:600}.docs-section-content ul,.docs-section-content ol{color:#4a4a4a;margin:0 0 12px;padding-left:24px;font-size:.9rem;line-height:1.8}.docs-section-content li{margin-bottom:4px}.docs-section-content strong{color:#2d3a2d}.docs-table{border-collapse:collapse;width:100%;margin:12px 0;font-size:.85rem}.docs-table th,.docs-table td{text-align:left;border:1px solid #e0e0e0;padding:10px 12px}.docs-table th{color:#3a5a3a;background:#f4f4f4;font-weight:600}.docs-table td{color:#4a4a4a}.docs-table tr:nth-child(2n) td{background:#fafafa}.docs-table tr:hover td{background:#f0f4f0}
