:root{--bg: #0b0f14;--panel: #121822;--panel-2: #0e141d;--text: #e9f0f7;--muted: #9fb2c7;--accent: #4bb3fd;--accent-2: #7bde8a;--warn: #ff8c69;--err: #ff5d6c;--grid: #1b2431;--grid-strong: #1f2b3c;--shadow: 0 8px 30px rgba(0,0,0,.35);--radius: 16px;--focus: 2px solid var(--accent);color-scheme:dark}:root[data-theme=light]{--bg: #f5f7fa;--panel: #ffffff;--panel-2: #f2f5f9;--text: #1b2735;--muted: #5a6b7c;--accent: #0d84d9;--accent-2: #2d9d52;--warn: #d95e1d;--err: #d92b3a;--grid: #dbe3ec;--grid-strong: #c8d3df;--shadow: 0 4px 18px rgba(0,0,0,.15);color-scheme:light}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:linear-gradient(180deg,var(--bg) 0%,#0c121b 100%);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Noto Sans JP,Arial,"Apple Color Emoji","Segoe UI Emoji";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:grid;grid-template-columns:320px 1fr;height:100%}.sidebar{background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border-right:1px solid #1d2735;padding:14px;gap:12px;display:grid;grid-auto-rows:min-content;overflow:auto}@media (min-width: 901px){.app:not(.side-open){grid-template-columns:0 1fr}.app:not(.side-open) .sidebar{visibility:hidden;pointer-events:none;overflow:hidden}}h1{font-size:18px;margin:8px 0 4px;letter-spacing:.2px}h2{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em;margin:18px 0 6px}.btn{background:#152030;color:var(--text);border:1px solid #233044;padding:10px 12px;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;box-shadow:var(--shadow);font-size:13px;line-height:1;position:relative}.btn:hover{background:#18263a}.btn:active{translate:0 1px}.btn:focus-visible{outline:var(--focus);outline-offset:2px}.btn.small{padding:6px 8px;border-radius:8px;box-shadow:none;font-size:12px}.btn[disabled]{opacity:.5;cursor:not-allowed}:root[data-theme=light] .btn{background:#e7eef5;border-color:#c2d2e0;color:#1b2735;box-shadow:var(--shadow)}:root[data-theme=light] .btn:hover{background:#dde6ee}:root[data-theme=light] .btn.danger{color:#fff}:root[data-theme=light] .btn.ok{color:#022}.seg{display:flex;gap:6px;flex-wrap:wrap}.seg .btn.tog{opacity:.85}.seg .btn.tog.active{outline:2px solid var(--accent);opacity:1}.panel{background:#0f1621;border:1px solid #1a2636;border-radius:var(--radius);padding:12px;box-shadow:var(--shadow);max-width:100%;overflow:hidden}:root[data-theme=light] .panel{background:#fff;border-color:#d6e0ea}.row{display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:center}.row-3{display:grid;grid-template-columns:auto 1fr 1fr;gap:8px;align-items:center}.row>*,.row-3>*{min-width:0}label{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}input[type=number],input[type=text],input[type=range],select{width:100%;max-width:100%;padding:8px 10px;background:#0c121b;border:1px solid #223049;color:var(--text);border-radius:8px;box-sizing:border-box;font-size:13px}:root[data-theme=light] input[type=number],:root[data-theme=light] input[type=text],:root[data-theme=light] input[type=range],:root[data-theme=light] select{background:#f2f6fa;border-color:#c9d6e3;color:#1b2735}input:focus-visible{outline:var(--focus);outline-offset:2px}input[type=checkbox]{transform:scale(1.1);cursor:pointer}button,input,select{touch-action:manipulation}.canvas-wrap{position:relative}.topbar{position:absolute;top:10px;left:10px;z-index:10;display:flex;gap:8px;align-items:center;padding-top:env(safe-area-inset-top,0)}.topbar{right:10px;justify-content:space-between;left:10px}.topbar .left-group{display:flex;gap:8px;align-items:center}.topbar .center-group,.topbar .right-group{display:flex;gap:6px;align-items:center}.topbar .modes{max-width:420px}.tag{background:#101827;border:1px solid #253145;color:var(--muted);padding:4px 8px;border-radius:999px;font-size:12px;font-weight:500;letter-spacing:.5px}:root[data-theme=light] .tag{background:#edf3f8;border-color:#d1dde8;color:#4c5d6f}.menu-btn{display:inline-flex;background:#101827;border:1px solid #253145;color:var(--text);padding:6px 10px;border-radius:8px;cursor:pointer}.menu-btn:hover{background:#18263a}:root[data-theme=light] .menu-btn{background:#e7eef5;border-color:#c2d2e0;color:#1b2735}:root[data-theme=light] .menu-btn:hover{background:#dde6ee}.danger{color:#fff;background:linear-gradient(180deg,#ff5d6c 0,#e44868);border:none}.ok{color:#022;background:linear-gradient(180deg,#84f3a9 0,#61d48c);border:none}.footer{font-size:12px;color:var(--muted);opacity:.9}.kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;background:#0b1320;border:1px solid #24324b;padding:2px 6px;border-radius:6px;font-size:11px}:root[data-theme=light] .kbd{background:#eef2f7;border-color:#ccd7e2;color:#456}canvas{background:#0a0f16;display:block;width:100%;height:100%;touch-action:none}:root[data-theme=light] canvas{background:#f8fafc}.canvas-host{position:relative;height:100%}.overlay-msg{position:absolute;left:50%;top:66px;transform:translate(-50%);padding:8px 12px;background:#132033cc;border:1px solid #20304a;border-radius:10px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-size:13px;z-index:12;pointer-events:none}:root[data-theme=light] .overlay-msg{background:#ffffffd0;border-color:#c7d6e3}.legend{font-size:12px;color:var(--muted);line-height:1.4}.link{color:var(--accent);text-decoration:none}.floating-panel{position:absolute;right:12px;top:64px;z-index:20;min-width:280px;max-width:min(420px,90vw);background:#0f1621ee;border:1px solid #1a2636;border-radius:var(--radius);padding:12px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);overflow:auto;max-height:calc(100% - 80px)}:root[data-theme=light] .floating-panel{background:#fffe;border-color:#d6e0ea}.floating-panel .title{display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:600;margin:2px 0 8px}.icon-btn{background:transparent;color:var(--muted);border:1px solid #253145;border-radius:8px;padding:4px 8px;cursor:pointer;font-size:12px}.icon-btn:hover{background:#18263a;color:#fff}.icon-btn:focus-visible{outline:var(--focus);outline-offset:2px}.icon-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}:root[data-theme=light] .icon-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}:root[data-theme=light] .icon-btn{border-color:#c2d2e0;color:#5a6b7c}:root[data-theme=light] .icon-btn:hover{background:#e0e8f1;color:#1b2735}.topbar .edit-tools{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.topbar .edit-tools input[type=number]{width:70px;padding:4px 6px;font-size:12px;background:#0c121b;border:1px solid #223049;color:var(--text);border-radius:6px}:root[data-theme=light] .topbar .edit-tools input[type=number]{background:#f2f6fa;border-color:#c9d6e3;color:#1b2735}.topbar .edit-tools .label{font-size:11px;color:var(--muted)}.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}.skip-link:focus{position:static;width:auto;height:auto;padding:8px 12px;background:var(--accent);color:#fff;border-radius:8px;z-index:100}@media (max-width: 900px){html,body,#root,.app{height:100dvh}.app{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:0;bottom:0;width:min(88vw,380px);max-width:94vw;transform:translate(-100%);transition:transform .25s ease;box-shadow:0 0 0 1px #1d2735,var(--shadow);z-index:20}.app.side-open .sidebar{transform:translate(0)}.canvas-wrap{grid-column:1 / -1}.row,.row-3{grid-template-columns:1fr}.panel{width:100%}.row>label{margin-bottom:4px}.floating-panel{position:fixed;left:12px;right:12px;top:auto;bottom:12px;transform:none;max-width:unset;width:auto}.canvas-host{min-height:60svh}.app.side-open .backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:15}}.backdrop{display:none}[role=radio].active:focus-visible{outline:var(--focus);outline-offset:2px}.dock-probe{position:absolute;right:12px;bottom:12px;background:#0f1621ee;border:1px solid #1a2636;border-radius:12px;padding:10px 10px 12px;display:grid;gap:8px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:25;max-width:min(520px,calc(100% - 24px))}:root[data-theme=light] .dock-probe{background:#fffe;border-color:#d6e0ea}.dock-probe select,.dock-probe input{padding:4px 6px;font-size:12px;border-radius:6px}.dock-row{display:flex;gap:8px;align-items:center;width:100%}.dock-row.first-row{flex-wrap:wrap}.dock-row.first-row>*{flex:1 1 90px}.dock-row.first-row select{flex:0 0 86px}.dock-row.second-row{justify-content:flex-start}.dock-row.second-row .angle-input{width:110px;flex:0 0 110px}.dock-row.second-row .center-btn{flex:0 0 auto;white-space:nowrap}@media (max-width: 640px){.dock-probe{left:12px;right:12px;max-width:unset}.dock-row.second-row{flex-wrap:wrap}.dock-row.second-row .center-btn{flex:1 1 140px}.topbar{justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none;padding:4px;gap:4px;background:#10182799;border:1px solid #253145;border-radius:12px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.topbar::-webkit-scrollbar{display:none}.topbar .center-group{display:none}.topbar .left-group,.topbar .right-group{flex-shrink:0}.topbar .modes{flex-wrap:nowrap;gap:4px}.topbar .modes .btn{background:#ffffff14;border:none;box-shadow:none;border-radius:8px;padding:8px 12px;flex:0 0 auto}.topbar .modes .btn.active{background:var(--accent);color:#fff}:root[data-theme=light] .topbar{background:#fffc;border-color:#c2d2e0}:root[data-theme=light] .topbar .modes .btn{background:#0000000d}}@media (max-width: 1200px){.compact-hide{display:none!important}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#0c121b;border-radius:8px}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#182230,#101922);border:1px solid #253145;border-radius:8px;box-shadow:inset 0 0 0 1px #1d2735}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#223246,#152130)}::-webkit-scrollbar-corner{background:transparent}:root[data-theme=light] ::-webkit-scrollbar-track{background:#e6edf4}:root[data-theme=light] ::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#cfd9e5,#b9c7d6);border:1px solid #b0c0cf;box-shadow:inset 0 0 0 1px #d5e0eb}:root[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#bcc9d6,#a9b9c9)}*{scrollbar-width:thin;scrollbar-color:var(--accent) #0c121b}:root[data-theme=light] *{scrollbar-color:var(--accent) #e6edf4}.ctx-menu{position:fixed;z-index:1000;min-width:180px;background:#0f1621ee;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #1a2636;border-radius:12px;padding:6px;box-shadow:0 8px 32px -4px #0000008c,0 0 0 1px #ffffff08;animation:ctxPop .14s ease;font-size:13px}:root[data-theme=light] .ctx-menu{background:#fffe;border-color:#d5e0ea;box-shadow:0 6px 28px -6px #00000040,0 0 0 1px #0000000d}@keyframes ctxPop{0%{opacity:0;transform:translateY(4px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.ctx-menu ul{list-style:none;margin:0;padding:0;max-height:400px;overflow:auto}.ctx-menu-item{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:none;color:var(--text);font:inherit;padding:6px 10px;border-radius:8px;cursor:pointer;text-align:left;position:relative}.ctx-menu-item:hover,.ctx-menu-item:focus{background:#18263a;outline:none}:root[data-theme=light] .ctx-menu-item:hover,:root[data-theme=light] .ctx-menu-item:focus{background:#e4ecf3}.ctx-menu-item.danger{color:#fff}.ctx-menu-item.danger:hover{background:#ff5d6c}.ctx-menu-sep{height:1px;margin:4px;background:linear-gradient(90deg,#ffffff0f,#ffffff0a)}:root[data-theme=light] .ctx-menu-sep{background:#d9e2eb}.ctx-menu kbd{font-size:10px;background:#18263a;border:1px solid #253145;padding:1px 4px;border-radius:4px;color:var(--muted);margin-left:auto}:root[data-theme=light] .ctx-menu kbd{background:#eef2f7;border-color:#ccd7e2}.ctx-menu-item[disabled]{opacity:.4;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:1200;background:#00000073;padding:20px}:root[data-theme=light] .modal-overlay{background:#fffc}.modal-panel{min-width:320px;max-width:min(720px,92vw);background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border:1px solid #1a2636;border-radius:calc(var(--radius) - 4px);padding:16px;box-shadow:var(--shadow);color:var(--text)}:root[data-theme=light] .modal-panel{background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border-color:#d6e0ea;color:var(--text)}.modal-panel .title{display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:600;margin-bottom:8px}.modal-panel p{margin:0;color:var(--muted)}.tutorial-highlight{position:relative;z-index:1301;box-shadow:0 0 0 4px #ffb86c;border-radius:4px;pointer-events:none}
