*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;overflow:hidden}.app{display:flex;height:100%;width:100%}.canvas-wrap{flex:1;position:relative;background:linear-gradient(#bfe3ff,#e9f5ff 60%,#f3f7f2);min-width:0}.panel{width:320px;flex-shrink:0;background:#fff;border-left:1px solid #e6e8eb;padding:20px;overflow-y:auto}.panel h1{font-size:18px;margin-bottom:4px;color:#1b2733}.panel .sub{font-size:13px;color:#6b7785;margin-bottom:18px}.field{margin-bottom:18px}.field label{display:block;font-size:13px;font-weight:600;color:#36424e;margin-bottom:8px}.field input[type=range]{width:100%}.kw-value{font-weight:700;color:#1473e6}.options{display:grid;grid-template-columns:1fr 1fr;gap:8px}.options.single{grid-template-columns:1fr}.opt{border:1.5px solid #d6dbe0;border-radius:8px;padding:10px;font-size:13px;cursor:pointer;background:#fff;text-align:center;transition:all .15s ease;color:#36424e}.opt:hover{border-color:#9db4cc}.opt.active{border-color:#1473e6;background:#eef5ff;color:#0d5bbd;font-weight:600}.summary{margin-top:8px;padding:14px;background:#f5f8fb;border-radius:8px;font-size:13px;color:#36424e;line-height:1.7}.summary b{color:#1b2733}.hint{position:absolute;bottom:12px;left:12px;background:#1b2733b3;color:#fff;font-size:12px;padding:6px 12px;border-radius:6px;pointer-events:none}.settings-fab{display:none;position:absolute;right:16px;bottom:16px;width:56px;height:56px;border-radius:50%;border:none;background:#1473e6;color:#fff;font-size:24px;cursor:pointer;box-shadow:0 4px 14px #00000040;z-index:20;align-items:center;justify-content:center}.settings-fab:active{transform:scale(.94)}.panel-close{display:none;position:absolute;top:10px;right:12px;width:36px;height:36px;border-radius:50%;border:1px solid #e0e3e7;background:#fff;color:#36424e;font-size:20px;line-height:1;cursor:pointer;z-index:5}.panel-backdrop{display:none}@media (max-width: 760px){.canvas-wrap{position:absolute;top:0;right:0;bottom:0;left:0;height:100%;width:100%}.settings-fab{display:flex}.panel{position:fixed;left:0;right:0;bottom:0;width:100%;max-height:82%;border-left:none;border-top:1px solid #e6e8eb;border-radius:16px 16px 0 0;box-shadow:0 -6px 24px #0000002e;transform:translateY(110%);transition:transform .28s ease;z-index:30;padding-top:28px}.app.panel-open .panel{transform:translateY(0)}.panel{opacity:.9}.app.panel-open .panel-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;z-index:25}.app.panel-open .settings-fab{display:none}.panel-close{display:block}}.save-btn{margin-top:16px;width:100%;padding:12px;font-size:14px;font-weight:600;color:#fff;background:#1473e6;border:none;border-radius:8px;cursor:pointer;transition:background .15s ease}.save-btn:hover{background:#0d5bbd}.save-btn:active{transform:translateY(1px)}.stepper{display:flex;align-items:center;gap:8px}.stepper button{width:38px;height:38px;font-size:20px;font-weight:600;border:1.5px solid #d6dbe0;border-radius:8px;background:#fff;color:#36424e;cursor:pointer;flex-shrink:0}.stepper button:hover{border-color:#1473e6;color:#1473e6}.stepper input{flex:1;min-width:0;height:38px;text-align:center;font-size:15px;font-weight:600;border:1.5px solid #d6dbe0;border-radius:8px;color:#1b2733}.back-link{display:block;margin-top:14px;text-align:center;font-size:13px;color:#6b7785;text-decoration:none}.back-link:hover{color:#1473e6}.string-list{display:flex;flex-direction:column;gap:6px}.string-item{border:1.5px solid #d6dbe0;border-radius:8px;padding:9px 12px;font-size:13px;cursor:pointer;background:#fff;color:#36424e;transition:all .15s ease}.string-item:hover{border-color:#9db4cc}.string-item.active{border-color:#1473e6;background:#eef5ff;color:#0d5bbd;font-weight:600}.dim-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.dim-grid.two{grid-template-columns:1fr 1fr}.dim-cell{display:flex;flex-direction:column;gap:4px}.dim-cell span{font-size:11px;color:#6b7785}.dim-cell input{width:100%;height:36px;text-align:center;font-size:14px;font-weight:600;border:1.5px solid #d6dbe0;border-radius:8px;color:#1b2733}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}.compass-btn{display:inline-flex;align-items:center;gap:5px;flex-shrink:0;padding:6px 10px;font-size:12px;font-weight:600;color:#36424e;background:#fff;border:1.5px solid #d6dbe0;border-radius:999px;cursor:pointer}.compass-btn:hover{border-color:#1473e6;color:#1473e6}.compass-btn.on{border-color:#1473e6;background:#eef5ff;color:#0d5bbd}.compass-err{font-size:12px;color:#c0392b;margin-bottom:10px}.house-dir-overlay{position:absolute;top:12px;left:12px;right:12px;max-width:420px;margin:0 auto;background:#ffffffeb;border:1px solid #e0e3e7;border-radius:12px;padding:10px 14px;box-shadow:0 2px 10px #0000001f;z-index:15;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.house-dir-label{display:flex;align-items:center;gap:6px;font-size:13px;color:#36424e;margin-bottom:6px}.house-dir-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.house-dir-row .house-dir-label{margin-bottom:0}.compass-err-overlay{font-size:11px;color:#c0392b;margin-top:6px}.house-dir-label b{color:#1473e6}.house-dir-label em{font-style:normal;font-size:11px;color:#1aa251}.house-dir-overlay input[type=range]{width:100%}
