@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-base:#111116;--bg-surface:#1a1a22;--bg-raised:#22222e;--bg-hover:#2a2a38;--bg-active:#32324a;--bg-input:#16161e;--border:#2e2e3e;--border-subtle:#252535;--border-focus:#6c6cff;--text-primary:#e4e4ef;--text-secondary:#9898ae;--text-muted:#6a6a80;--text-accent:#8b8bff;--accent:#6c6cff;--accent-hover:#7e7eff;--accent-subtle:#6c6cff1f;--accent-glow:#6c6cff40;--success:#3ecf8e;--success-bg:#3ecf8e1a;--warning:#f5a623;--danger:#ef4444;--danger-hover:#dc2626;--danger-bg:#ef44441a;--radius-sm:4px;--radius:6px;--radius-lg:10px;--shadow:0 2px 8px #0000004d;--shadow-lg:0 8px 32px #0006;--transition:.15s ease;--font-sans:"DM Sans", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--header-height:48px;--sidebar-width:280px}html,body{width:100%;height:100%;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-base);-webkit-font-smoothing:antialiased;font-size:14px;overflow:hidden}#root{width:100%;height:100vh}a{color:var(--text-accent);transition:color var(--transition);text-decoration:none}:root{--bg-base:#111116;--bg-surface:#1a1a22;--bg-raised:#22222e;--bg-hover:#2a2a38;--bg-active:#32324a;--bg-input:#16161e;--border:#2e2e3e;--border-subtle:#252535;--border-focus:#6c6cff;--text-primary:#e4e4ef;--text-secondary:#9898ae;--text-muted:#6a6a80;--text-accent:#8b8bff;--accent:#6c6cff;--accent-hover:#7e7eff;--accent-subtle:#6c6cff1f;--accent-glow:#6c6cff40;--success:#3ecf8e;--success-bg:#3ecf8e1a;--warning:#f5a623;--danger:#ef4444;--danger-hover:#dc2626;--danger-bg:#ef44441a;--radius-sm:4px;--radius:6px;--radius-lg:10px;--shadow:0 2px 8px #0000004d;--shadow-lg:0 8px 32px #0006;--transition:.15s ease;--font-sans:"DM Sans", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-base);-webkit-font-smoothing:antialiased;font-size:14px;overflow:hidden}a{color:var(--text-accent);text-decoration:none}a:hover{color:var(--accent-hover)}.landing{background:radial-gradient(ellipse at 30% 20%, #6c6cff0f 0%, transparent 60%), var(--bg-base);justify-content:center;align-items:center;height:100vh;display:flex}.landing-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:480px;box-shadow:var(--shadow-lg);padding:48px 40px}.landing-logo{letter-spacing:.15em;text-transform:uppercase;color:var(--text-accent);font-size:13px;font-weight:600;font-family:var(--font-mono);margin-bottom:4px}.landing-title{color:var(--text-primary);margin-bottom:8px;font-size:28px;font-weight:700}.landing-subtitle{color:var(--text-secondary);margin-bottom:36px;font-size:14px;line-height:1.5}.landing-section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;font-size:11px;font-weight:600}.landing-create{gap:8px;margin-bottom:32px;display:flex}.landing-create input{flex:1}.landing-projects{flex-direction:column;gap:6px;max-height:240px;display:flex;overflow-y:auto}.project-item{background:var(--bg-raised);border:1px solid var(--border-subtle);border-radius:var(--radius);transition:all var(--transition);align-items:center;gap:4px;display:flex;overflow:hidden}.project-item:hover{background:var(--bg-hover);border-color:var(--border)}.project-item-link{color:var(--text-primary);flex:1;align-items:center;gap:12px;min-width:0;padding:10px 14px;text-decoration:none;display:flex}.project-item .icon{font-size:20px}.project-item .name{flex:1;font-weight:500}.project-item .meta{color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.project-icon{flex-shrink:0;font-size:20px}.project-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.project-name{color:var(--text-primary);font-weight:500}.project-path{font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.project-download{opacity:.5;flex-shrink:0;margin-right:8px;font-size:16px;text-decoration:none;background:0 0!important;border:none!important}.project-item:hover .project-download{opacity:1}.project-download:hover{opacity:1;background:var(--accent-subtle)!important;border:1px solid var(--accent)!important;color:var(--accent)!important}.file-input-label{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;transition:border-color var(--transition);flex:1;align-items:center;min-width:0;padding:8px 12px;font-size:13px;display:flex}.file-input-label:hover{border-color:var(--text-muted);color:var(--text-primary)}.file-input-label input[type=file]{display:none}.file-input-label span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.landing-empty{text-align:center;color:var(--text-muted);padding:24px;font-size:13px}.error-msg{background:var(--danger-bg);color:#fca5a5;border-radius:var(--radius);border:1px solid #ef44444d;margin-bottom:16px;padding:10px 14px;font-size:13px}.app-layout{flex-direction:column;height:100vh;display:flex}.app-header{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:10;align-items:center;gap:16px;height:48px;min-height:48px;padding:0 20px;display:flex}.app-header .logo{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text-accent);white-space:nowrap;font-size:12px;font-weight:600}.app-header .project-name{color:var(--text-primary);font-size:14px;font-weight:600}.header-sep{color:var(--text-muted);font-size:16px}.header-spacer{flex:1}.search-box{width:260px;position:relative}.search-box input{width:100%;padding:6px 12px 6px 32px;font-size:13px}.search-box .search-icon{color:var(--text-muted);pointer-events:none;font-size:13px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-results-dropdown{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:100;max-height:320px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.search-result-item{cursor:pointer;transition:background var(--transition);color:var(--text-primary);align-items:center;gap:10px;padding:8px 12px;text-decoration:none;display:flex}.search-result-item:hover{background:var(--bg-hover);color:var(--text-primary)}.search-result-item .sr-icon{font-size:15px}.search-result-item .sr-name{flex:1;font-weight:500}.search-result-item .sr-type{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.search-empty{text-align:center;color:var(--text-muted);padding:12px;font-size:13px}.header-btn{border:1px solid var(--border);color:var(--text-secondary);background:0 0;padding:5px 12px;font-size:12px}.header-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.app-body{flex:1;display:flex;overflow:hidden}.panel-tree{background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;width:560px;min-width:220px;max-width:800px;display:flex;position:relative;overflow:hidden}.panel-resize-handle{cursor:col-resize;z-index:5;background:0 0;width:5px;height:100%;transition:background .15s;position:absolute;top:0;right:0}.panel-resize-handle:hover,.panel-resize-handle.dragging{background:var(--accent);opacity:.5}.tree-scroll{flex:1;padding:8px 0;overflow-y:auto}.tree-category{margin-bottom:4px}.tree-category-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);cursor:default;align-items:center;padding:6px 16px;font-size:11px;font-weight:600;display:flex}.tree-entity-group{margin-bottom:2px}.tree-group-header{cursor:pointer;transition:background var(--transition);user-select:none;align-items:center;gap:6px;padding:5px 12px 5px 16px;display:flex}.tree-group-header:hover{background:var(--bg-hover)}.tree-group-header .chevron{color:var(--text-muted);transition:transform var(--transition);text-align:center;width:14px;font-size:10px}.tree-group-header.collapsed .chevron{transform:rotate(-90deg)}.tree-group-header .icon{font-size:14px}.tree-group-header .label{flex:1;font-size:13px;font-weight:500}.tree-group-header .count{color:var(--text-muted);font-size:11px;font-family:var(--font-mono);background:var(--bg-base);border-radius:8px;padding:1px 6px}.tree-group-header .add-btn{opacity:0;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;padding:0 4px;font-size:16px;line-height:1}.tree-group-header:hover .add-btn{opacity:1}.tree-group-header .add-btn:hover{color:var(--accent)}.tree-items{transition:max-height .2s;overflow:hidden}.tree-items.collapsed{max-height:0!important}.tree-item{cursor:pointer;transition:all var(--transition);color:var(--text-secondary);align-items:center;gap:8px;padding:4px 12px 4px 42px;font-size:13px;text-decoration:none;display:flex}.tree-item:hover{background:var(--bg-hover);color:var(--text-primary)}.tree-item.active{background:var(--accent-subtle);color:var(--text-accent);font-weight:500}.tree-item .dot{background:var(--text-muted);border-radius:50%;flex-shrink:0;width:5px;height:5px}.tree-item.active .dot{background:var(--accent)}.panel-editor{background:var(--bg-base);flex:1;overflow-y:auto}.editor-empty{height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:14px;display:flex}.editor-empty .hint{color:var(--text-muted);opacity:.6;font-size:12px}.entity-editor{max-width:800px;margin:0 auto;padding:32px 40px 64px}.entity-header{border-bottom:1px solid var(--border-subtle);align-items:flex-start;gap:16px;margin-bottom:28px;padding-bottom:20px;display:flex}.entity-header .icon{margin-top:2px;font-size:28px}.entity-header-info{flex:1}.entity-header .type-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:2px;font-size:11px;font-weight:600}.entity-header .entity-name{color:var(--text-primary);font-size:22px;font-weight:700;line-height:1.2}.entity-header .entity-meta{color:var(--text-muted);font-size:12px;font-family:var(--font-mono);margin-top:4px}.entity-actions{align-items:flex-start;gap:8px;display:flex}.tab-bar{border-bottom:1px solid var(--border);gap:0;margin-bottom:24px;display:flex;overflow-x:auto}.tab-btn{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 18px;font-size:13px;font-weight:500}.tab-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.tab-btn.active{color:var(--text-accent);border-bottom-color:var(--accent)}.tab-content{animation:.15s fadeIn;display:none}.tab-content.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.field-group{margin-bottom:20px}.field-label{color:var(--text-secondary);letter-spacing:.02em;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.field-label .required{color:var(--danger);margin-left:2px}.field-help{color:var(--text-muted);margin-top:4px;font-size:11px;line-height:1.4}input[type=text],input[type=number],input[type=search],select,textarea,.form-control{width:100%;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);outline:none;padding:8px 12px;font-size:13px}input:focus,select:focus,textarea:focus,.form-control:focus{border-color:var(--border-focus);box-shadow:0 0 0 2px var(--accent-glow)}input::placeholder,textarea::placeholder,.form-control::placeholder{color:var(--text-muted);opacity:.7}textarea{resize:vertical;min-height:80px;line-height:1.5}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236a6a80'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}select option{background:var(--bg-raised);color:var(--text-primary)}.field-checkbox{align-items:center;gap:8px;display:flex}.field-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.field-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.btn{font-family:var(--font-sans);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);background:var(--bg-raised);color:var(--text-primary);white-space:nowrap;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;display:inline-flex}.btn:hover{background:var(--bg-hover);border-color:var(--text-muted)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-danger{border-color:var(--border);color:var(--text-secondary);background:0 0}.btn-danger:hover{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{padding:6px 8px;font-size:15px;line-height:1}.save-bar{border-top:1px solid var(--border-subtle);align-items:center;gap:12px;margin-top:32px;padding-top:20px;display:flex}.save-indicator{color:var(--success);opacity:0;font-size:12px;transition:opacity .3s}.save-indicator.show{opacity:1}.toast{background:var(--bg-raised);border:1px solid var(--success);color:var(--success);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:1000;padding:10px 18px;font-size:13px;font-weight:500;animation:.3s toastIn,.3s 2s forwards toastOut;position:fixed;bottom:20px;right:20px}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0}}.hidden{display:none!important}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.text-muted{color:var(--text-muted)}.text-sm{font-size:12px}.mono{font-family:var(--font-mono)}.query-main{flex:1;padding:40px;overflow-y:auto}.query-hero{text-align:center;margin-bottom:40px}.query-hero h1{color:var(--text-primary);margin-bottom:6px;font-size:26px;font-weight:700}.query-hero p{color:var(--text-secondary);font-size:14px}.query-cards{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;max-width:1200px;margin:0 auto 48px;display:grid}.query-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition);flex-direction:column;gap:16px;padding:24px;display:flex}.query-card:hover{border-color:var(--text-muted)}.query-card-icon{font-size:28px;line-height:1}.query-card-body h3{color:var(--text-primary);margin-bottom:4px;font-size:16px;font-weight:600}.query-card-body p{color:var(--text-secondary);margin-bottom:16px;font-size:13px;line-height:1.5}.query-card-inputs{flex-direction:column;gap:10px;display:flex}.query-card-inputs select{width:100%}.query-card-inputs .btn{align-self:flex-start}#query-results{max-width:1200px;margin:0 auto;padding-bottom:64px}#query-results-title{color:var(--text-primary);border-bottom:1px solid var(--border);margin-bottom:20px;padding-bottom:12px;font-size:20px;font-weight:700}.query-table thead th{text-align:left;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-surface);white-space:nowrap;padding:10px 12px;font-size:11px;font-weight:600}.query-table tbody td{border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);vertical-align:top;padding:10px 12px}.query-table tbody tr:hover td{background:var(--bg-hover);color:var(--text-primary)}.query-table a{color:var(--text-accent);font-weight:500}.query-table a:hover{text-decoration:underline}.query-table-compact{font-size:12px}.query-table-compact thead th,.query-table-compact tbody td{padding:6px 10px}.query-badge{background:var(--accent-subtle);color:var(--text-accent);white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.query-badge-accent{background:var(--accent-subtle);color:var(--text-accent)}.query-badge-muted{background:var(--bg-hover);color:var(--text-muted);font-size:10px}.query-context-grid,.query-stats-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;display:grid}.query-context-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.query-context-card h3{color:var(--text-primary);border-bottom:1px solid var(--border-subtle);margin-bottom:14px;padding-bottom:8px;font-size:14px;font-weight:600}.query-dl{grid-template-columns:auto 1fr;gap:6px 16px;font-size:13px;display:grid}.query-dl dt{color:var(--text-muted);white-space:nowrap;font-weight:500}.query-dl dd{color:var(--text-primary);word-break:break-word}.query-empty{text-align:center;color:var(--text-muted);padding:24px;font-size:13px}.query-error{text-align:center;color:#fca5a5;background:var(--danger-bg);border-radius:var(--radius);border:1px solid #ef444440;padding:24px;font-size:13px}.header-btn-active,.header-btn-active:hover{background:var(--accent-subtle);border-color:var(--accent);color:var(--text-accent)}.link-panel{border-top:1px solid var(--border-subtle);margin-top:28px;padding-top:20px}.link-panel-header{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;font-size:12px;font-weight:600}.link-search{margin-bottom:12px;position:relative}.link-search-input{width:100%;padding:8px 12px;font-size:13px}.link-autocomplete-dropdown{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:50;max-height:240px;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto}.link-autocomplete-item{cursor:pointer;transition:background var(--transition);color:var(--text-primary);align-items:center;gap:10px;padding:8px 12px;font-size:13px;display:flex}.link-autocomplete-item:hover,.link-autocomplete-item.highlighted{background:var(--bg-hover)}.link-autocomplete-item.highlighted{background:var(--accent-subtle);color:var(--text-accent)}.link-autocomplete-create{color:var(--success);border-top:1px solid var(--border-subtle);font-style:italic}.link-chips{flex-direction:column;gap:6px;display:flex}.link-chip{background:var(--bg-raised);border:1px solid var(--border-subtle);border-radius:var(--radius);transition:border-color var(--transition);align-items:center;gap:10px;padding:6px 10px;display:flex}.link-chip:hover{border-color:var(--border)}.link-chip-name{color:var(--text-accent);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:13px;font-weight:500;text-decoration:none;overflow:hidden}.link-chip-name:hover{color:var(--accent-hover);text-decoration:underline}.link-new-indicator{color:var(--success);flex-shrink:0;font-size:11px;font-style:italic}.link-chip-meta{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:130px;color:var(--text-primary);flex-shrink:0;padding:4px 8px;font-size:12px}.link-chip-order{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:60px;color:var(--text-primary);text-align:center;flex-shrink:0;padding:4px 8px;font-size:12px}.link-chip-remove{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;flex-shrink:0;padding:2px 6px;font-size:16px;line-height:1}.link-chip-remove:hover{background:var(--danger-bg);color:var(--danger)}.appears-in{border-top:1px solid var(--border-subtle);margin-top:28px;padding-top:20px}.appears-in-header{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;font-size:12px;font-weight:600}.appears-in-list{flex-direction:column;gap:4px;display:flex}.appears-in-item{background:var(--bg-raised);border:1px solid var(--border-subtle);border-radius:var(--radius);color:var(--text-primary);transition:all var(--transition);align-items:center;gap:10px;padding:6px 10px;font-size:13px;text-decoration:none;display:flex}.appears-in-item:hover{background:var(--bg-hover);border-color:var(--border);color:var(--text-accent)}.appears-in-number{font-family:var(--font-mono);color:var(--text-muted);flex-shrink:0;width:36px;font-size:11px}.appears-in-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.appears-in-badge{background:var(--accent-subtle);color:var(--text-accent);border-radius:10px;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:500}.appears-in-empty{color:var(--text-muted);padding:8px 0;font-size:13px;font-style:italic}.tree-toolbar{border-bottom:1px solid var(--border-subtle);gap:4px;padding:6px 12px;display:flex}.tree-toolbar-btn{border-color:var(--border-subtle);color:var(--text-muted);background:0 0;padding:3px 10px;font-size:11px}.tree-toolbar-btn:hover{background:var(--bg-hover);border-color:var(--border);color:var(--text-primary)}.tree-category-label{cursor:pointer;user-select:none;transition:color var(--transition)}.tree-category-label:hover{color:var(--text-secondary)}.tree-category-label .cat-chevron{transition:transform var(--transition);text-align:center;width:12px;margin-right:2px;font-size:9px;display:inline-block}.tree-category.cat-collapsed .tree-category-label .cat-chevron{transform:rotate(-90deg)}.tree-category.cat-collapsed .tree-category-body{display:none}.tree-category-placeholder .tree-category-label{opacity:.55}.tree-category-placeholder .tree-category-label:hover{opacity:.8}.tree-entity-placeholder .tree-group-header .label{color:var(--text-muted)}.tree-entity-placeholder .tree-group-header .icon{opacity:.45}.tree-entity-placeholder .tree-group-header .count{opacity:.5}.tree-dev-badge{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-base);border:1px solid var(--border-subtle);letter-spacing:.03em;white-space:nowrap;opacity:.7;border-radius:8px;margin-left:auto;padding:1px 6px;font-size:9px;font-weight:500}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.screenplay-layout{flex:1;min-height:0;display:flex;overflow:hidden}.panel-navigator{background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:260px;min-width:180px;max-width:500px;display:flex;position:relative}.navigator-scroll{flex:1;padding:8px 0;overflow-y:auto}.panel-navigator .panel-resize-handle{cursor:col-resize;z-index:10;background:0 0;width:6px;height:100%;transition:background .15s;position:absolute;top:0;right:-3px}.panel-navigator .panel-resize-handle:hover,.panel-navigator .panel-resize-handle.dragging{background:var(--accent)}.nav-section{margin-bottom:2px}.nav-section-header{cursor:pointer;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;user-select:none;align-items:center;gap:6px;padding:6px 12px;font-size:11px;font-weight:600;transition:color .15s;display:flex}.nav-section-header:hover{color:var(--text-primary)}.nav-section-header .chevron{font-size:9px;transition:transform .15s;display:inline-block}.nav-section.collapsed .nav-section-header .chevron{transform:rotate(-90deg)}.nav-section-items{padding:0 12px 4px 24px}.nav-section.collapsed .nav-section-items{display:none}.nav-empty-msg{color:var(--text-muted);font-size:11px;font-style:italic}.nav-item{cursor:pointer;color:var(--text-secondary);user-select:none;white-space:nowrap;border-radius:4px;align-items:center;gap:6px;padding:3px 8px;font-size:12px;transition:background .1s,color .1s;display:flex;overflow:hidden}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-subtle);color:var(--text-accent);font-weight:500}.nav-item.filtered-out{display:none}.nav-item.unmapped{opacity:.55}.nav-scene-num{font-family:var(--font-mono);color:var(--text-muted);text-align:right;flex-shrink:0;min-width:26px;font-size:10px}.nav-item-name{text-overflow:ellipsis;flex:1;overflow:hidden}.nav-item-badge{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-input,var(--bg-base));border-radius:3px;flex-shrink:0;padding:0 4px;font-size:10px;line-height:16px}.nav-item-icon{flex-shrink:0;font-size:11px}.nav-item-link{color:var(--text-muted);opacity:0;flex-shrink:0;padding:0 2px;font-size:10px;text-decoration:none;transition:opacity .15s}.nav-item:hover .nav-item-link{opacity:1}.nav-item-link:hover{color:var(--accent)}.nav-section-header .nav-count-badge{font-family:var(--font-mono);color:var(--text-muted);margin-left:auto;font-size:10px}.nav-section-header .nav-filter-indicator{color:var(--accent);margin-left:4px;font-size:9px;display:none}.nav-section-header .nav-filter-indicator.active{display:inline}.status-chars{text-overflow:ellipsis;white-space:nowrap;max-width:280px;overflow:hidden}.panel-screenplay{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.panel-screenplay .cm-editor{flex:1;overflow:hidden}.panel-screenplay .cm-scroller{overflow:auto!important}.screenplay-status-bar{background:var(--bg-surface);border-top:1px solid var(--border);height:28px;min-height:28px;font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:0;padding:0 12px;font-size:11px;display:flex}.status-item{padding:0 10px}.status-divider{background:var(--border);width:1px;height:14px}.status-mode-item{color:var(--text-accent);letter-spacing:.03em;font-weight:600}.screenplay-empty{flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.screenplay-empty-card{background:var(--bg-surface);border:1px solid var(--border);text-align:center;border-radius:12px;width:100%;max-width:640px;padding:40px 48px}.screenplay-empty-card h2{color:var(--text-primary);margin:0 0 8px;font-size:20px;font-weight:600}.screenplay-empty-desc{color:var(--text-secondary);margin:0 0 32px;font-size:14px;line-height:1.5}.screenplay-empty-options{text-align:left;grid-template-columns:1fr 1fr;gap:20px;display:grid}.screenplay-option{background:var(--bg-raised);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:8px;padding:24px;display:flex}.screenplay-option-icon{font-size:24px;line-height:1}.screenplay-option h3{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.screenplay-option p{color:var(--text-secondary);flex:1;margin:0;font-size:12px;line-height:1.5}.screenplay-option code{background:var(--bg-input);border-radius:3px;padding:1px 4px;font-size:11px}.screenplay-file-label{cursor:pointer;text-align:center;margin-top:4px}.screenplay-option .btn{align-self:flex-start;margin-top:4px}.cm-editor{background:var(--bg-base);color:var(--text-primary);font-family:Courier Prime,Courier New,Courier,monospace;font-size:15px;line-height:1.5}.cm-editor .cm-content{caret-color:var(--accent);padding:24px 0}.cm-editor .cm-cursor,.cm-editor .cm-dropCursor{border-left-color:var(--accent);border-left-width:2px}.cm-editor .cm-selectionBackground,.cm-editor.cm-focused .cm-selectionBackground{background:var(--accent-subtle)!important}.cm-editor .cm-activeLine{background:#2a2a384d}.cm-editor .cm-gutters,.cm-editor .cm-lineNumbers{display:none}.cm-editor .cm-scroller{padding:24px 0;overflow:auto}.cm-editor .cm-content{border-left:1px solid #ffffff0a;border-right:1px solid #ffffff0a;max-width:680px;margin:0 auto;padding:24px 20px}.cm-line.cm-scf-pagebreak{border-bottom:1px dashed #ffffff1f;margin-bottom:14px;position:relative;padding-bottom:14px!important}.cm-line.cm-scf-pagebreak:after{content:attr(data-page);font-family:var(--font-mono,monospace);color:var(--text-muted);opacity:.5;pointer-events:none;font-size:10px;position:absolute;bottom:-9px;right:-20px}.cm-line.cm-scf-heading{letter-spacing:.03em;color:var(--text-primary);background:#ffffff12;margin-left:-20px;margin-right:-20px;padding:12px 20px 4px;font-weight:700}.cm-line.cm-scf-character{color:var(--text-accent);padding-left:35%}.cm-line.cm-scf-dialogue{color:#b8b8f7;padding-left:20%;padding-right:20%}.cm-line.cm-scf-parenthetical{color:var(--text-secondary);padding-left:28%;padding-right:28%;font-style:italic}.cm-line.cm-scf-transition{text-align:right;color:var(--text-muted)}.cm-line.cm-scf-titleKey{color:var(--text-muted)}.cm-line.cm-scf-titleValue{color:var(--text-secondary)}.cm-line.cm-scf-section{color:var(--text-secondary);font-weight:700}.cm-line.cm-scf-synopsis{color:var(--text-muted);font-style:italic}.cm-line.cm-scf-centered{text-align:center}.cm-line.cm-scf-boneyard{color:var(--text-muted);opacity:.4}.cm-line.cm-scf-gap-scene{border-top:1px solid #ffffff0f;padding-top:28px!important}.cm-content>.cm-line.cm-scf-gap-scene:first-child{border-top:none;padding-top:0!important}.cm-line.cm-scf-gap-block{padding-top:18px!important}.cm-line.cm-scf-gap-element{padding-top:14px!important}.cm-editor.mode-scene .cm-line.cm-activeLine{margin-left:-20px;margin-right:-20px;text-align:left!important;letter-spacing:.03em!important;color:var(--text-primary)!important;background:#ffffff12!important;padding:12px 20px 4px!important;font-style:normal!important;font-weight:700!important}.cm-editor.mode-character .cm-line.cm-activeLine{text-align:left!important;color:var(--text-accent)!important;letter-spacing:normal!important;background:#2a2a384d!important;padding-left:35%!important;padding-right:0!important;font-style:normal!important;font-weight:700!important}.cm-editor.mode-dialogue .cm-line.cm-activeLine{text-align:left!important;color:#b8b8f7!important;letter-spacing:normal!important;background:#2a2a384d!important;padding-left:20%!important;padding-right:20%!important;font-style:normal!important;font-weight:400!important}.cm-editor.mode-transition .cm-line.cm-activeLine{text-align:right!important;color:var(--text-muted)!important;letter-spacing:normal!important;background:#2a2a384d!important;padding-left:0!important;padding-right:0!important;font-style:normal!important;font-weight:400!important}.cm-editor.mode-description .cm-line.cm-activeLine{text-align:left!important;color:var(--text-primary)!important;letter-spacing:normal!important;background:#2a2a384d!important;padding-left:0!important;padding-right:0!important;font-style:normal!important;font-weight:400!important}.cm-fountain-heading{color:var(--text-primary);font-weight:700}.cm-fountain-character{color:var(--text-accent,#8b8bff)}.cm-fountain-dialogue{color:#b8b8f7}.cm-fountain-parenthetical{color:var(--text-secondary);font-style:italic}.cm-fountain-transition{color:var(--text-muted)}.cm-fountain-note{color:var(--text-muted);opacity:.5}.cm-fountain-boneyard{color:var(--text-muted);opacity:.4}.cm-fountain-centered{color:var(--text-primary)}.cm-fountain-synopsis{color:var(--text-muted);font-style:italic}.cm-fountain-section{color:var(--text-secondary);font-weight:700}.cm-fountain-titleKey{color:var(--text-muted)}.cm-fountain-titleValue{color:var(--text-secondary)}.screenplay-autocomplete{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:100;min-width:200px;max-width:400px;max-height:240px;position:fixed;overflow-y:auto}.screenplay-autocomplete.hidden{display:none}.screenplay-ac-item{cursor:pointer;color:var(--text-primary);align-items:center;gap:8px;padding:6px 12px;font-size:13px;transition:background .1s;display:flex}.screenplay-ac-item:hover,.screenplay-ac-item.highlighted{background:var(--bg-hover)}.screenplay-ac-item.highlighted{background:var(--accent-subtle);color:var(--text-accent)}.screenplay-ac-icon{flex-shrink:0;font-size:12px}.screenplay-ac-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.screenplay-ac-meta{color:var(--text-muted);font-size:11px;font-family:var(--font-mono);flex-shrink:0}.screenplay-ac-new{color:var(--success);padding:6px 12px;font-size:11px;font-style:italic}.screenplay-load-error{color:var(--text-muted);flex:1;justify-content:center;align-items:center;padding:40px;font-size:14px;display:flex}.toast{background:var(--bg-raised);color:var(--text-primary);border:1px solid var(--border);z-index:1000;pointer-events:none;border-radius:6px;padding:8px 16px;font-size:13px;animation:.2s toast-in,.3s 2.2s forwards toast-out;position:fixed;bottom:48px;left:50%;transform:translate(-50%)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toast-out{0%{opacity:1}to{opacity:0}}.help-modal-overlay{z-index:500;backdrop-filter:blur(2px);background:#0009;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.help-modal-overlay.active{display:flex}.help-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg,10px);flex-direction:column;width:680px;max-width:90vw;max-height:85vh;animation:.2s help-modal-in;display:flex;overflow:hidden;box-shadow:0 16px 64px #00000080}@keyframes help-modal-in{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.help-modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.help-modal-header h2{color:var(--text-primary);margin:0;font-size:16px;font-weight:600}.help-modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:22px;line-height:1;transition:all .15s}.help-modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.help-modal-body{color:var(--text-secondary);padding:20px 24px 28px;font-size:13px;line-height:1.6;overflow-y:auto}.help-modal-body h3{color:var(--text-primary);border-bottom:1px solid var(--border-subtle,#252535);margin:24px 0 8px;padding-bottom:6px;font-size:14px;font-weight:600}.help-modal-body h3:first-child{margin-top:0}.help-modal-body p{margin:6px 0}.help-modal-body ul,.help-modal-body ol{margin:8px 0;padding-left:20px}.help-modal-body li{margin:4px 0}.help-modal-body code{background:var(--bg-input,#16161e);font-family:var(--font-mono,monospace);color:var(--text-accent);border-radius:3px;padding:1px 5px;font-size:12px}.help-modal-body kbd{background:var(--bg-raised,#22222e);border:1px solid var(--border);font-family:var(--font-mono,monospace);color:var(--text-primary);border-radius:4px;padding:1px 6px;font-size:11px;line-height:1.6;display:inline-block;box-shadow:0 1px 2px #0000004d}.help-modal-body strong{color:var(--text-primary)}.help-dl{grid-template-columns:auto 1fr;gap:6px 16px;margin:8px 0;display:grid}.help-dl dt{color:var(--text-accent);white-space:nowrap;padding-top:1px;font-weight:600}.help-dl dd{margin:0}.help-shortcuts{border-collapse:collapse;width:100%;margin:8px 0}.help-shortcuts td{border-bottom:1px solid var(--border-subtle,#252535);padding:5px 0}.help-shortcuts td:first-child{width:120px;padding-right:16px}.version-drawer-overlay{z-index:200;backdrop-filter:blur(2px);background:#00000080;display:none;position:fixed;inset:0}.version-drawer-overlay.active{display:block}.version-drawer{background:var(--bg-surface);border-left:1px solid var(--border);z-index:201;flex-direction:column;width:420px;height:100vh;transition:right .25s;display:flex;position:fixed;top:0;right:-420px;box-shadow:-8px 0 32px #0006}.version-drawer.open{right:0}.version-drawer-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.version-drawer-header h2{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.version-drawer-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:20px;line-height:1;transition:all .15s}.version-drawer-close:hover{background:var(--bg-hover);color:var(--text-primary)}.version-drawer-body{flex:1;padding:16px 20px;overflow-y:auto}.version-publish-form{border-bottom:1px solid var(--border-subtle);gap:8px;margin-bottom:20px;padding-bottom:16px;display:flex}.version-publish-form input{flex:1;padding:8px 12px;font-size:13px}.version-publish-form .btn{flex-shrink:0}.version-list{flex-direction:column;gap:8px;display:flex}.version-empty{text-align:center;color:var(--text-muted);padding:24px 0;font-size:13px;font-style:italic}.version-item{background:var(--bg-raised);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:12px 14px;transition:border-color .15s}.version-item:hover{border-color:var(--border)}.version-item-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.version-item-number{font-family:var(--font-mono);color:var(--text-accent);background:var(--accent-subtle);border-radius:10px;flex-shrink:0;padding:2px 8px;font-size:12px;font-weight:600}.version-item-desc{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:500;overflow:hidden}.version-item-date{font-family:var(--font-mono);color:var(--text-muted);flex-shrink:0;font-size:11px}.version-item-stats{color:var(--text-muted);font-size:11px;font-family:var(--font-mono);gap:12px;margin-bottom:8px;display:flex}.version-item-stat{align-items:center;gap:3px;display:flex}.version-item-actions{gap:6px;display:flex}.version-item-actions .btn{padding:3px 10px;font-size:11px}.version-restore-btn{background:var(--accent-subtle);border-color:var(--accent);color:var(--text-accent)}.version-restore-btn:hover{background:var(--accent);color:#fff}.version-delete-btn{border-color:var(--border);color:var(--text-muted);background:0 0}.version-delete-btn:hover{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.btn-publish{background:var(--bg-raised);border-color:var(--border);color:var(--text-secondary)}.btn-publish:hover{background:var(--accent-subtle);border-color:var(--accent);color:var(--text-accent)}.cm-prop-highlight{cursor:default;border-bottom:1.5px dotted #e6a93cb3;border-radius:1px;transition:background .15s,border-color .15s}.cm-prop-highlight:hover{background:#e6a93c1a;border-bottom-color:#e6a93c}.nav-item.nav-prop-item .nav-item-icon{font-size:11px}.prop-tag-popover{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:100;min-width:220px;max-width:360px;position:fixed;overflow:hidden}.prop-tag-popover.hidden{display:none}.prop-tag-popover-header{border-bottom:1px solid var(--border-subtle);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:6px;padding:8px 12px;font-size:11px;font-weight:600;display:flex}.prop-tag-popover-header .prop-tag-text{color:#e6a93c;text-transform:none;letter-spacing:normal;font-size:12px;font-weight:700}.prop-tag-popover .screenplay-ac-item{padding:6px 12px}.prop-tag-popover .screenplay-ac-new{color:var(--success);cursor:pointer;padding:6px 12px;font-size:11px;transition:background .1s}.prop-tag-popover .screenplay-ac-new:hover{background:var(--bg-hover)}.prop-tag-remove{color:var(--danger);cursor:pointer;border-top:1px solid var(--border-subtle);align-items:center;gap:6px;padding:6px 12px;font-size:12px;transition:background .1s;display:flex}.prop-tag-remove:hover{background:var(--danger-bg)}.nav-sort-toggle{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-base);border:1px solid var(--border-subtle);cursor:pointer;user-select:none;letter-spacing:.03em;border-radius:3px;flex-shrink:0;margin-left:6px;padding:1px 5px;font-size:9px;font-weight:600;transition:all .15s}.nav-sort-toggle:hover{color:var(--text-accent);border-color:var(--accent);background:var(--accent-subtle)}.tree-tooltip{z-index:200;max-width:280px;font-family:var(--font-sans);color:var(--text-secondary);background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);white-space:normal;pointer-events:none;opacity:0;padding:8px 12px;font-size:12px;font-weight:400;line-height:1.45;transition:opacity .15s;position:fixed}.tree-tooltip.visible{opacity:1}.image-upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;background:var(--bg-input);margin-bottom:24px;padding:28px 20px;transition:all .2s;position:relative}.image-upload-zone:hover{border-color:var(--accent);background:var(--accent-subtle)}.image-upload-zone.drag-over{border-color:var(--accent);background:var(--accent-subtle);box-shadow:0 0 0 3px var(--accent-glow)}.image-upload-zone input[type=file]{display:none}.image-upload-icon{opacity:.6;margin-bottom:8px;font-size:28px}.image-upload-text{color:var(--text-secondary);font-size:13px;line-height:1.5}.image-upload-text strong{color:var(--text-accent)}.image-upload-hint{color:var(--text-muted);margin-top:4px;font-size:11px}.image-upload-progress{color:var(--text-accent);margin-top:8px;font-size:12px;display:none}.image-upload-zone.uploading .image-upload-progress{display:block}.image-upload-zone.uploading .image-upload-text{display:none}.image-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.image-grid-empty{text-align:center;color:var(--text-muted);padding:32px 20px;font-size:13px;font-style:italic}.image-card{background:var(--bg-raised);border:1px solid var(--border-subtle);border-radius:var(--radius);flex-direction:column;transition:border-color .15s;display:flex;overflow:hidden}.image-card-thumb{aspect-ratio:4/3;background:var(--bg-base);cursor:pointer;position:relative;overflow:hidden}.image-card-thumb img{object-fit:cover;width:100%;height:100%;transition:transform .2s;display:block}.image-card-thumb:hover img{transform:scale(1.03)}.image-card-thumb .image-card-zoom{color:#fff;cursor:pointer;opacity:0;background:#0009;border:none;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;transition:opacity .15s;display:flex;position:absolute;top:8px;right:8px}.image-card-thumb:hover .image-card-zoom{opacity:1}.image-card-body{flex-direction:column;flex:1;gap:6px;padding:10px 12px;display:flex}.image-card-desc{width:100%;font-size:12px;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);resize:vertical;outline:none;min-height:36px;max-height:80px;padding:6px 8px;line-height:1.4;transition:border-color .15s}.image-card-desc:focus{border-color:var(--border-focus);box-shadow:0 0 0 2px var(--accent-glow)}.image-card-desc::placeholder{color:var(--text-muted);opacity:.7}.image-card-footer{justify-content:space-between;align-items:center;padding:0 12px 8px;display:flex}.image-card-filename{font-family:var(--font-mono);color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:10px;overflow:hidden}.image-card-delete{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;padding:2px 6px;font-size:14px;transition:all .15s}.image-card-delete:hover{background:var(--danger-bg);color:var(--danger)}.image-card-missing{color:var(--text-muted);justify-content:center;align-items:center;font-size:12px;font-style:italic;display:flex}.image-lightbox-overlay{z-index:600;backdrop-filter:blur(4px);cursor:pointer;background:#000000d9;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.image-lightbox-overlay.active{display:flex}.image-lightbox-content{cursor:default;max-width:90vw;max-height:90vh;position:relative}.image-lightbox-content img{object-fit:contain;border-radius:var(--radius);max-width:90vw;max-height:85vh;display:block;box-shadow:0 16px 64px #0009}.image-lightbox-close{color:#fff;cursor:pointer;opacity:.7;background:0 0;border:none;padding:4px 8px;font-size:28px;transition:opacity .15s;position:absolute;top:-40px;right:0}.image-lightbox-close:hover{opacity:1}.image-lightbox-caption{text-align:center;color:#ffffffb3;max-width:600px;margin-top:12px;margin-left:auto;margin-right:auto;font-size:13px}.image-lightbox-nav{color:#fff;cursor:pointer;border-radius:var(--radius);opacity:.6;background:#00000080;border:none;padding:12px 16px;font-size:24px;transition:opacity .15s,background .15s;position:absolute;top:50%;transform:translateY(-50%)}.image-lightbox-nav:hover{opacity:1;background:#000000b3}.image-lightbox-prev{left:-60px}.image-lightbox-next{right:-60px}.tab-image-count{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-base);border-radius:8px;margin-left:6px;padding:1px 6px;font-size:10px}.app-container{background:var(--bg-base);height:100vh;color:var(--text-primary);flex-direction:column;display:flex;overflow:hidden}.main-header{border-bottom:1px solid var(--border);background:var(--bg-surface);z-index:100;justify-content:space-between;align-items:center;height:48px;min-height:48px;padding:0 16px;display:flex}.header-left,.header-right{align-items:center;gap:12px;display:flex}.logo{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text-accent);align-items:center;gap:8px;font-size:12px;font-weight:600;display:flex}.header-nav{gap:4px;display:flex}.nav-link{border-radius:var(--radius);color:var(--text-secondary);transition:all var(--transition);align-items:center;gap:8px;padding:6px 12px;font-size:13px;font-weight:500;text-decoration:none;display:flex}.nav-link:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-link.active{background:var(--accent-subtle);color:var(--text-accent)}.main-content{flex:1;display:flex;overflow:hidden}.sidebar{border-right:1px solid var(--border);background:var(--bg-surface);flex-direction:column;width:280px;transition:width .1s;display:flex;position:relative;overflow:visible}.sidebar-resizer{cursor:col-resize;z-index:10;width:6px;height:100%;transition:background .2s;position:absolute;top:0;right:-3px}.sidebar-resizer:hover{background:var(--accent)}.sidebar.closed{border-right:none;width:0}.content-area{background:var(--bg-base);flex:1;overflow-y:auto}.sidebar-tree{flex-direction:column;height:100%;display:flex}.sidebar-search{border-bottom:1px solid var(--border-subtle);padding:12px}.search-input-container{align-items:center;display:flex;position:relative}.search-icon{color:var(--text-muted);position:absolute;left:10px}.search-input-container input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);outline:none;padding:6px 12px 6px 32px;font-size:13px}.search-input-container input:focus{border-color:var(--border-focus)}.tree-content{flex:1;padding:8px 0;overflow-y:auto}.tree-node{cursor:pointer;color:var(--text-secondary);transition:all var(--transition);align-items:center;gap:8px;padding:5px 12px;font-size:13px;text-decoration:none;display:flex}.tree-node:hover{background:var(--bg-hover);color:var(--text-primary)}.tree-node.active{background:var(--accent-subtle);color:var(--text-accent);font-weight:500}.category-node{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;cursor:default;padding-top:12px;font-size:11px;font-weight:600}.category-node:hover{background:0 0}.type-node{padding-left:16px;font-weight:500}.entity-node{padding-left:40px}.node-icon{color:var(--text-muted)}.tree-node.active .node-icon{color:var(--text-accent)}.add-button{opacity:0;cursor:pointer;color:var(--text-muted);transition:all var(--transition);background:0 0;border:none;margin-left:auto;padding:2px;display:flex}.tree-node:hover .add-button{opacity:1}.add-button:hover{color:var(--accent)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:500px;max-width:90vw;box-shadow:var(--shadow-lg);padding:24px}.modal-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;display:flex}.modal-title{color:var(--text-primary);font-size:18px;font-weight:600}.close-button{color:var(--text-muted);cursor:pointer;background:0 0;border:none}.close-button:hover{color:var(--text-primary)}.placeholder-view{max-width:1000px;margin:0 auto;padding:40px}.empty-state{height:100%;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex}.empty-state-icon{opacity:.3;margin-bottom:24px}.empty-state h2{color:var(--text-secondary);margin-bottom:8px;font-size:20px;font-weight:500}.empty-state p{max-width:300px;font-size:14px;line-height:1.5}.placeholder-header{border-bottom:1px solid var(--border-subtle);margin-bottom:32px;padding-bottom:16px}.placeholder-header h1{color:var(--text-primary);margin-bottom:8px;font-size:24px;font-weight:700}.placeholder-header p{color:var(--text-secondary);font-size:14px}.placeholder-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;color:var(--text-muted);padding:32px}.global-search-container{align-items:center;width:300px;margin:0 20px;display:flex;position:relative}.global-search-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);transition:all var(--transition);outline:none;padding:6px 12px 6px 36px;font-size:13px}.global-search-input:focus{border-color:var(--border-focus);background:var(--bg-surface);width:400px;box-shadow:var(--shadow-md);margin-left:-50px;margin-right:-50px}.global-search-icon{color:var(--text-muted);pointer-events:none;z-index:10;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.icon-button{color:var(--text-secondary);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:6px;display:flex}.icon-button:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border)}.global-search-results{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1000;max-height:400px;padding:8px 0;position:absolute;top:calc(100% + 8px);left:-50px;right:-50px;overflow-y:auto}.search-result-item{cursor:pointer;color:var(--text-primary);transition:background var(--transition);align-items:center;gap:12px;padding:10px 16px;text-decoration:none;display:flex}.search-result-item:hover,.search-result-item.selected{background:var(--bg-hover)}.search-result-icon{justify-content:center;width:24px;font-size:16px;display:flex}.search-result-info{flex-direction:column;display:flex}.search-result-name{font-size:13px;font-weight:500}.search-result-type{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.search-no-results{text-align:center;color:var(--text-muted);padding:20px;font-size:13px}.image-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-top:8px;display:grid}.image-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);transition:transform .2s,border-color .2s;overflow:hidden}.image-card:hover{border-color:var(--border-focus)}.image-preview{aspect-ratio:16/9;background:#000;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.image-preview img{object-fit:contain;max-width:100%;max-height:100%}.image-delete{color:#fff;cursor:pointer;opacity:0;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;transition:opacity .2s;display:flex;position:absolute;top:8px;right:8px}.image-card:hover .image-delete{opacity:1}.image-delete:hover{background:var(--danger)}.image-info{padding:8px}.image-info input{width:100%;color:var(--text-primary);background:0 0;border:none;border-bottom:1px solid #0000;outline:none;padding:4px 0;font-size:11px}.image-info input:focus{border-bottom-color:var(--accent)}.scene-link-card:hover{border-color:var(--border-focus)!important;background:var(--bg-hover)!important}.query-explorer{height:100%;display:flex;overflow:hidden}.query-sidebar{border-right:1px solid var(--border);background:var(--bg-surface);flex-direction:column;flex-shrink:0;width:260px;display:flex}.sidebar-section{border-bottom:1px solid var(--border-subtle);padding:16px}.sidebar-section.inputs{flex:1;overflow-y:auto}.sidebar-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:12px;font-size:11px;font-weight:600;display:block}.query-nav{flex-direction:column;gap:4px;display:flex}.query-nav-item{border-radius:var(--radius);color:var(--text-secondary);text-align:left;cursor:pointer;transition:all var(--transition);background:0 0;border:none;align-items:center;gap:10px;padding:8px 12px;font-size:13px;display:flex}.query-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.query-nav-item.active{background:var(--accent-subtle);color:var(--text-accent);font-weight:500}.input-group{margin-bottom:16px}.input-group label{color:var(--text-secondary);margin-bottom:6px;font-size:12px;display:block}.input-group select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);outline:none;padding:8px;font-size:13px}.query-results-area{background:var(--bg-base);flex:1;padding:24px;overflow-y:auto}.results-empty{height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.results-content{max-width:1200px;margin:0 auto}.query-table-container{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.query-table{border-collapse:collapse;width:100%;font-size:13px}.query-table th{text-align:left;background:var(--bg-hover);color:var(--text-secondary);border-bottom:1px solid var(--border);padding:12px 16px;font-weight:600}.query-table td{border-bottom:1px solid var(--border-subtle);color:var(--text-primary);padding:12px 16px}.query-table tr:last-child td{border-bottom:none}.tag-cloud{flex-wrap:wrap;gap:4px;display:flex}.mini-tag{background:var(--bg-input);border:1px solid var(--border);color:var(--text-secondary);border-radius:4px;padding:2px 6px;font-size:11px}.mini-tag.prop{color:#a78bfa;background:#8b5cf61a;border-color:#8b5cf633}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px;display:grid}.stats-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;padding:20px}.stats-label{color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;font-size:12px}.stats-value{color:var(--text-accent);font-size:28px;font-weight:700}.stats-sections{grid-template-columns:1fr 1fr;gap:24px;display:grid}.stats-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.stats-section h3{color:var(--text-primary);margin-bottom:16px;font-size:14px}.stats-list{flex-direction:column;gap:8px;display:flex}.stats-list-item{background:var(--bg-base);border:1px solid var(--border-subtle);border-radius:var(--radius);color:var(--text-primary);justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;text-decoration:none;display:flex}.stats-list-item.clickable:hover{border-color:var(--accent);background:var(--bg-hover)}.scene-context-results{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px}.context-header{border-bottom:1px solid var(--border-subtle);margin-bottom:32px;padding-bottom:16px}.context-title{align-items:center;gap:16px;margin-bottom:8px;display:flex}.context-title h2{margin:0;font-size:24px}.context-location{color:var(--text-secondary);align-items:center;gap:8px;font-size:14px;display:flex}.context-grid{grid-template-columns:1.5fr 1fr 1fr;gap:32px;display:grid}.context-block h3{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;margin-bottom:12px;font-size:12px}.context-text{color:var(--text-primary);font-size:14px;line-height:1.6}.context-text.italic{color:var(--text-secondary);font-style:italic}.context-list{flex-direction:column;gap:12px;display:flex}.context-list-item{background:var(--bg-base);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:10px}.context-list-item strong{margin-bottom:4px;font-size:13px;display:block}.sub-note{color:var(--text-muted);border-top:1px solid var(--border-subtle);margin-top:4px;padding-top:4px;font-size:11px}.badge.prop{color:#a78bfa;background:#8b5cf61a}.stats-section.warning h3{color:var(--accent-red)}.stats-empty{text-align:center;color:var(--text-muted);background:var(--bg-base);border:1px dashed var(--border);border-radius:var(--radius);padding:12px;font-size:12px}
