:root{color-scheme:light;--top-gap:20px;--child-gap:6px;--header-h:56px;--bg:#ffffff;--header-bg:#ffffff;--panel-bg:#f7f7f7;--surface:#f9f9f9;--surface-hover:#f2f2f2;--surface-muted:#fafafa;--text:#222;--text-strong:#444;--text-muted:#666;--text-subtle:#777;--line:#ccc;--border:rgba(0, 0, 0, 0.15);--node-border:rgba(0, 0, 0, 0.18);--input-bg:rgba(255, 255, 250, 0.96);--input-border:rgba(0, 0, 0, 0.2);--btn-bg:#fff;--btn-text:#222;--btn-border:#d0d0d0;--btn-hover:#f6f6f6;--ghost-text:#333;--ghost-hover:#f2f2f2;--icon-hover:rgba(0, 0, 0, 0.06);--focus-ring:rgba(0, 120, 255, 0.25);--focus-border:#7fb6ff;--drag-accent:#7aa7ff;--drag-forbidden:#ff7a7a;--modal-backdrop:rgba(0, 0, 0, 0.45);--tooltip-bg:#222;--tooltip-text:#fff;--perm-chip-border:rgba(0, 0, 0, 0.18);--perm-chip-bg:rgba(0, 0, 0, 0.04);--perm-search-border:rgba(0, 0, 0, 0.2);--perm-search-bg:#ffffff}:root[data-theme=dark]{color-scheme:dark;--bg:#0b1220;--header-bg:#0b1220;--panel-bg:#0f1a2b;--surface:#0f1a2b;--surface-hover:#12213a;--surface-muted:#101c30;--text:#e5e7eb;--text-strong:#e5e7eb;--text-muted:#a6b0bf;--text-subtle:#9ca3af;--line:rgba(255, 255, 255, 0.22);--border:rgba(255, 255, 255, 0.18);--node-border:rgba(255, 255, 255, 0.22);--input-bg:rgba(15, 26, 43, 0.92);--input-border:rgba(255, 255, 255, 0.22);--btn-bg:#0f1a2b;--btn-text:#e5e7eb;--btn-border:rgba(255, 255, 255, 0.22);--btn-hover:rgba(255, 255, 255, 0.08);--ghost-text:#e5e7eb;--ghost-hover:rgba(255, 255, 255, 0.08);--icon-hover:rgba(255, 255, 255, 0.08);--modal-backdrop:rgba(0, 0, 0, 0.6);--tooltip-bg:#111827;--tooltip-text:#e5e7eb;--perm-chip-border:rgba(255, 255, 255, 0.22);--perm-chip-bg:rgba(255, 255, 255, 0.08);--perm-search-border:rgba(255, 255, 255, 0.22);--perm-search-bg:rgba(0, 0, 0, 0.2)}body,html{min-height:100%;overflow:auto}body{font-family:system-ui,Arial,sans-serif;margin:0;background:var(--bg);color:var(--text);cursor:default}.add-menu button,.btn,.icon-btn,.toggle,button{cursor:pointer}input[type=text],textarea{cursor:text;background:var(--input-bg);border:1px solid var(--input-border);color:var(--text)}header{position:sticky;top:0;z-index:2;background:var(--header-bg);height:var(--header-h);display:flex;align-items:center;padding:0 20px}h1{margin:0 0 12px}h1,h2,h3,h4,h5{margin-bottom:3px}.help-modal h3{margin-bottom:0}.help-modal p{margin:0}#app{display:grid;grid-template-columns:1fr;min-height:calc(100vh - var(--header-h))}#main{padding:0 20px 20px}#controls{display:flex;gap:8px;align-items:center;margin-bottom:10px}#controls .controls-left,#controls .controls-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}#controls .controls-right{margin-left:auto}#addTopBtn,#clearBtn,#collapseAllBtn,#expandAllBtn,#exportBtn,#hint,#permissionsBtn{display:none}#tree>ul{margin-left:10px}#tree>ul::before{content:none}ul{list-style:none}#tree>ul>li+li,li.has-children+li,li.no-children+li.has-children{margin-top:var(--top-gap)}#tree>ul>li::before{content:none}li>ul,ul ul>li+li{margin-top:var(--child-gap)}.node{position:relative;display:grid;grid-auto-flow:row;grid-template-columns:1fr;align-items:center;padding:4px 8px;border:1px solid var(--node-border);background:var(--surface);border-left:50px solid transparent;border-radius:8px}.node:hover{background:var(--surface-hover)}.node-folder{border-left-color:#4c78ff}.node-group{border-left-color:#e89b2c}.node-capcode{border-left-color:#38a169}.node-folder .kind-icon{color:#4c78ff}.node-group .kind-icon{color:#e89b2c}.node-capcode .kind-icon{color:#38a169}.node.node-invalid{border:2px solid #c00}.node .actions{opacity:0;pointer-events:none;transform:translateY(-1px);transition:opacity 120ms,transform 120ms}.node:focus-within .actions,.node:hover .actions{opacity:1;pointer-events:auto;transform:translateY(0)}.node-header{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.node-header .actions{margin-left:auto}.node strong{text-transform:uppercase;font-size:12px;color:var(--text-strong);letter-spacing:.02em}.node .meta-title{font-size:large}.node .meta-row{grid-column:1/-1;display:flex;align-items:center;gap:8px;white-space:nowrap;overflow-x:auto}.node .meta-inline{display:inline-flex}.node .meta-description{grid-column:1/-1;display:block;font-style:italic;color:var(--text-muted)}.toggle{user-select:none;margin-right:4px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;color:var(--text-subtle);padding:0;border:none;background:0 0}.actions{display:inline-flex;gap:6px;margin-left:8px}.actions button,.actions select{font-size:12px}.actions button{padding:2px 6px}li.collapsed>ul{display:none}.top-level .node{border-width:2px;padding:6px 10px}.root-actions{display:flex;align-items:center;gap:8px;margin:8px 0 12px}.modal{position:fixed;inset:0;z-index:1000;display:none}.modal.show{display:block}.modal-backdrop{position:fixed;inset:0;background:var(--modal-backdrop)}.modal-dialog{position:fixed;inset:0;margin:auto;width:min(720px,92vw);max-height:90vh;background:var(--bg);border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.25);border:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.modal-header{flex:0 0 auto;padding:12px 16px;background:var(--panel-bg);display:flex;align-items:center;justify-content:space-between;gap:8px;border-bottom:1px solid var(--border)}.modal-body{flex:1 1 auto;overflow:auto;padding:14px 16px;display:flex;flex-direction:column;gap:12px}.modal-footer{flex:0 0 auto;padding:12px 16px;background:var(--panel-bg);display:flex;align-items:center;gap:8px;border-top:1px solid var(--border)}#modal-close{font-size:18px;line-height:1;padding:4px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text)}body.modal-open{overflow:hidden}body.modal-open header{filter:brightness(.55)}.computed-panel{border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:12px;background:var(--surface-muted)}.computed-title{font-weight:700;margin-bottom:8px}.computed-grid{display:grid;gap:8px}.computed-row{display:grid;grid-template-columns:140px 1fr;gap:10px;align-items:center}.computed-label{color:var(--text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.02em}.computed-value{font-family:ui-monospace,monospace}.source-generated{color:var(--text-muted);font-style:italic}.source-inherited{color:var(--text-subtle)}.computed-tag{margin-left:6px;font-size:11px;color:var(--text-subtle)}.form-row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start;margin:12px 0}.klabel{font-weight:600}.klabel-wrap{display:flex;align-items:baseline;gap:6px}.label-col{min-width:0;display:grid;gap:4px}.optional-tag{font-size:11px;color:var(--text-subtle);font-weight:500}.field-help{font-size:12px;color:var(--text-subtle);line-height:1.25}input[type=text],textarea{justify-self:end;padding:8px 10px;border-radius:8px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);font-size:14px;line-height:1.35;transition:border-color 120ms,box-shadow 120ms}.form-row textarea{width:320px;min-height:110px;resize:vertical}.form-row input:focus,.form-row textarea:focus{outline:0;border-color:var(--focus-border);box-shadow:0 0 0 3px var(--focus-ring)}.hr{height:1px;background:var(--border);margin:14px 0}.drag-before::after{content:'';position:absolute;left:-6px;right:-6px;top:-2px;height:2px;background:var(--drag-accent);pointer-events:none}.drag-after::after{content:'';position:absolute;left:-6px;right:-6px;bottom:-2px;height:2px;background:var(--drag-accent);pointer-events:none}.drag-into{outline:2px solid var(--drag-accent);outline-offset:2px}.drag-forbidden{outline:2px dashed var(--drag-forbidden);outline-offset:3px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--node-border);border-radius:6px;color:inherit;outline:0}.icon-btn svg{pointer-events:none}.icon-btn:hover{background:var(--icon-hover)}.icon-btn:active{transform:translateY(1px)}.icon-btn:focus-visible{outline:0;box-shadow:0 0 0 2px rgba(0,120,255,.45);border-color:rgba(0,120,255,.55)}.icon-btn.icon-compact{width:28px;height:28px}.icon-btn.icon-compact svg{width:18px;height:18px}.icon-btn svg,.kind-icon svg{width:22px;height:22px}.kind-capcode,.kind-folder,.kind-group{opacity:.8}.add-menu{position:fixed;background:var(--bg);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.1);padding:4px;z-index:1000}.add-menu button{display:block;width:100%;padding:6px 10px;border:none;background:0 0;text-align:left;color:var(--text)}.add-menu button:hover{background:var(--ghost-hover)}.has-tooltip{position:relative;cursor:help}.has-tooltip::after{content:attr(data-tooltip);position:absolute;bottom:120%;left:0;background:var(--tooltip-bg);color:var(--tooltip-text);font-size:12px;padding:6px 8px;border-radius:4px;white-space:nowrap;opacity:0;pointer-events:none;transform:translateY(4px);transition:opacity 120ms,transform 120ms}.has-tooltip:hover::after{opacity:1;transform:translateY(0)}.btn{appearance:none;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--btn-text);font:inherit;font-size:14px;line-height:1;padding:7px 12px;border-radius:8px;display:inline-flex;align-items:center;gap:8px;user-select:none;transition:background 120ms,border-color 120ms,transform 80ms,box-shadow 120ms}.btn:hover{background:var(--btn-hover);border-color:var(--btn-border)}.btn:active{transform:translateY(1px)}.btn:focus-visible{outline:0;box-shadow:0 0 0 3px var(--focus-ring);border-color:var(--focus-border)}.btn-primary{background:#1f6feb;border-color:#1f6feb;color:#fff}.btn-primary:hover{background:#1a5fd0;border-color:#1a5fd0}.btn-danger{background:#d1242f;border-color:#d1242f;color:#fff}.btn-danger:hover{background:#b91c25;border-color:#b91c25}.btn-ghost{background:0 0;border-color:transparent;color:var(--ghost-text)}.btn-ghost:hover{background:var(--ghost-hover);border-color:var(--ghost-hover)}#permissionsModal .modal-dialog.modal-lg{width:min(1200px,92vw);max-height:90vh}#permissionsModal .modal-body{display:flex;flex-direction:column;overflow:hidden;min-height:0}#permissionsModal .perm-tabs{display:flex;gap:8px;margin-bottom:12px}#permissionsModal .perm-tab.active{background:var(--btn-hover);border-color:var(--btn-border)}#permissionsModal .perm-layout{display:grid;grid-template-columns:320px 1fr;gap:14px;flex:1 1 auto;min-height:0}#permissionsModal .perm-left{display:flex;flex-direction:column;min-height:0}#permissionsModal .perm-left-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}#permissionsModal .perm-list{flex:1 1 auto;min-height:0;overflow:auto}#permissionsModal .perm-right{min-height:0;overflow:hidden;display:flex;flex-direction:column}#permissionsModal #permEditorEmpty{padding:16px;opacity:.8}#permissionsModal #permEditor{flex:1 1 auto;min-height:0;overflow:auto;padding:14px}#permissionsModal .perm-bucket,#permissionsModal .perm-list,#permissionsModal .perm-result,#permissionsModal .perm-right{border:1px solid var(--border);background:var(--surface);border-radius:12px;padding:12px}#permissionsModal .perm-result{width:100%;text-align:left;border-radius:10px;color:inherit;padding:10px;cursor:pointer;transition:margin-left 120ms}#permissionsModal .perm-result-title{display:flex;align-items:center;gap:8px;font-weight:700}#permissionsModal .perm-result-title .kind-icon svg{width:18px;height:18px}#permissionsModal .perm-list-item{width:100%;text-align:left;padding:8px 10px;border-radius:8px;border:1px solid transparent;background:0 0;color:inherit;cursor:pointer}#permissionsModal .perm-list-item:hover,#permissionsModal .perm-result:hover{background:var(--surface-hover)}#permissionsModal .perm-list-item.active{background:var(--surface-hover);border-color:var(--border)}#permissionsModal .perm-editor-title{font-weight:700;margin:0 0 12px}#permissionsModal .perm-row{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}#permissionsModal .perm-label{font-size:12px;opacity:.85}#permissionsModal .perm-buckets{display:grid;grid-template-columns:1fr;gap:12px;margin-top:10px}#permissionsModal .perm-bucket-title{font-weight:650}#permissionsModal .perm-bucket-desc{margin-top:4px;font-size:12px;opacity:.75}#permissionsModal .perm-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;margin-bottom:10px}#permissionsModal .perm-chip{border:1px solid var(--perm-chip-border);background:var(--perm-chip-bg);color:inherit;border-radius:999px;padding:6px 10px;cursor:pointer;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#permissionsModal .perm-search{width:100%;padding:8px 10px;border-radius:10px;border:1px solid var(--perm-search-border);background:var(--perm-search-bg);color:inherit;outline:0;box-sizing:border-box}#permissionsModal .perm-results{margin-top:10px;max-height:220px;overflow:auto;display:flex;flex-direction:column;gap:8px}#permissionsModal .perm-warnings{margin-top:12px;border:1px solid rgba(255,180,0,.35);background:rgba(255,180,0,.08);border-radius:12px;padding:10px 12px}#permissionsModal .perm-warnings-title{font-weight:700;margin-bottom:6px}#permissionsModal .perm-shift-hint{margin-top:8px;padding:6px 10px;border-radius:10px;font-size:12px;opacity:.9;border:1px solid var(--border);background:var(--surface-muted)}#permissionsModal .perm-result.shift-eligible{outline:rgba(0,120,255,.35) solid 2px;outline-offset:2px}#permissionsModal .perm-result.shift-disabled{opacity:.45;cursor:not-allowed;pointer-events:none;filter:grayscale(.4)}