*{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:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}#root{max-width:1400px;margin:0 auto;padding:2rem}h1{color:#fff;text-align:center;margin-bottom:2rem;font-size:2.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.controls{background:#fff;padding:1.5rem;border-radius:10px;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem}.button-group{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:1rem}button{padding:.75rem 1.5rem;border:2px solid #667eea;background:#fff;color:#667eea;border-radius:5px;cursor:pointer;font-weight:600;transition:all .3s ease}button:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}button.active{background:#667eea;color:#fff}.chart-container{background:#fff;padding:2rem;border-radius:10px;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem}.loading{text-align:center;padding:3rem;color:#667eea;font-size:1.5rem}.error{background:#fee;border:2px solid #f88;padding:1rem;border-radius:5px;color:#c33;margin:1rem 0}select{padding:.5rem 1rem;border:2px solid #667eea;border-radius:5px;font-size:1rem;cursor:pointer;background:#fff}.diagram-info{margin-top:1rem;padding:1rem;background:#f5f5f5;border-radius:5px;font-size:.9rem;color:#666}.footer{background:#fff;border-top:2px solid #667eea;padding:2rem;border-radius:10px;box-shadow:0 4px 6px #0000001a;margin-top:2rem}.footer-content{text-align:center;color:#666}.footer-content p{margin:.5rem 0;font-size:.95rem}.footer-content a{color:#667eea;text-decoration:none;font-weight:600;transition:color .3s ease}.footer-content a:hover{color:#764ba2;text-decoration:underline}.heart{color:#e74c3c;animation:heartbeat 1.5s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}
