.turing-machine{background:#fff;border-radius:15px;padding:2rem;box-shadow:0 10px 20px #0000001a;width:90%;max-width:1200px;margin:0 auto}.info-panel{display:flex;justify-content:space-around;flex-wrap:wrap;gap:1rem;margin-top:1rem}.info-panel div{flex:1;min-width:120px;text-align:center}.tape-wrapper{position:relative;background:#fff;border-radius:10px;padding:.5rem;margin:1rem 0;overflow:hidden}.tape-container{display:flex;overflow-x:auto;padding:1rem;background:#fff;border-radius:10px;box-shadow:inset 0 2px 4px #0000001a;margin:1rem 0;scrollbar-width:thin;scrollbar-color:var(--primary-color) #f0f0f0;max-width:100%}.tape-container::-webkit-scrollbar{height:8px}.tape-container::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.tape-container::-webkit-scrollbar-thumb{background-color:var(--primary-color);border-radius:4px;border:2px solid #f0f0f0}.tape-container::-webkit-scrollbar-thumb:hover{background:var(--accent-color)}.tape-container:after{content:"";padding-right:calc(50% - 25px)}.tape-container:before{content:"";padding-left:calc(50% - 25px)}.tape-cell{min-width:50px;width:50px;height:50px;flex:0 0 auto;border:2px solid var(--primary-color);margin:0 4px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;background:#fff;border-radius:8px;transition:all .3s ease;box-shadow:0 2px 4px #0000001a}.tape-cell.active{background:var(--secondary-color);color:#fff;transform:scale(1.1);box-shadow:0 0 15px #3498db80;z-index:1}.controls{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.controls button{padding:.8rem 1.5rem;font-size:1rem;border:none;border-radius:8px;background:var(--primary-color);color:#fff;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.controls button:hover{background:var(--secondary-color);transform:translateY(-2px);box-shadow:0 5px 15px #0000001a}.controls button:active{transform:translateY(0)}.controls button.active{background:var(--accent-color)}.controls button:disabled{opacity:.5;cursor:not-allowed;background:var(--primary-color);transform:none;box-shadow:none}.controls button:disabled:hover{background:var(--primary-color);transform:none;box-shadow:none}.speed-button{background:var(--secondary-color)!important;min-width:120px}.speed-button:hover{background:var(--accent-color)!important}.lock-button{position:absolute;top:10px;right:10px;width:40px;height:40px;border-radius:50%;border:none;background:#fff;box-shadow:0 2px 8px #0000001a;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all .3s ease}.lock-button:hover{transform:scale(1.1);box-shadow:0 4px 12px #00000026}.lock-button.locked{background:var(--secondary-color);color:#fff}.lock-button.unlocked{background:var(--accent-color);color:#fff}.menu-button{position:fixed;top:1.5rem;left:1.5rem;padding:.5rem;border:none;border-radius:8px;background:var(--primary-color);color:#fff;font-size:1.5rem;cursor:pointer;transition:all .3s ease;z-index:999;display:flex;align-items:center;justify-content:center;width:45px;height:45px;box-shadow:0 2px 8px #0003}.menu-button:hover{background:var(--secondary-color);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.menu-button:active{transform:translateY(0)}.language-toggle{position:fixed;top:1.5rem;right:1.5rem;padding:.5rem 1rem;border:none;border-radius:4px;background:var(--primary-color);color:#fff;font-weight:700;cursor:pointer;transition:all .3s ease;z-index:999;min-width:80px;display:flex;align-items:center;justify-content:center;gap:.5rem}.language-toggle:hover{background:var(--secondary-color);transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.language-toggle:active{transform:translateY(0)}.language-toggle svg{border-radius:2px;box-shadow:0 1px 3px #0003}@media (max-width: 768px){.turing-machine{padding:1rem;width:95%;margin:1rem auto}.info-panel{flex-direction:column;gap:.5rem;margin-top:3.5rem;padding:0 .5rem}.info-panel div{width:100%;text-align:left;padding:0 .5rem}.tape-wrapper{margin:1.5rem 0;padding:0;width:100%;overflow:hidden;position:relative}.tape-container{padding:1.5rem 1rem;margin:0;width:100%;overflow-x:auto}.controls{flex-wrap:wrap;gap:.5rem}.controls button{flex:1;min-width:calc(50% - .5rem);padding:.6rem;font-size:.9rem}.tape-cell{min-width:40px;width:40px;height:40px;font-size:1.2rem}.menu-button{top:1rem;left:1rem;width:40px;height:40px;font-size:1.3rem}.language-toggle{top:1rem;right:1rem}.lock-button{top:8px;right:8px;width:35px;height:35px;font-size:1.1rem}}@media (max-width: 480px){.controls button{min-width:100%}}.visualization-controls{margin:1rem 0;display:flex;justify-content:center}.visualization-mode-select{padding:.5rem 1rem;border:2px solid var(--primary-color);border-radius:4px;background:#fff;font-size:1rem;cursor:pointer;transition:all .3s ease}.visualization-mode-select:hover{border-color:var(--secondary-color)}.tape-container.compact{justify-content:center}.tape-container.expanded{justify-content:flex-start}.tape-cell-container{display:flex;flex-direction:column;align-items:center;gap:.5rem}.cell-position{font-size:.8rem;color:var(--secondary-color);font-family:monospace}.compact .tape-cell{min-width:40px;width:40px;height:40px;font-size:1.2rem}.expanded .tape-cell{min-width:35px;width:35px;height:35px;font-size:1rem;margin:0 2px}@media (max-width: 768px){.expanded .tape-cell{min-width:30px;width:30px;height:30px;font-size:.9rem}.cell-position{font-size:.7rem}}.state-graph{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;padding:2rem;min-height:200px;background:#ecf0f180;border-radius:10px}.state-node{padding:1rem;border:2px solid var(--primary-color);border-radius:8px;background:#fff;min-width:150px;transition:all .3s ease;box-shadow:0 2px 4px #0000001a}.state-node.active{border-color:var(--secondary-color);box-shadow:0 0 15px #3498db4d;transform:scale(1.05)}.state-node.accept{border-color:#2ecc71}.state-label{font-weight:700;text-align:center;margin-bottom:.5rem;color:var(--primary-color)}.state-node.active .state-label{color:var(--secondary-color)}.transitions{display:flex;flex-direction:column;gap:.5rem}.transition{font-size:.9rem;padding:.3rem .6rem;background:#f8f9fa;border-radius:4px;transition:all .3s ease}.transition.active{background:#3498db1a;color:var(--secondary-color)}@media (max-width: 768px){.state-graph{padding:1rem;gap:1rem}.state-node{min-width:120px;padding:.8rem}.transition{font-size:.8rem;padding:.2rem .4rem}}.menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);overflow-y:auto;padding:2rem 0}.menu{background:#fff;padding:2rem;border-radius:15px;box-shadow:0 15px 30px #0003;width:90%;max-width:600px;margin:auto;max-height:90vh;overflow-y:auto}.menu::-webkit-scrollbar{width:8px}.menu::-webkit-scrollbar-track{background:transparent;border-radius:4px}.menu::-webkit-scrollbar-thumb{background:var(--secondary-color);border-radius:4px}.menu::-webkit-scrollbar-thumb:hover{background:var(--accent-color)}.menu{scrollbar-width:thin;scrollbar-color:var(--secondary-color) transparent}.config-editor{display:flex;flex-direction:column;gap:1.5rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-weight:700;color:var(--primary-color)}.input-group input{padding:.8rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s ease}.input-group input:focus{border-color:var(--secondary-color);outline:none;box-shadow:0 0 10px #3498db33}.buttons{display:flex;gap:1rem;margin-top:2rem}.menu button{padding:.8rem 1.5rem;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.menu button:first-child{background:var(--secondary-color);color:#fff}.menu button:not(:first-child){background:var(--primary-color);color:#fff}.menu button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0000001a}.menu button:active{transform:translateY(0)}.menu-buttons{display:flex;flex-direction:column;gap:1rem;width:100%}.menu-buttons button{width:100%;padding:1rem;font-size:1.1rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease}.menu-buttons button:hover{background:var(--secondary-color);transform:translateY(-2px);box-shadow:0 5px 15px #0000001a}.menu-buttons button:nth-child(3){background:var(--accent-color)}.transitions-editor{margin-top:2rem;padding:1rem;background:#f8f9fa;border-radius:8px}.transitions-editor h4{margin:0 0 1rem;color:var(--primary-color)}.add-transition{display:flex;gap:1rem;margin-bottom:1rem}.add-transition select{flex:1;padding:.5rem;border:2px solid #e0e0e0;border-radius:4px}.add-button{padding:.5rem 1rem;background:var(--secondary-color);color:#fff;border:none;border-radius:4px;cursor:pointer}.transitions-list{display:flex;flex-direction:column;gap:1rem}.transition-item{padding:1rem;background:#fff;border:1px solid #e0e0e0;border-radius:4px}.transition-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-weight:700}.remove-button{background:none;border:none;color:var(--accent-color);font-size:1.2rem;cursor:pointer;padding:0 .5rem}.transition-inputs{display:flex;gap:.5rem}.transition-inputs input,.transition-inputs select{flex:1;padding:.5rem;border:1px solid #e0e0e0;border-radius:4px}.presets-section{padding:1rem;border-bottom:1px solid #eee}.presets-section h4{margin:0 0 1rem;color:var(--primary-color)}.presets-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1rem}.preset-card{background:#f8f9fa;border:1px solid #eee;border-radius:8px;padding:1rem;transition:all .3s ease}.preset-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.preset-card h5{margin:0 0 .5rem;color:var(--secondary-color)}.preset-card p{margin:0 0 1rem;font-size:.9rem;color:#666}.preset-card button{width:100%;padding:.5rem;background:var(--secondary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease}.preset-card button:hover{background:var(--accent-color)}.menu-actions{padding:1rem;display:flex;flex-direction:column;gap:.5rem}@media (max-width: 768px){.menu{width:95%;padding:1rem;max-height:95vh}.input-group input{padding:.6rem;font-size:.9rem}.buttons{flex-direction:column}.buttons button{width:100%}.transitions-editor{padding:.8rem}.add-transition{flex-direction:column}.add-transition select,.add-button{width:100%}.transition-inputs{flex-direction:column}.presets-grid{grid-template-columns:1fr}}.tm-graph{background:#fff;border-radius:15px;padding:2rem;box-shadow:0 10px 20px #0000001a;width:90%;max-width:800px;margin:1rem auto;overflow:hidden}.tm-graph h3{color:var(--primary-color);margin-bottom:2rem;text-align:center}.state-diagram{width:100%;height:auto;max-height:500px;overflow:visible;padding:0;margin-top:1rem}.node-circle{transition:all .3s ease}.state-node:hover .node-circle{filter:drop-shadow(0 0 5px rgba(0,0,0,.2))}.node-circle.accept{stroke:#2ecc71}.accept-inner{fill:none;stroke:#2ecc71;stroke-width:2}.start-arrow{stroke:var(--primary-color);stroke-width:2;fill:none}.node-label{text-anchor:middle;dominant-baseline:middle;font-weight:700;font-size:14px;fill:var(--primary-color)}.transition-arrow path{stroke-dasharray:none}.transition-label{text-anchor:middle;dominant-baseline:middle;font-size:12px;fill:#666;font-family:monospace}.graph-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;padding:1rem}.graph-node{border:2px solid var(--primary-color);border-radius:8px;padding:1rem;background:#fff;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.graph-node:hover{transform:translateY(-5px);box-shadow:0 5px 15px #00000026}.graph-node.accept{border-color:#2ecc71}.node-transitions{display:flex;flex-direction:column;gap:.8rem}.transition-info{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#f8f9fa;border-radius:4px;font-family:monospace}.transition-arrow{color:var(--secondary-color);font-weight:700}.transition-details{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.symbol{color:#e74c3c;font-weight:700}.write{color:#2ecc71;font-weight:700}.move{color:#3498db;font-weight:700}.next-state{color:#9b59b6;font-weight:700}.separator{color:#95a5a6}.graph-legend{margin-top:2rem;padding-top:1rem;border-top:1px solid #eee;display:flex;justify-content:center;gap:2rem}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-symbol{width:20px;height:20px;border-radius:4px;border:2px solid}.legend-symbol.normal-state{border-color:var(--primary-color)}.legend-symbol.accept-state{border-color:#2ecc71}@media (max-width: 768px){.tm-graph{padding:1rem;margin:1rem auto}.state-diagram{max-height:400px}.transition-label{font-size:10px}}.notification{position:fixed;top:20px;left:50%;transform:translate(-50%);padding:1rem 2rem;border-radius:8px;background:#fff;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:1rem;z-index:1000;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(-50%,-100%);opacity:0}to{transform:translate(-50%);opacity:1}}.notification.success{border-left:4px solid #2ecc71}.notification.error{border-left:4px solid #e74c3c}.notification.info{border-left:4px solid #3498db}.notification-content{display:flex;align-items:center;gap:1rem}.notification-icon{font-size:1.2rem}.notification.success .notification-icon{color:#2ecc71}.notification.error .notification-icon{color:#e74c3c}.notification.info .notification-icon{color:#3498db}.notification-message{color:#2c3e50;font-weight:500}.notification-close{background:none;border:none;color:#95a5a6;font-size:1.5rem;cursor:pointer;padding:0 .5rem;transition:color .3s ease}.notification-close:hover{color:#2c3e50}.configuration-history{position:relative;width:90%;max-width:1200px;margin:2rem auto;background:#fff;border-radius:10px;box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;max-height:500px}.history-header{padding:1rem;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:10px 10px 0 0;position:sticky;top:0;z-index:1}.history-header h3{margin:0;color:var(--primary-color)}.save-button{padding:.5rem 1rem;background:var(--secondary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .3s ease}.save-button:hover{background:var(--accent-color);transform:translateY(-2px)}.history-content{flex:1;overflow-y:auto;padding:1rem;scrollbar-width:thin;scrollbar-color:var(--secondary-color) transparent}.history-content::-webkit-scrollbar{width:8px}.history-content::-webkit-scrollbar-track{background:transparent;border-radius:4px}.history-content::-webkit-scrollbar-thumb{background:var(--secondary-color);border-radius:4px}.history-content::-webkit-scrollbar-thumb:hover{background:var(--accent-color)}.history-item{position:relative;padding:1rem;border:1px solid #eee;border-radius:8px;margin-bottom:1rem;background:#f8f9fa;transition:all .3s ease}.history-item:hover{transform:translate(-5px);box-shadow:2px 2px 8px #0000001a}.history-step{font-weight:700;color:var(--secondary-color);margin-bottom:.5rem}.history-state{margin-bottom:.5rem}.history-tape{font-family:monospace;overflow-x:auto;white-space:nowrap;padding:.5rem;background:#fff;border-radius:4px}.history-details{margin-top:.5rem;padding:.5rem;background:#3498db1a;border-radius:4px;font-size:.9rem}.history-details>div{margin:.25rem 0}.accept-state{border-left:4px solid #2ecc71}.accept-badge{margin-left:.5rem;padding:.2rem .5rem;background:#2ecc71;color:#fff;border-radius:4px;font-size:.8rem;font-weight:700}.error-state{border-left:4px solid #e74c3c}.error-badge{margin-left:.5rem;padding:.2rem .5rem;background:#e74c3c;color:#fff;border-radius:4px;font-size:.8rem;font-weight:700}.history-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.restore-button{padding:.3rem .8rem;background:var(--secondary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.restore-button:hover{background:var(--accent-color);transform:translateY(-1px)}.restore-button:active{transform:translateY(0)}.history-filters{padding:1rem;display:flex;gap:1rem;background:#fff;border-bottom:1px solid #eee;position:sticky;top:0;z-index:1}.history-filters input{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.history-filters input:focus{border-color:var(--secondary-color);outline:none;box-shadow:0 0 0 2px #3498db33}.clear-filters{padding:.5rem 1rem;background:var(--accent-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1.2rem;transition:all .3s ease}.clear-filters:hover{background:#e74c3c;transform:translateY(-1px)}.history-explanation{margin:.8rem 0;padding:.8rem;background:#3498db0d;border-left:3px solid var(--secondary-color);border-radius:0 4px 4px 0;font-size:.95rem;line-height:1.4;color:#2c3e50}.accept-state .history-explanation{background:#2ecc710d;border-left-color:#2ecc71}.error-state .history-explanation{background:#e74c3c0d;border-left-color:#e74c3c}@media (max-width: 768px){.configuration-history{width:95%;margin:1rem auto}.history-item{padding:.8rem}.history-header-row{flex-direction:column;align-items:flex-start;gap:.5rem}.restore-button{width:100%}.history-tape{font-size:.9rem}.history-details{font-size:.8rem}.history-filters{flex-direction:column;padding:.8rem}.history-explanation{font-size:.9rem;padding:.6rem;margin:.6rem 0}}:root{--primary-color: #2c3e50;--secondary-color: #3498db;--accent-color: #e74c3c;--background-color: #ecf0f1;--text-color: #2c3e50}body{margin:0;padding:0;background-color:var(--background-color);font-family:Roboto,sans-serif}.app{min-height:100vh;padding:2rem;display:flex;flex-direction:column;gap:2rem;background:#f5f6fa}h1{color:var(--primary-color);font-size:2.5rem;margin-bottom:2rem;text-transform:uppercase;letter-spacing:2px;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.bottom-section{display:flex;flex-direction:column;gap:2rem}@media (max-width: 768px){.app{padding:1rem}}
