*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;color:#333;background-color:#f5f5f5}h1,h2,h3,h4{font-weight:600;margin-bottom:1rem}h1{font-size:1.8rem;text-align:center;padding:1rem 0;margin-bottom:2rem;background-color:#036;color:#fff}h2{font-size:1.4rem;color:#036;padding-bottom:.5rem;border-bottom:2px solid #eaeaea}h3{font-size:1.2rem;color:#0055a4}h4{font-size:1rem;color:#666}.app-container{width:100%;max-width:1400px;margin:0 auto;padding:0 1rem}.visualization-layout{display:flex;gap:2rem;flex-direction:column}@media (min-width: 992px){.visualization-layout{flex-direction:row}.setup-column{flex:1;min-width:300px;max-width:400px}.visualization-column{flex:2}}.setup-frame,.team-visualization-pane,.codebase-visualization-pane{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;margin-bottom:2rem}.setup-section{margin-bottom:1.5rem}.form-group{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}input[type=text],select{padding:.5rem;border:1px solid #ddd;border-radius:4px;flex:1;min-width:150px}button{background-color:#0055a4;color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;cursor:pointer;transition:background-color .2s}button:hover{background-color:#003d7a}button:disabled{background-color:#ccc;cursor:not-allowed}.config-controls button{flex:1;min-width:140px;font-weight:500}.config-controls button:first-child{background-color:#2a9d8f}.config-controls button:first-child:hover{background-color:#237c6e}.config-controls button:last-of-type{background-color:#e76f51}.config-controls button:last-of-type:hover{background-color:#cc5b40}.team-members-list,.products-list{background-color:#f9f9f9;border-radius:4px;padding:.75rem;margin-top:.75rem}ul{list-style-type:none;padding-left:.5rem}li{padding:.25rem 0;border-bottom:1px solid #eee}li:last-child{border-bottom:none}.components-list{margin-top:.25rem;margin-left:1rem;padding-left:.25rem;border-left:2px solid #eee}.components-list li{font-size:.9rem;padding:.1rem 0;color:#666}.controls{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.speed-control{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.parameter-sliders{display:flex;flex-direction:column;gap:1rem}.parameter{display:flex;align-items:center;gap:.5rem}.parameter label{min-width:180px}.team-stats,.codebase-stats{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem;background-color:#f5f7fa;padding:1rem;border-radius:6px}.stat{background-color:#fff;padding:.75rem;border-radius:4px;box-shadow:0 1px 3px #0000001a;flex:1;min-width:150px}.stat .label{font-weight:500;color:#666;display:block;margin-bottom:.25rem}.stat .value{font-size:1.25rem;font-weight:600;color:#0055a4}.simulation-panel,.stats-panel,.team-panel{background-color:#1a1a1a;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.control-group{margin-bottom:1.5rem;text-align:left}.control-group label{display:flex;align-items:center;gap:.5rem}.control-group input[type=range]{flex:1}.team-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem}.team-member{background-color:#2a2a2a;border-radius:6px;padding:1rem;text-align:left}.member-name{font-weight:700;font-size:1.1rem;margin-bottom:.3rem}.member-role{color:#aaa;font-size:.9rem;margin-bottom:.7rem}.member-heat{display:flex;justify-content:space-between}.productive{color:#4cc9f0}.wasteful{color:#f72585}@media (prefers-color-scheme: light){.simulation-panel,.stats-panel,.team-panel{background-color:#fff;box-shadow:0 2px 8px #0000001a}.team-member{background-color:#f5f5f5}.member-role{color:#666}}.team-selector{margin-bottom:1rem}.team-tabs{display:flex;border-bottom:1px solid #ddd;overflow-x:auto;padding-bottom:1px}.team-tab{padding:.5rem 1rem;background-color:#f0f0f0;border:1px solid #ddd;border-bottom:none;border-radius:4px 4px 0 0;margin-right:.25rem;cursor:pointer;display:flex;align-items:center;min-width:120px;position:relative}.team-tab.active{background-color:#fff;border-bottom:1px solid white;margin-bottom:-1px;font-weight:500}.team-tab input{width:100%;padding:.25rem;border:1px solid #0055a4;border-radius:2px}.team-name{flex-grow:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.team-actions{display:flex;opacity:0;transition:opacity .2s}.team-tab:hover .team-actions{opacity:1}.team-actions .edit-btn,.team-actions .remove-btn{background:none;border:none;font-size:14px;padding:.1rem .3rem;cursor:pointer;margin-left:.2rem}.team-actions .edit-btn:hover,.team-actions .remove-btn:hover{background-color:#0000001a;border-radius:2px}.add-team-btn{background-color:#eaeaea;border:1px dashed #aaa;border-radius:4px 4px 0 0;padding:.25rem .75rem;margin-left:.5rem;cursor:pointer;font-size:1.1rem;font-weight:700;color:#555}.add-team-btn:hover{background-color:#e0e0e0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:#fff;border-radius:8px;padding:1.5rem;width:90%;max-width:500px;box-shadow:0 5px 15px #0003}.modal-content h3{margin-top:0;border-bottom:1px solid #eee;padding-bottom:.75rem;margin-bottom:1rem}.modal-content .form-group{margin-bottom:1rem;display:flex;flex-direction:column}.modal-content label{font-weight:500;margin-bottom:.25rem}.modal-content input{padding:.5rem;border:1px solid #ddd;border-radius:4px}.modal-content input:disabled{background-color:#f5f5f5;cursor:not-allowed}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;border-top:1px solid #eee;padding-top:1rem}.primary-button{background-color:#0055a4;color:#fff}.team-member-node{cursor:pointer}.role-badge{x:-50px;y:-10px;width:100px;height:20px;rx:4px}.role-text{y:4px;text-anchor:middle;fill:#fff;font-size:10px;font-weight:500;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.member-text{y:0;text-anchor:middle;fill:#666;font-size:14px;font-weight:700;dominant-baseline:middle;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.team-label{x:-60px;y:-12px;width:120px;height:24px;rx:4px;fill:#1a1a1a;stroke:#ffffff1a;stroke-width:1px}.team-title-text{y:4px;text-anchor:middle;fill:#fff;font-size:12px;font-weight:500;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.team-connection{stroke:#ddd;stroke-width:1px;opacity:.3}.team-member-container{cursor:pointer}.team-member-role-label{transform:translateY(-55px)}.team-member-role-background{x:-50px;y:-12px;width:100px;height:20px;rx:4px;fill:#1a1a1a!important;stroke:#ffffff1a;stroke-width:1}.team-member-role-text{y:4px;text-anchor:middle;fill:#fff!important;font-size:10px!important;font-weight:500!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.team-member-circle{fill:#f5f5f5;stroke:#1a1a1a;stroke-width:2px}.team-member-abbreviation{y:0;text-anchor:middle;fill:#666!important;font-size:14px!important;font-weight:700!important;dominant-baseline:middle;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.team-member-name-container{transform:translateY(55px)}.team-member-name-background{x:-40px;y:-12px;width:80px;height:20px;rx:4px;fill:#1a1a1a!important;stroke:#ffffff1a;stroke-width:1}.team-member-name-text{y:4px;text-anchor:middle;fill:#fff!important;font-size:10px!important;font-weight:500!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.team-member-tooltip{fill:#000000e6;stroke:#fff}.team-member-tooltip-text{fill:#fff;font-size:12px;text-anchor:middle}.team-name-container{transform:translateY(-50%)}.team-name-background{x:-80px;y:-15px;width:160px;height:30px;rx:6px;fill:#2c3e50;stroke:#ffffff1a;stroke-width:1px}.team-name-text{dominant-baseline:central;text-anchor:middle;fill:#fff;font-size:16px;font-weight:600;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.team-connection-line{stroke:#95a5a6;stroke-width:1px;opacity:.3}.team-member-role-background.developer,.team-member-role-background.other,.team-member-name-background.developer,.team-member-name-background.other{fill:#1a1a1a}.team-name-background{fill:#1a1a1a!important}.efficiency-badge{font-size:10px!important;font-weight:500!important;padding:2px 6px;border-radius:3px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.efficiency-badge.low{background-color:#dc3545!important;color:#fff!important}.efficiency-badge.high{background-color:#28a745!important;color:#fff!important}.active-badge{background-color:#007bff!important;color:#fff!important;font-size:10px!important;font-weight:500!important;padding:2px 8px;border-radius:3px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.team-title-background{y:-15px;height:30px;rx:6px;fill:#2c3e50;stroke:#ffffff1a;stroke-width:1px}.team-title-text{dominant-baseline:central;text-anchor:middle;fill:#fff;font-size:16px;font-weight:600;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.role-background{x:-70px;y:-12px;width:140px;height:24px;rx:6px;stroke:#ffffff1a;stroke-width:1px}.role-text{dominant-baseline:central;text-anchor:middle;fill:#fff;font-size:14px;font-weight:600;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.name-background{x:-60px;y:-10px;width:120px;height:20px;rx:6px;stroke:#ffffff1a;stroke-width:1px}.name-background.developer{fill:#2c3e50}.name-background.other{fill:#34495e}.name-text{dominant-baseline:central;text-anchor:middle;fill:#fff;font-size:12px;font-weight:600;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.member-circle{fill:#f5f5f5;stroke:#1a1a1a;stroke-width:2px}.member-abbreviation{dominant-baseline:central;text-anchor:middle;fill:#666;font-size:16px;font-weight:700;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.team-connection{stroke:#95a5a6;stroke-width:1px;opacity:.3}.team-active{opacity:1}.team-inactive{opacity:.5}.role-background.developer{fill:#2c3e50}.role-background.other{fill:#34495e}.team-member-name-background.developer{fill:#2c3e50}.team-member-name-background.other{fill:#34495e}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;min-width:320px;min-height:100vh}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}}
