*,*: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:24px;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:8px;font-size:16px;font-weight:700;letter-spacing:.02em;white-space:nowrap}.kara-logo{font-size:22px}.main-layout{display:flex;flex:1;gap:8px;padding:8px;overflow:hidden;min-height:0}.left-panel{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.right-panel{flex:1;min-width:0;display:flex;flex-direction:column}.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:38px;height: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}.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}::-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}
