:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1d2a2a;background:#d9e7e1;font-synthesis:none;text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}button,input,select{font:inherit}button{border:1px solid rgba(31,45,43,.16);border-radius:8px;background:#f7f4eb;color:#1d2a2a;cursor:pointer;transition:background .16s ease,border-color .16s ease,transform .16s ease}button:hover:not(:disabled){border-color:#1f2d2b5c;transform:translateY(-1px)}button:disabled{cursor:not-allowed;opacity:.45}.app-shell{display:grid;grid-template-columns:minmax(280px,340px) 1fr;width:100vw;height:100vh}.side-panel{position:relative;z-index:5;display:flex;flex-direction:column;gap:18px;overflow-y:auto;border-right:1px solid rgba(31,45,43,.14);background:#f7f4ebf0;padding:22px;box-shadow:12px 0 32px #212b2c1f}.brand-row{display:flex;align-items:center;gap:12px;padding-bottom:6px}.brand-row svg{color:#d4513f}h1,h2,p{margin:0}h1{font-size:19px;font-weight:780;letter-spacing:0}.brand-row p,.hint,.empty-state,.vessel-row small,.status-strip span,.timeline-header span{color:#61706b}.brand-row p{margin-top:2px;font-size:12px}.control-group{display:flex;flex:0 0 auto;flex-direction:column;gap:10px}.control-group h2{font-size:13px;font-weight:760}.segmented-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.segmented-grid button,.mode-toggle button,.control-group>button,.file-actions button,.speed-buttons button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:38px;padding:8px 10px;white-space:nowrap}button.selected{border-color:#d4513f8c;background:#f1d3b4}.mode-toggle,.file-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.hint,.empty-state{font-size:12px;line-height:1.55}.field-control{width:100%;min-height:38px;border:1px solid rgba(31,45,43,.16);border-radius:8px;background:#fffdf7;color:#1d2a2a;padding:8px 10px}.vessel-settings{display:flex;flex-direction:column;gap:10px}.vessel-settings label{display:flex;flex-direction:column;gap:5px;color:#61706b;font-size:12px}.number-field{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px}.number-field span{color:#61706b;font-size:12px}.stepper-row{display:grid;grid-template-columns:42px 1fr 42px;align-items:center;gap:8px}.stepper-row button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0}.stepper-row strong{display:flex;align-items:center;justify-content:center;min-height:38px;border:1px solid rgba(31,45,43,.12);border-radius:8px;background:#fffdf7;color:#1d2a2a}.danger-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:38px;border-color:#ab352952;background:#f8dfd9;color:#7c271f}.vessel-list{min-height:auto}.vessel-row{display:grid;grid-template-columns:14px 1fr;gap:10px;width:100%;min-height:52px;padding:10px;text-align:left}.vessel-row span:last-child{display:flex;min-width:0;flex-direction:column;gap:3px}.vessel-row strong,.vessel-row small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vessel-swatch{width:12px;height:12px;margin-top:5px;border-radius:50%;box-shadow:0 0 0 2px #ffffffb8}.file-input{display:none}.scene-shell{position:relative;min-width:0;min-height:0}.scene-shell canvas{display:block;cursor:crosshair}.scene-shell.is-pan-mode canvas{cursor:grab}.status-strip,.warning-panel,.timeline-panel{position:absolute;z-index:3;border:1px solid rgba(31,45,43,.16);border-radius:8px;background:#f7f4ebeb;box-shadow:0 16px 42px #212b2c24;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.status-strip{top:18px;right:18px;display:grid;grid-template-columns:repeat(5,auto);align-items:center;gap:16px;padding:12px 14px;font-size:12px}.status-strip div,.status-strip label{display:flex;flex-direction:column;gap:4px}.status-strip label{color:#61706b}.status-strip input{width:110px;accent-color:#d4513f}.warning-panel{top:88px;right:18px;display:flex;max-width:min(360px,calc(100vw - 380px));gap:10px;padding:12px;color:#4a271e;background:#ffe1bef5}.warning-panel svg{flex:0 0 auto;color:#d4513f}.warning-panel div{display:flex;flex-direction:column;gap:4px;font-size:13px}.timeline-panel{right:18px;bottom:18px;left:18px;display:grid;grid-template-columns:54px 1fr auto;align-items:center;gap:14px;padding:14px}.play-button{width:48px;height:48px;padding:0;color:#f7f4eb;background:#d4513f}.timeline-main{display:flex;min-width:0;flex-direction:column;gap:8px}.timeline-header{display:flex;justify-content:space-between;gap:18px;font-size:13px}.timeline-header span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.timeline-main input{width:100%;accent-color:#d4513f}.speed-buttons{display:grid;grid-template-columns:repeat(5,48px);gap:7px}.speed-buttons button{min-height:34px;padding:6px}@media(max-width:920px){body{overflow:auto}.app-shell{grid-template-columns:1fr;grid-template-rows:auto minmax(620px,1fr);height:auto;min-height:100vh}.side-panel{max-height:none;border-right:0;border-bottom:1px solid rgba(31,45,43,.14)}.scene-shell{min-height:620px}.status-strip{left:14px;right:14px;grid-template-columns:repeat(2,minmax(0,1fr))}.status-strip div:first-child{grid-column:1 / -1}.warning-panel{top:148px;right:14px;left:14px;max-width:none}.timeline-panel{left:14px;right:14px;grid-template-columns:48px 1fr}.speed-buttons{grid-column:1 / -1;grid-template-columns:repeat(5,1fr)}}
