:root{--primary-color: #3498db;--secondary-color: #2c3e50;--accent-color: #e74c3c;--light-bg: #ecf0f1;--dark-bg: #34495e;--text-color: #2c3e50;--white: #ffffff;--shadow: 0 4px 6px rgba(0, 0, 0, .1);--status-full: #e74c3c;--status-almost-full: #f39c12;--status-balanced: #2ecc71;--status-almost-empty: #f1c40f;--status-empty: #c0392b}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:var(--text-color);background-color:var(--light-bg);padding:20px}#app{max-width:1200px;margin:0 auto}header{background-color:var(--white);border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:var(--shadow)}h1{color:var(--primary-color);margin-bottom:20px;text-align:center}h2{color:var(--secondary-color);margin-bottom:15px;font-size:1.2rem}.controls{display:flex;flex-wrap:wrap;gap:15px;align-items:center;justify-content:center}.control-group{display:flex;align-items:center;gap:5px}button{border:none;padding:10px 16px;border-radius:8px;font-weight:500;font-family:Inter,sans-serif;font-size:.9rem;letter-spacing:.3px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;box-shadow:0 2px 5px #00000014,0 1px 1px #0000000a;position:relative;overflow:hidden;color:#fff}button:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:#ffffff1a;opacity:0;transition:opacity .2s ease}button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001f,0 2px 3px #00000014}button:hover:after{opacity:1}button:active{transform:translateY(1px);box-shadow:0 1px 3px #0000001a}#run-step{background:linear-gradient(135deg,#3498db,#2980b9)}#advance-time{background:linear-gradient(135deg,#9b59b6,#8e44ad)}#simulate-day{background:linear-gradient(135deg,#27ae60,#2ecc71)}#reset-simulation{background:linear-gradient(135deg,#e74c3c,#c0392b)}.emoji{font-size:1.1em}.custom-select{position:relative}.custom-select select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border:1px solid #ddd;border-radius:6px;padding:8px 30px 8px 12px;font-size:14px;cursor:pointer;font-family:Inter,sans-serif;box-shadow:0 1px 3px #0000000d;transition:border-color .2s ease,box-shadow .2s ease}.custom-select select:hover{border-color:#bbb;box-shadow:0 1px 3px #0000001a}.custom-select select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db33}.custom-select:after{content:"▼";position:absolute;top:50%;right:12px;transform:translateY(-50%);pointer-events:none;font-size:10px;color:#666}select{padding:6px 10px;border-radius:4px;border:1px solid #ccc}.dashboard{display:grid;grid-template-columns:1fr 3fr;gap:24px;margin-bottom:20px}.stats-panel,.visualization-panel{background-color:var(--white);border-radius:8px;padding:20px;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.1);box-shadow:0 4px 16px #00000014}.stats-panel,.visualization-panel,.chart-container,.station-list{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000000d,0 1px 2px #0000001a;transition:all .2s ease}.stats-panel:hover,.visualization-panel:hover,.chart-container:hover,.station-list:hover{box-shadow:0 3px 6px #00000014,0 3px 6px #0000001f}.stats-panel{background:linear-gradient(to bottom right,#fff,#f9f9f9);border:1px solid rgba(0,0,0,.1);box-shadow:0 4px 12px #0000000d;padding:20px}.stat-item{padding:8px 0;border-bottom:1px solid rgba(0,0,0,.05);display:flex;justify-content:space-between;align-items:center;transition:background-color .2s ease}.stat-item:hover{background-color:#3498db0d}.highlight-stat{background-color:#9b59b614;border-radius:6px;padding:8px 12px;margin:8px 0;border-left:3px solid #9b59b6}.efficiency{font-weight:700;padding:3px 8px;border-radius:4px;font-size:.9em}.efficiency.high{background-color:#2ecc7133;color:#27ae60}.efficiency.medium{background-color:#f1c40f33;color:#f39c12}.efficiency.low{background-color:#e74c3c33;color:#c0392b}.stat-item{margin-bottom:10px;display:flex;justify-content:space-between}.stat-label{font-weight:700}#map-container{height:400px;border:1px solid #eaeaea;border-radius:8px;background-color:#f8f9fa;position:relative;overflow:hidden;box-shadow:inset 0 1px 3px #0000000d}.map-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#2c3e501a;z-index:1}.neighborhood-label{position:absolute;font-size:10px;color:var(--secondary-color);opacity:.7;pointer-events:none;text-shadow:0px 0px 2px white;font-weight:700;z-index:2;background:#ffffffb3;padding:3px 6px;border-radius:4px;border:1px solid rgba(0,0,0,.05)}.station-point{position:absolute;width:38px;height:38px;border-radius:50%;background-color:var(--primary-color);transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;cursor:pointer;transition:transform .3s,box-shadow .3s;box-shadow:0 0 0 1px #fff,0 2px 6px #00000040;border:2px solid white;z-index:5}.station-point:hover{transform:translate(-50%,-50%) scale(1.15);z-index:10;box-shadow:0 3px 8px #0000004d}.station-point.status-full{background-color:#e74c3c}.station-point.status-almost-full{background-color:#f39c12}.station-point.status-balanced{background-color:#2ecc71}.station-point.status-almost-empty{background-color:#f1c40f}.station-point.status-empty{background-color:#c0392b}.station-tooltip{position:absolute;background-color:#fff;color:#333;padding:12px 15px;border-radius:8px;z-index:100;pointer-events:none;box-shadow:0 4px 15px #00000026;border:1px solid #eaeaea;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);min-width:200px;font-size:.9em}.station-flow{position:absolute;z-index:3;pointer-events:none}.station-list{background-color:var(--white);border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:var(--shadow)}#stations-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px;margin-top:15px}.station-card{background:#fff;border-radius:10px;padding:16px;margin-bottom:16px;transition:all .2s ease;border-left:4px solid transparent;box-shadow:0 2px 4px #0000000a,0 0 0 1px #00000008}.station-card:hover{box-shadow:0 4px 8px #00000014,0 0 0 1px #0000000d}.station-card.status-balanced{border-left-color:#2ecc71}.station-card.status-almost-full,.station-card.status-almost-empty{border-left-color:#f1c40f}.station-card.status-full,.station-card.status-empty{border-left-color:#e74c3c}.station-card.status-full{border-left-color:red}.station-name{font-weight:700;margin-bottom:5px;display:flex;align-items:center;justify-content:space-between}.station-location{font-size:.8em;color:#777;margin-bottom:8px;display:flex;align-items:center}.station-location:before{content:"📍";margin-right:4px;font-size:.9em}.station-icon{margin-right:5px;font-size:1.2em}.status-indicator{width:12px;height:12px;border-radius:50%;display:inline-block;margin-right:5px;vertical-align:middle;padding:3px 8px;font-size:.9em;font-weight:500}.status-indicator.idle{background-color:#ecf0f1;color:#7f8c8d}.status-indicator.low{background-color:#d5f5e3;color:#27ae60}.status-indicator.moderate{background-color:#fef9e7;color:#f39c12}.status-indicator.high{background-color:#fadbd8;color:#e74c3c}.status-badge{display:inline-block;padding:2px 6px;border-radius:4px;font-size:.75em;font-weight:500;margin-left:8px}.status-badge.full,.status-badge.empty{background-color:#e74c3c26;color:#c0392b}.status-badge.full{background-color:#f003;color:red;font-weight:700}.status-badge.almost-full,.status-badge.almost-empty{background-color:#f1c40f26;color:#d35400}.status-badge.balanced{background-color:#2ecc7126;color:#27ae60}.station-status{display:flex;align-items:center;font-size:.85em;margin-bottom:8px;color:#555}.progress-container{background-color:#f5f5f5;height:12px;border-radius:6px;margin:10px 0;overflow:hidden;box-shadow:inset 0 1px 2px #0000001a;border:1px solid #eaeaea}.progress-bar{height:100%;background-color:var(--primary-color);width:70%;transition:width .3s ease}.progress-bar.status-full{background-color:red;background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:1rem 1rem;animation:progress-bar-stripes 1s linear infinite}@keyframes progress-bar-stripes{0%{background-position:1rem 0}to{background-position:0 0}}.progress-bar.status-almost-full{background-color:#f39c12}.progress-bar.status-balanced{background-color:#2ecc71}.progress-bar.status-almost-empty{background-color:#f1c40f}.progress-bar.status-empty{background-color:#c0392b}.fill-percentage{font-weight:700;margin-bottom:5px}.station-card .fill-percentage:contains("100%"){color:red;font-weight:700}.charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px}.chart-container{background-color:var(--white);border-radius:8px;padding:15px;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.1);box-shadow:0 4px 12px #0000000d}.chart-container h2{display:flex;align-items:center;gap:8px}.chart-info{font-size:.75rem;color:#666;font-style:italic;margin-top:5px;margin-bottom:10px}canvas{width:100%!important;max-height:300px}.hidden{display:none!important}#loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#ffffffeb;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000;transition:opacity .3s ease-out}.spinner-container{position:relative;width:80px;height:80px;margin-bottom:20px}.spinner{box-sizing:border-box;position:absolute;top:50%;left:50%;width:60px;height:60px;margin-top:-30px;margin-left:-30px;border-radius:50%;border:4px solid transparent;border-top-color:var(--primary-color);animation:spin 1s linear infinite}.spinner:before,.spinner:after{content:"";box-sizing:border-box;position:absolute;border-radius:50%}.spinner:before{top:-10px;left:-10px;right:-10px;bottom:-10px;border:4px solid transparent;border-left-color:var(--secondary-color);animation:spin 1.5s linear infinite}.spinner:after{top:6px;left:6px;right:6px;bottom:6px;border:4px solid transparent;border-right-color:var(--accent-color);animation:spin 1s linear infinite reverse}.loading-text{font-size:1.1rem;font-weight:500;margin-top:10px;color:var(--dark-bg);text-align:center;max-width:80%}.loading-progress{display:flex;align-items:center;margin-top:15px;width:200px}.progress-bar-container{flex-grow:1;height:6px;background-color:#0000001a;border-radius:3px;overflow:hidden;margin-right:10px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));border-radius:3px;width:0%;transition:width .3s ease}.loading-icon{display:inline-block;margin-right:8px;animation:pulse 1.2s ease-in-out infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}to{transform:scale(1);opacity:1}}.fade-in{animation:fadeIn .5s ease-in forwards}.hidden{opacity:0;pointer-events:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.quantum-loading .loading-icon{position:relative}.quantum-loading .loading-icon:after{content:"";position:absolute;width:24px;height:24px;background:radial-gradient(circle,#3498db66,#9b59b600 70%);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);animation:quantumPulse 2s ease-in-out infinite}@keyframes quantumPulse{0%{transform:translate(-50%,-50%) scale(.8);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.2);opacity:.2}to{transform:translate(-50%,-50%) scale(.8);opacity:.5}}.legend{position:absolute;bottom:15px;right:15px;background-color:#fff;border-radius:8px;padding:12px;box-shadow:0 2px 8px #00000026;border:1px solid #eaeaea;font-size:.85rem;max-width:180px;z-index:10}.legend-item{display:flex;align-items:center;gap:8px;margin-bottom:6px}.legend-color{width:16px;height:16px;border-radius:4px;box-shadow:inset 0 0 0 1px #0000001a}.emoji{margin-right:5px;font-size:1.2em}.quantum-badge{display:inline-flex;align-items:center;background:linear-gradient(135deg,#9b59b61a,#3498db1a);border:1px solid rgba(155,89,182,.2);color:#8e44ad;padding:4px 10px;border-radius:4px;font-weight:600;font-size:.85em;margin-left:4px;letter-spacing:.5px}.quantum-badge:before{content:"⚛️";margin-right:4px}.visualization-panel{background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:10px;overflow:hidden;box-shadow:0 4px 16px #00000014}.visualization-panel h2{border-bottom:1px solid rgba(0,0,0,.05);padding-bottom:12px;margin-bottom:16px}.custom-select{position:relative;display:inline-block}.custom-select select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border:1px solid #ddd;border-radius:4px;padding:8px 30px 8px 10px;font-size:14px;cursor:pointer}.custom-select:after{content:"▼";position:absolute;top:50%;right:10px;transform:translateY(-50%);pointer-events:none;font-size:10px}.weather-display{display:flex;align-items:center;gap:8px}.weather-icon{font-size:1.5em}.neighborhood-name{font-style:italic;font-size:.85rem;color:#666}.time-display{display:flex;align-items:center;background-color:var(--dark-bg);color:#fff;padding:5px 10px;border-radius:4px;font-weight:700;margin:0 10px}.time-icon{margin-right:5px}.controls-info{font-size:.8em;text-align:center;color:#777;margin-top:15px;padding:5px;border-top:1px dashed #ddd}.simulation-explanations{background-color:#fff;border-radius:12px;box-shadow:0 4px 16px #00000014;margin:24px 0;overflow:hidden}.explanations-header{background:linear-gradient(135deg,#3498db,#9b59b6);color:#fff;padding:18px 24px;border-bottom:1px solid rgba(0,0,0,.05)}.explanations-header h2{margin:0;font-size:1.4rem;color:#fff;display:flex;align-items:center;gap:10px}.explanations-header h2:before{content:"💡";font-size:1.5rem}.explanations-content{padding:0}.explanation-tabs{display:flex;border-bottom:1px solid #eee}.explanation-tab{padding:12px 24px;cursor:pointer;font-weight:500;color:#666;position:relative;transition:all .2s ease}.explanation-tab.active{color:#3498db;background-color:#3498db0d}.explanation-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:3px;background-color:#3498db}.explanation-tab:not(.active):hover{background-color:#00000008}.tab-content{display:none;padding:24px;line-height:1.6}.tab-content.active{display:block;animation:fadeIn .3s ease}.technical-tab{border-left:3px solid #3498db}.non-technical-tab{border-left:3px solid #2ecc71}.technical-icon:before{content:"⚙️";margin-right:8px}.non-technical-icon:before{content:"👨‍👩‍👧‍👦";margin-right:8px}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}#technical-explanation,#non-technical-explanation{margin:0;font-family:Inter,sans-serif;white-space:normal;overflow-wrap:break-word}#technical-explanation{color:#2c3e50}#non-technical-explanation{color:#34495e}.explanation-section{margin-bottom:16px}.explanation-section:last-child{margin-bottom:0}.loading-explanation{display:flex;align-items:center;justify-content:center;padding:40px;color:#999;font-style:italic}.tech-stat{display:inline-block;background-color:#3498db1a;padding:1px 5px;border-radius:3px;font-weight:500;color:#2980b9}.station-card.status-full .action-needed{color:red;font-weight:700;font-size:.95em}
