*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:13px;background:#f1f5f9;color:#1e293b}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{display:flex;align-items:center;gap:16px;padding:6px 16px;background:#1e293b;color:#f8fafc;flex-shrink:0;box-shadow:0 2px 8px #00000040;flex-wrap:wrap}.app-title{display:flex;align-items:center;gap:10px;flex-shrink:0}.kara-logo{font-size:24px}.app-title-text{display:flex;flex-direction:column;gap:1px}.app-name{font-size:17px;font-weight:800;letter-spacing:.02em;color:#f8fafc}.app-subtitle{font-size:10px;color:#94a3b8;white-space:nowrap}.subtitle-link{color:#93c5fd;text-decoration:underline;text-underline-offset:2px}.subtitle-link:hover{color:#bfdbfe}.header-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap;flex:1}.header-btn{padding:4px 10px;border:1px solid #475569;border-radius:6px;background:transparent;color:#cbd5e1;cursor:pointer;font-size:12px;transition:background .12s,color .12s;white-space:nowrap}.header-btn:hover{background:#334155;color:#f8fafc}.header-btn:disabled{opacity:.4;cursor:not-allowed}.header-btn.about-btn{color:#93c5fd;border-color:#3b5068}.header-btn.about-btn:hover{background:#1d3a5a;color:#bfdbfe}.header-sep{width:1px;height:28px;background:#334155;flex-shrink:0}.load-error-banner{background:#fef2f2;border-bottom:1px solid #fca5a5;color:#b91c1c;padding:6px 16px;font-size:12px;display:flex;align-items:center;gap:12px;flex-shrink:0}.load-error-banner button{margin-left:auto;background:none;border:none;cursor:pointer;color:#b91c1c;font-size:14px;padding:0 4px}.main-layout{display:flex;flex:1;gap:0;padding:8px;overflow:hidden;min-height:0}.left-panel{display:flex;flex-direction:column;gap:8px;flex-shrink:0;overflow:hidden;max-height:100%}.left-world-section{flex-shrink:0;display:flex;flex-direction:column;gap:8px}.hsplit-handle{width:8px;flex-shrink:0;cursor:col-resize;display:flex;align-items:center;justify-content:center;margin:0 1px;border-radius:4px;transition:background .12s;position:relative}.hsplit-handle:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:3px;height:40px;border-radius:2px;background:#cbd5e1}.hsplit-handle:hover{background:#e2e8f0}.hsplit-handle:hover:after{background:#64748b}.hsplit-handle:active{background:#dbeafe}.right-panel{flex:1;min-width:200px;display:flex;flex-direction:column;margin-left:8px}.bottom-panel{flex-shrink:0;margin:0 8px 8px;max-height:180px;overflow:hidden;display:flex;flex-direction:column}.panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:8px}.panel-title{font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#64748b;margin-bottom:6px;display:flex;align-items:center;gap:8px}.log-count{background:#e2e8f0;color:#475569;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:600}.tool-btn{padding:4px 10px;border:1px solid #cbd5e1;border-radius:6px;background:#f8fafc;cursor:pointer;font-size:12px;transition:background .12s,border-color .12s;white-space:nowrap}.tool-btn:hover{background:#e2e8f0}.tool-btn.active{background:#2563eb;color:#fff;border-color:#1d4ed8}.tool-btn.danger:hover{background:#fee2e2;border-color:#f87171;color:#b91c1c}.tool-btn:disabled{opacity:.45;cursor:not-allowed}.toolbar-sep{width:1px;background:#e2e8f0;margin:0 4px;align-self:stretch}.world-editor{display:flex;flex-direction:column;gap:6px}.world-toolbar{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.world-grid{display:grid;gap:1px;background:#94a3b8;border:2px solid #64748b;border-radius:4px;overflow:hidden;cursor:crosshair;flex-shrink:0}.world-cell{width:var(--cell-size, 38px);height:var(--cell-size, 38px);background:#f8fafc;position:relative;display:flex;align-items:center;justify-content:center;transition:background .1s}.world-cell:hover{outline:2px solid #60a5fa;z-index:1}.world-cell.has-leaf{background:#f0fdf4}.world-cell.sensor-kara{box-shadow:inset 0 0 0 2px #16a34a}.world-cell.sensor-front{box-shadow:inset 0 0 0 2px #f59e0b}.world-cell.sensor-left{box-shadow:inset 0 0 0 2px #a78bfa}.world-cell.sensor-right{box-shadow:inset 0 0 0 2px #38bdf8}.kara-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:2}.leaf-under-kara{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:1;opacity:.5}.world-size-row{display:flex;gap:12px;align-items:center}.world-size-row label{display:flex;align-items:center;gap:6px;font-size:12px}.world-size-row input[type=number]{width:52px;padding:2px 4px;border:1px solid #cbd5e1;border-radius:4px;font-size:12px}.zoom-control{display:flex;align-items:center;gap:2px}.zoom-btn{padding:3px 8px;font-size:15px;font-weight:700;line-height:1}.zoom-label{font-size:11px;color:#64748b;min-width:36px;text-align:center}.sensor-display{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:8px}.sensor-grid{display:flex;gap:6px;flex-wrap:wrap}.sensor-chip{display:flex;flex-direction:column;align-items:center;gap:2px;padding:5px 8px;border-radius:6px;border:1px solid #e2e8f0;background:#f8fafc;min-width:48px;transition:background .15s,border-color .15s}.sensor-chip.on{background:#dcfce7;border-color:#4ade80}.sensor-chip.off{background:#f8fafc;border-color:#e2e8f0}.sensor-icon{font-size:14px}.sensor-abbr{font-size:9px;font-weight:700;color:#64748b;letter-spacing:.05em}.sensor-val{font-size:11px;font-weight:700}.sensor-val.true{color:#16a34a}.sensor-val.false{color:#94a3b8}.fsm-editor{flex:1;display:flex;flex-direction:column;min-height:0}.fsm-toolbar{display:flex;flex-wrap:wrap;gap:4px;align-items:center;margin-bottom:6px}.fsm-hint{font-size:11px;color:#64748b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;padding:4px 8px;margin-bottom:6px}.fsm-canvas{flex:1;min-height:300px;border:1px solid #e2e8f0;border-radius:6px;background:radial-gradient(circle,#cbd5e1 1px,transparent 1px),#f8fafc;background-size:30px 30px;width:100%;cursor:default}.fsm-sim-status{margin-top:6px;font-size:12px;color:#16a34a;padding:4px 8px;background:#f0fdf4;border:1px solid #86efac;border-radius:6px}.sim-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.sim-buttons{display:flex;gap:6px}.sim-btn{padding:5px 14px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:opacity .12s,transform .08s}.sim-btn:active{transform:scale(.96)}.sim-btn.run{background:#22c55e;color:#fff}.sim-btn.pause{background:#f59e0b;color:#fff}.sim-btn.step{background:#3b82f6;color:#fff}.sim-btn.reset{background:#64748b;color:#fff}.sim-btn:hover{opacity:.88}.sim-speed{display:flex;align-items:center;gap:6px;color:#cbd5e1;font-size:12px}.sim-speed label{display:flex;align-items:center;gap:6px;white-space:nowrap}.sim-speed input[type=range]{width:100px;accent-color:#60a5fa}.sim-speed span{min-width:52px;color:#94a3b8}.sim-info{display:flex;gap:14px;font-size:12px;color:#94a3b8}.sim-info strong{color:#f8fafc}.sim-error{background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c;border-radius:6px;padding:4px 10px;font-size:12px;max-width:400px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.exec-log{overflow-y:auto;flex:1;font-family:Courier New,Courier,monospace;font-size:11px}.exec-log.empty{color:#94a3b8;padding:8px;font-style:italic;font-family:inherit}.exec-log-header{display:grid;grid-template-columns:40px 120px 80px 1fr;gap:8px;padding:3px 6px;background:#f1f5f9;border-bottom:1px solid #e2e8f0;font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-family:inherit;position:sticky;top:0}.exec-row{display:grid;grid-template-columns:40px 120px 80px 1fr;gap:8px;padding:2px 6px;border-bottom:1px solid #f1f5f9;align-items:center}.exec-row:first-of-type{background:#fffbeb}.exec-step{color:#94a3b8;font-size:10px}.exec-states{color:#1e293b}.exec-sensors{display:flex;gap:3px}.sensor-bit{display:inline-block;width:12px;text-align:center;border-radius:2px;padding:0 1px}.sensor-bit.on{background:#dcfce7;color:#16a34a;font-weight:700}.sensor-bit.off{background:#f1f5f9;color:#94a3b8}.exec-action{color:#2563eb;font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:#fff;border-radius:12px;padding:24px;min-width:360px;max-width:480px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;gap:14px}.modal h3{font-size:16px;font-weight:700;color:#1e293b}.rename-input{width:100%;padding:8px 12px;border:1.5px solid #3b82f6;border-radius:6px;font-size:14px;outline:none}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.transition-modal{max-width:500px}.transition-route{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.state-chip{background:#2563eb;color:#fff;padding:3px 12px;border-radius:16px;font-weight:700;font-size:13px}.route-arrow{font-size:20px;color:#64748b}.section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.guard-table{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.guard-header{display:grid;grid-template-columns:1fr 80px;gap:8px;padding:6px 12px;background:#f1f5f9;font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.guard-row{display:grid;grid-template-columns:1fr 80px 60px;gap:8px;align-items:center;padding:7px 12px;border-top:1px solid #f1f5f9}.guard-row label{font-size:12px;cursor:help}.guard-toggle{padding:4px 12px;border-radius:6px;border:1.5px solid #cbd5e1;font-size:14px;font-weight:700;cursor:pointer;transition:all .12s}.guard-toggle.dc{background:#f8fafc;color:#94a3b8}.guard-toggle.yes{background:#dcfce7;border-color:#4ade80;color:#15803d}.guard-toggle.no{background:#fee2e2;border-color:#f87171;color:#b91c1c}.guard-current-val{font-size:11px;color:#64748b;font-family:monospace}.guard-hint{font-size:11px;color:#64748b;padding:6px 10px;background:#fffbeb;border:1px solid #fde68a;border-radius:6px}.action-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.action-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 6px;border:1.5px solid #e2e8f0;border-radius:8px;background:#f8fafc;cursor:pointer;transition:all .12s;font-size:11px}.action-btn:hover{border-color:#93c5fd;background:#eff6ff}.action-btn.selected{border-color:#2563eb;background:#eff6ff;color:#1d4ed8;font-weight:600}.action-icon{font-size:18px}.btn-primary{padding:7px 20px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-weight:600;font-size:13px;cursor:pointer}.btn-primary:hover{background:#1d4ed8}.btn-secondary{padding:7px 20px;background:#f1f5f9;color:#475569;border:1px solid #cbd5e1;border-radius:6px;font-weight:600;font-size:13px;cursor:pointer}.btn-secondary:hover{background:#e2e8f0}.about-modal{max-width:560px;width:100%;gap:16px}.about-header{display:flex;align-items:flex-start;gap:14px}.about-logo{font-size:36px;flex-shrink:0}.about-title{font-size:22px;font-weight:800;color:#1e293b;margin-bottom:4px}.about-subtitle{font-size:12px;color:#64748b;line-height:1.4}.about-subtitle a{color:#2563eb;text-decoration:underline;text-underline-offset:2px}.about-divider{border:none;border-top:1px solid #e2e8f0}.about-section h3{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin-bottom:8px}.about-section p{font-size:13px;line-height:1.6;color:#334155;margin-bottom:8px}.about-section p:last-child{margin-bottom:0}.about-section a{color:#2563eb;text-decoration:underline;text-underline-offset:2px}.licence-badge{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;margin-bottom:10px}.licence-link{font-size:13px;font-weight:700;color:#15803d;background:#dcfce7;padding:3px 10px;border-radius:12px;text-decoration:none;white-space:nowrap;border:1px solid #4ade80}.licence-link:hover{background:#bbf7d0}.licence-name{font-size:11px;color:#166534;line-height:1.4}.save-dialog{max-width:380px}.save-hint{font-size:12px;color:#64748b}.save-hint code{background:#f1f5f9;padding:1px 4px;border-radius:3px;font-family:monospace}.save-label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:600;color:#475569}.save-preview{font-size:11px;color:#64748b}.save-preview strong{color:#1e293b;font-family:monospace}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.examples-select{padding:4px 10px;border:1px solid #475569;border-radius:6px;background:transparent;color:#cbd5e1;cursor:pointer;font-size:12px;font-family:inherit;outline:none;white-space:nowrap;transition:background .12s,color .12s}.examples-select:hover{background:#334155;color:#f8fafc}.examples-select:disabled{opacity:.4;cursor:not-allowed}.examples-select option{background:#1e293b;color:#f8fafc}.notes-panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;overflow:hidden;flex:1;min-height:80px}.notes-header{display:flex;align-items:center;justify-content:space-between;padding:5px 10px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.notes-title{font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.notes-close{background:none;border:none;cursor:pointer;color:#94a3b8;font-size:13px;padding:1px 4px;line-height:1;border-radius:4px;transition:background .1s,color .1s}.notes-close:hover{background:#f1f5f9;color:#475569}.notes-body{overflow-y:auto;flex:1;padding:10px 14px}.notes-body h1{font-size:15px;font-weight:800;color:#1e293b;margin-bottom:8px;margin-top:2px}.notes-body h2{font-size:12px;font-weight:700;color:#1e293b;margin-bottom:5px;margin-top:14px;padding-top:10px;border-top:1px solid #f1f5f9}.notes-body h2:first-child{margin-top:0;padding-top:0;border-top:none}.notes-body h3{font-size:11px;font-weight:700;color:#475569;margin-bottom:4px;margin-top:10px}.notes-body p{font-size:12px;line-height:1.65;color:#334155;margin-bottom:7px}.notes-body ul{padding-left:16px;margin-bottom:7px}.notes-body li{font-size:12px;line-height:1.65;color:#334155;margin-bottom:3px}.notes-body hr{border:none;border-top:1px solid #e2e8f0;margin:10px 0}.notes-body strong{font-weight:700;color:#1e293b}.notes-body em{font-style:italic}.panel-close-btn{margin-left:auto;background:none;border:none;cursor:pointer;color:#94a3b8;font-size:12px;padding:1px 4px;line-height:1;border-radius:4px;transition:background .1s,color .1s}.panel-close-btn:hover{background:#f1f5f9;color:#475569}.panels-menu-wrap{position:relative}.panels-menu{position:absolute;top:calc(100% + 4px);left:0;background:#1e293b;border:1px solid #334155;border-radius:8px;padding:4px;display:flex;flex-direction:column;gap:2px;z-index:200;min-width:130px;box-shadow:0 8px 24px #00000059}.panels-menu-item{display:flex;align-items:center;gap:7px;padding:6px 10px;border:none;border-radius:5px;background:transparent;color:#cbd5e1;font-size:12px;font-family:inherit;cursor:pointer;text-align:left;white-space:nowrap;transition:background .1s,color .1s}.panels-menu-item:hover{background:#334155;color:#f8fafc}.panels-menu-item.checked{color:#93c5fd}.fsm-error-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c;border-radius:6px;padding:6px 10px;font-size:12px;margin-bottom:6px;flex-shrink:0}.fsm-error-banner button{background:none;border:none;cursor:pointer;color:#b91c1c;font-size:14px;padding:0 2px;line-height:1;flex-shrink:0}.fsm-error-banner button:hover{color:#7f1d1d}
