:root{--app-bg:#e7ece8;--stage-bg:#f4f6f2;--panel:#fbfaf6;--control:#fff;--control-hover:#f1f5ef;--grid-line:#30463c14;--line:#d9ddd5;--line-strong:#aeb9ad;--ink:#242821;--muted:#687164;--accent:#2f765f;--accent-strong:#205845;--warn:#9b5c3d;color:var(--ink);background:var(--app-bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:ui-sans-serif,Avenir Next,PingFang SC,Hiragino Sans GB,Microsoft YaHei,system-ui,sans-serif}*{box-sizing:border-box}html,body,#root{min-width:320px;min-height:100%;margin:0}body{min-height:100svh}button,input,select{letter-spacing:0}button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid color-mix(in srgb, var(--accent) 70%, white);outline-offset:2px}.workspace-shell{background:var(--app-bg);min-height:100svh;color:var(--ink);grid-template-rows:72px minmax(0,1fr);display:grid}.topbar{border-bottom:1px solid var(--line);background:var(--panel);justify-content:space-between;align-items:center;gap:20px;padding:12px 18px;display:flex}.brand{align-items:center;gap:12px;min-width:246px;display:flex}.brand svg{width:30px;height:30px;color:var(--accent)}.brand h1{margin:0;font-size:18px;font-weight:720;line-height:1.1}.brand p{color:var(--muted);margin:3px 0 0;font-size:12px}.toolbar{justify-content:flex-end;align-items:center;gap:8px;min-width:0;display:flex}.toolbar-divider{background:var(--line);width:1px;height:28px;margin:0 2px}.tool-button,.inline-action,.toolbar select,.segmented button,.book-row{border:1px solid var(--line);background:var(--control);min-height:34px;color:var(--ink);font:inherit;border-radius:6px}.tool-button{cursor:pointer;justify-content:center;align-items:center;gap:7px;padding:0 11px;display:inline-flex}.inline-action{cursor:pointer;justify-content:center;align-items:center;gap:7px;width:100%;margin:2px 0 8px;display:inline-flex}.tool-button svg,.inline-action svg,.asset-icon svg,.book-row svg,.toggle svg{width:16px;height:16px}.tool-button:hover,.inline-action:hover,.book-row:hover,.asset-upload:hover,.segmented button:hover{border-color:var(--line-strong);background:var(--control-hover)}.tool-button.active,.segmented button.active,.book-row.active{border-color:color-mix(in srgb, var(--accent) 58%, var(--line));background:color-mix(in srgb, var(--accent) 14%, var(--control));color:var(--accent-strong)}.toolbar select{max-width:148px;height:34px;padding:0 9px}.icon-action{border:1px solid var(--line);background:var(--control);width:34px;height:34px;color:var(--ink);cursor:pointer;border-radius:6px;place-items:center;display:inline-grid}.icon-action:hover{border-color:var(--line-strong);background:var(--control-hover)}.icon-action svg{width:16px;height:16px}.studio-grid{grid-template-columns:286px minmax(380px,1fr) 318px;min-height:0;display:grid}.panel{background:var(--panel);min-height:0;padding:16px;overflow:auto}.left-panel{border-right:1px solid var(--line)}.right-panel{border-left:1px solid var(--line)}.section-title{margin:4px 0 12px}.section-title small,.field-grid legend{color:var(--muted);text-transform:uppercase;font-size:11px}.section-title h2{margin:2px 0 0;font-size:18px;line-height:1.15}.panel-section{border-bottom:1px solid var(--line);margin-bottom:10px;padding:0 0 10px}.panel-section summary{cursor:pointer;grid-template-columns:1fr auto;align-items:center;gap:8px;min-height:42px;list-style:none;display:grid}.panel-section summary::-webkit-details-marker{display:none}.panel-section summary:after{content:"＋";color:var(--muted);font-size:16px}.panel-section[open] summary:after{content:"－"}.panel-section summary span{color:var(--muted);text-transform:uppercase;grid-column:1;font-size:11px;line-height:1}.panel-section summary strong{grid-column:1;font-size:18px;line-height:1.15}.panel-section-body{padding-top:6px}.asset-list,.book-list,.library-list{gap:8px;margin-bottom:18px;display:grid}.library-entry{border:1px solid var(--line);background:var(--control);width:100%;min-height:58px;color:var(--ink);font:inherit;text-align:left;cursor:pointer;border-radius:8px;grid-template-columns:32px 1fr;align-items:center;gap:10px;margin-bottom:24px;padding:10px;display:grid}.library-entry:hover{border-color:var(--line-strong);background:var(--control-hover)}.library-entry svg{width:18px;height:18px;color:var(--accent)}.library-entry strong,.library-entry small{display:block}.library-entry small{color:var(--muted);font-size:12px}.library-heading{grid-template-columns:1fr auto;align-items:start;gap:10px;display:grid}.search-field{border:1px solid var(--line);background:var(--control);min-height:34px;color:var(--muted);border-radius:6px;grid-template-columns:16px 1fr;align-items:center;gap:8px;margin-bottom:10px;padding:0 9px;display:grid}.search-field svg{width:16px;height:16px}.search-field input,.custom-tag-row input{width:100%;min-width:0;color:var(--ink);font:inherit;background:0 0;border:0;outline:0}.library-card{border:1px solid var(--line);background:var(--control);border-radius:8px;gap:8px;padding:10px;display:grid;position:relative}.library-card-main{width:100%;color:var(--ink);font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;grid-template-columns:18px 1fr;align-items:center;gap:8px;padding:0 58px 0 0;display:grid}.library-card-main svg{width:16px;height:16px;color:var(--accent)}.library-card-main strong,.library-card-main small{display:block}.library-card-main small,.empty-note,.readonly-book-card span{color:var(--muted);font-size:12px}.library-card-actions{gap:4px;display:flex;position:absolute;top:8px;right:8px}.library-card-actions button{width:26px;height:26px;color:var(--muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:5px;place-items:center;display:grid}.library-card-actions button:hover{border-color:var(--line);color:var(--ink)}.library-card-actions svg{width:14px;height:14px}.tag-row,.tag-options{flex-wrap:wrap;gap:5px;display:flex}.tag-chip,.tag-option{border:1px solid var(--line);background:var(--app-bg);min-height:24px;color:var(--muted);border-radius:999px;align-items:center;font-size:12px;display:inline-flex}.tag-chip{padding:0 8px}.tag-option{cursor:pointer;padding:0 10px}.tag-option.active{border-color:color-mix(in srgb, var(--accent) 58%, var(--line));background:color-mix(in srgb, var(--accent) 12%, var(--control));color:var(--accent-strong)}.asset-upload{border:1px solid var(--line);background:var(--control);cursor:pointer;border-radius:8px;grid-template-columns:34px 1fr;align-items:center;gap:10px;padding:10px;display:grid}.asset-upload input{display:none}.asset-list.compact{grid-template-columns:repeat(3,minmax(0,1fr));margin:14px 0}.asset-icon{background:var(--app-bg);width:34px;height:34px;color:var(--accent);border-radius:6px;place-items:center;display:grid}.asset-upload strong,.asset-upload small{display:block}.asset-upload small,.book-row small{color:var(--muted);font-size:12px}.segmented{grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:16px;display:grid}.segmented button{cursor:pointer}.book-row{text-align:left;cursor:pointer;grid-template-columns:18px 1fr auto;align-items:center;gap:8px;width:100%;padding:0 10px;display:grid}.book-assignment{border:1px solid var(--line);background:var(--control);border-radius:8px;gap:6px;padding:8px;display:grid}.book-assignment.active{border-color:color-mix(in srgb, var(--accent) 58%, var(--line));background:color-mix(in srgb, var(--accent) 10%, var(--control))}.book-assignment>button:first-child{width:100%;color:var(--ink);font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;grid-template-columns:18px 1fr auto;align-items:center;gap:8px;display:grid}.book-assignment svg{width:16px;height:16px}.book-assignment small{color:var(--muted);font-size:12px}.book-assignment select{border:1px solid var(--line);background:var(--panel);width:100%;height:32px;color:var(--ink);border-radius:6px;padding:0 8px}.book-assignment .slot-pick-button{border:1px solid var(--line);background:var(--panel);width:100%;min-height:32px;color:var(--ink);font:inherit;cursor:pointer;border-radius:6px;grid-template-columns:none;justify-content:center;align-items:center;display:inline-flex}.slot-pick-button:hover{border-color:var(--line-strong);background:var(--control-hover)}.stage{background:linear-gradient(var(--grid-line) 1px, transparent 1px), linear-gradient(90deg, var(--grid-line) 1px, transparent 1px), var(--stage-bg);background-size:36px 36px;min-width:0;min-height:0;position:relative}.scene-canvas{position:absolute;inset:0}.scene-canvas canvas{width:100%;height:100%;display:block}.stage-status{border:1px solid var(--line);background:color-mix(in srgb, var(--panel) 88%, transparent);max-width:min(560px,100% - 36px);color:var(--muted);border-radius:8px;padding:9px 12px;font-size:13px;position:absolute;bottom:18px;left:18px;box-shadow:0 8px 24px #22292214}.field,.toggle{color:var(--muted);gap:6px;font-size:12px;display:grid}.field input{box-sizing:border-box;border:1px solid var(--line);background:var(--control);width:100%;height:34px;color:var(--ink);font:inherit;border-radius:6px;padding:0 9px}.field-grid{border:0;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:16px 0;padding:0;display:grid}.field-grid legend{grid-column:1/-1;margin-bottom:2px}.toggle{border:1px solid var(--line);background:var(--control);min-height:34px;color:var(--ink);border-radius:6px;grid-template-columns:16px 16px 1fr;align-items:center;gap:7px;padding:0 8px}.toggle input{margin:0}.toggle.full{grid-template-columns:16px 1fr;margin-top:10px}.toggle.full svg{display:none}.export-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.readonly-book-card{border:1px solid var(--line);background:var(--control);border-radius:8px;gap:4px;padding:10px;display:grid}.readonly-book-card strong{font-size:14px}.modal-backdrop{z-index:20;background:#1f242057;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.editor-backdrop{z-index:30}.library-dialog{border:1px solid var(--line);background:var(--panel);border-radius:8px;width:min(720px,100%);max-height:min(820px,100svh - 36px);padding:18px;overflow:auto;box-shadow:0 18px 60px #2229222e}.library-browser{border:1px solid var(--line);background:var(--panel);border-radius:8px;width:min(1040px,100%);max-height:min(860px,100svh - 36px);padding:18px;overflow:auto;box-shadow:0 18px 60px #2229222e}.dialog-header{grid-template-columns:1fr auto;align-items:start;gap:12px;margin-bottom:14px;display:grid}.dialog-header-actions{align-items:center;gap:8px;display:flex}.dialog-header small,.tag-selector legend{color:var(--muted);text-transform:uppercase;font-size:11px}.dialog-header h2{margin:2px 0 0;font-size:20px}.tag-selector{border:0;gap:8px;margin:14px 0;padding:0;display:grid}.library-browser-search{max-width:420px}.library-filter-group{gap:8px;margin:14px 0;display:grid}.filter-group-title{color:var(--muted);text-transform:uppercase;font-size:11px}.library-grid{grid-template-columns:repeat(auto-fill,minmax(154px,1fr));gap:10px;margin-top:16px;display:grid}.library-grid-card{border:1px solid var(--line);background:var(--control);border-radius:8px;gap:8px;min-width:0;padding:10px;display:grid;position:relative}.book-cover-button{width:100%;color:var(--ink);font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;gap:8px;padding:0;display:grid}.book-cover-button strong,.book-cover-button small{display:block}.book-cover-button small{color:var(--muted);font-size:12px}.cover-thumb{aspect-ratio:4/5.4;border:1px solid var(--line);background:var(--app-bg);width:100%;color:var(--accent);border-radius:6px;place-items:center;display:grid;position:relative;overflow:hidden}.cover-thumb img{object-fit:cover;width:100%;height:100%;display:block}.cover-thumb svg{width:26px;height:26px}.cover-thumb span{color:color-mix(in srgb, var(--ink) 50%, transparent);font-size:22px;font-weight:720;position:absolute;bottom:6px;left:8px}.custom-tag-row{border:1px solid var(--line);background:var(--control);border-radius:6px;grid-template-columns:1fr 34px;align-items:center;gap:8px;min-height:34px;padding-left:9px;display:grid}.dialog-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=1180px){.workspace-shell{grid-template-rows:auto minmax(0,1fr)}.topbar{flex-direction:column;align-items:flex-start}.toolbar{flex-wrap:wrap;justify-content:flex-start;width:100%}.studio-grid{grid-template-columns:246px minmax(360px,1fr)}.right-panel{border-left:0;border-top:1px solid var(--line);grid-column:1/-1;max-height:280px}}@media (width<=720px){.studio-grid{grid-template-rows:auto minmax(420px,58svh) auto;grid-template-columns:1fr}.left-panel,.right-panel{border-inline:0}.left-panel{border-bottom:1px solid var(--line)}.tool-button span{display:none}}
