.grid-container{display:flex;flex-direction:column;gap:.5rem;max-width:1000px}.grid-canvas{border:2px solid #404040;border-radius:8px;background-color:#0a0a0a;box-shadow:0 4px 6px #0000004d;width:100%;max-width:1000px;height:auto}.grid-info{color:#6b7280;font-size:.85rem;padding:0 .5rem}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#fff;padding:1rem 2rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.app-header h1{font-size:1.5rem;color:#111827;font-weight:600;letter-spacing:-.025em;margin:0}.app-header p{color:#6b7280;font-size:.875rem;font-weight:400;margin:0}.app-main{flex:1;display:flex;gap:2rem;padding:2rem;max-width:1600px;margin:0 auto;width:100%}.grid-section{flex:1;display:flex;flex-direction:column;gap:1rem;max-width:1000px}.grid-section .controls-panel{width:100%}.app-sidebar{min-width:320px;display:flex;flex-direction:column;gap:1rem}.info-panel{background-color:#fff;border-radius:8px;padding:1.5rem;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a}.info-panel h2{font-size:1.125rem;margin-bottom:1rem;color:#111827;font-weight:600}.position-info{display:flex;align-items:center;gap:.75rem;padding:.75rem;background-color:#f9fafb;border-radius:6px;margin-bottom:.5rem;font-size:.875rem;border:1px solid #e5e7eb}.position-indicator{width:12px;height:12px;flex-shrink:0}.position-indicator.square{border-radius:2px}.position-indicator.circle{border-radius:50%}.position-info span:last-child{margin-left:auto;color:#6b7280;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.8125rem}.distance-section{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.distance-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.distance-section h3{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.distance-info{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;font-size:.8125rem;color:#6b7280}.distance-value{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-weight:600;color:#111827}.distance-value.highlight{color:#f97316;font-size:.875rem}.inter-tag-distance{background-color:#fff7ed;padding:.75rem;border-radius:6px;border:1px solid #fed7aa}.controls-panel{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bfdbfe}.controls-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.5rem;border-radius:6px}.controls-panel-header h2{margin:0;display:flex;align-items:center;gap:.5rem}.toggle-button{background:#3b82f6;border:none;font-size:.875rem;color:#fff;cursor:pointer;padding:.5rem .75rem;border-radius:6px;transition:all .3s;font-weight:600;display:flex;align-items:center;gap:.5rem}.toggle-button:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 2px 4px #3b82f64d}.toggle-button .arrow{transition:transform .3s}.toggle-button.collapsed .arrow{transform:rotate(180deg)}.controls-content{overflow:hidden;transition:max-height .3s ease-out,opacity .3s ease-out}.controls-content.collapsed{max-height:0;opacity:0}.controls-content.expanded{max-height:1000px;opacity:1}.control-group{margin-bottom:1rem}.control-group:last-of-type{margin-bottom:0}.control-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.mode-toggle{width:100%;padding:.75rem;font-size:1rem;font-weight:600;border:2px solid #3b82f6;border-radius:8px;background:#fff;color:#3b82f6;cursor:pointer;transition:all .2s}.mode-toggle:hover{background:#eff6ff}.mode-toggle.auto{background:#3b82f6;color:#fff}.button-group{display:flex;gap:.5rem}.control-button{flex:1;padding:.75rem 1rem;font-size:.875rem;font-weight:600;border:2px solid #e5e7eb;border-radius:8px;background:#fff;color:#374151;cursor:pointer;transition:all .2s}.control-button:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.control-button.primary{background:#10b981;color:#fff;border-color:#10b981}.control-button.primary:hover:not(:disabled){background:#059669}.control-button:disabled{opacity:.5;cursor:not-allowed}.speed-slider{width:100%;height:6px;border-radius:3px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(to right,#93c5fd,#3b82f6);cursor:pointer}.speed-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#3b82f6;cursor:pointer;border:3px solid #ffffff;box-shadow:0 2px 4px #0003}.speed-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#3b82f6;cursor:pointer;border:3px solid #ffffff;box-shadow:0 2px 4px #0003}.slider-labels{display:flex;justify-content:space-between;margin-top:.25rem}.slider-labels span{font-size:.75rem;color:#6b7280}.status-indicator{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fff;border-radius:6px;font-size:.875rem;color:#374151;margin-top:1rem}.status-dot{width:10px;height:10px;border-radius:50%;background:#9ca3af}.status-dot.running{background:#10b981;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.bubble-slider{width:100%;height:6px;border-radius:3px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(to right,#fbbf24,#f59e0b);cursor:pointer}.bubble-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#f59e0b;cursor:pointer;border:3px solid #ffffff;box-shadow:0 2px 4px #0003}.bubble-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#f59e0b;cursor:pointer;border:3px solid #ffffff;box-shadow:0 2px 4px #0003}.collision-indicator{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fff;border-radius:8px;font-size:.875rem;font-weight:600;margin-top:1rem;border:2px solid #10b981;transition:all .3s}.collision-indicator.collision{background:#fef2f2;border-color:#ef4444}.collision-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1.25rem;font-weight:700;background:#d1fae5;border:2px solid #10b981;color:#10b981}.collision-icon.warning{background:#fee2e2;border-color:#ef4444;color:#ef4444;font-size:1.5rem;animation:pulse-warning 1s infinite}.collision-indicator.safe span{color:#10b981}.collision-indicator.collision span{color:#ef4444}@keyframes pulse-warning{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.alarm-settings{border-top:1px solid #e5e7eb;padding-top:1rem;margin-top:.5rem}.alarm-settings-title{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.75rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;cursor:pointer;font-size:.875rem;color:#374151}.checkbox-input{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6}*{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-color:#f9fafb;color:#111827}#root{min-height:100vh}
