*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #000000;--color-surface: #0d1117;--color-surface2: #161b22;--color-border: #21262d;--color-text: #e6edf3;--color-muted: #8b949e;--color-accent: #3b82f6;--color-accent-h: #60a5fa;--color-cta: #f97316;--color-cta-h: #fb923c;--color-danger: #f85149;--color-success: #3fb950;--color-warning: #d29922;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow: 0 2px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .6);--transition: .2s ease;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.6}body{background:var(--color-bg);color:var(--color-text);min-height:100vh}a{color:var(--color-accent);text-decoration:none}a:hover{color:var(--color-accent-h);text-decoration:underline}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid transparent;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:background var(--transition),border-color var(--transition),opacity var(--transition),transform .15s ease,box-shadow var(--transition);text-decoration:none;white-space:nowrap;letter-spacing:.01em}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:not(:disabled):active{transform:scale(.97)}.btn-primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.btn-primary:hover:not(:disabled){background:var(--color-accent-h);box-shadow:0 0 0 3px #2563eb40}.btn-cta{background:var(--color-cta);color:#fff;border-color:var(--color-cta)}.btn-cta:hover:not(:disabled){background:var(--color-cta-h);box-shadow:0 0 0 3px #f9731640}.btn-secondary{background:var(--color-surface2);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-border);border-color:var(--color-muted)}.btn-ghost{background:transparent;color:var(--color-muted);border-color:transparent}.btn-ghost:hover:not(:disabled){color:var(--color-text);background:var(--color-surface2)}.btn-danger{background:#f851491f;color:var(--color-danger);border-color:#f851494d}.btn-danger:hover:not(:disabled){background:#f8514933}.btn-success{background:#3fb9501f;color:var(--color-success);border-color:#3fb9504d}.btn-success:hover:not(:disabled){background:#3fb95033}.btn-sm{padding:.3rem .65rem;font-size:.8rem}label{display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;color:var(--color-muted);font-weight:500}label small{font-weight:400;color:var(--color-muted)}input[type=text],input[type=email],input[type=password],input[type=search],input[type=number],input[type=url],select,textarea{background:var(--color-surface2);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);padding:.5rem .75rem;font-size:.9rem;font-family:inherit;width:100%;transition:border-color var(--transition),box-shadow var(--transition)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #2563eb26}input[type=search]{max-width:280px}.form-error{background:#e052521f;border:1px solid var(--color-danger);border-radius:var(--radius);color:var(--color-danger);padding:.6rem .9rem;font-size:.875rem}.form-actions{display:flex;gap:.6rem;align-items:center;margin-top:.5rem}.page{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.page-narrow{max-width:520px}.page-wide{max-width:1400px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.page-header h1{font-size:1.5rem;font-weight:600;color:var(--color-text)}.page-header-actions,.entity-nav{display:flex;gap:.5rem;flex-wrap:wrap}.auth-layout{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.auth-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;width:100%;max-width:420px;display:flex;flex-direction:column;gap:1rem;box-shadow:var(--shadow)}.auth-form h1{font-size:1.4rem;font-weight:700}.auth-form p{font-size:.875rem;color:var(--color-muted)}.auth-form a{color:var(--color-accent)}.badge{display:inline-block;padding:.15rem .5rem;border-radius:99px;font-size:.75rem;font-weight:600;background:var(--color-surface2);color:var(--color-muted);border:1px solid var(--color-border)}.badge-role{background:#4a90a426;color:var(--color-accent)}.badge-canonical{background:#4caf8226;color:var(--color-success)}.badge-ai{background:#e0a03026;color:var(--color-warning)}.badge-draft{color:var(--color-muted)}.badge-published{background:#4caf8226;color:var(--color-success)}.badge-archived{background:#e052521a;color:var(--color-danger)}.badge-bi{background:#4a90a433;color:var(--color-accent)}.badge-dir{font-size:.75rem;padding:.1rem .3rem;min-width:1.2rem;text-align:center}.world-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.world-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.2rem;cursor:pointer;transition:border-color .15s,transform .1s}.world-card:hover{border-color:var(--color-accent);transform:translateY(-1px)}.world-card-title{font-size:1.05rem;font-weight:600;margin-bottom:.4rem}.world-card-meta{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.5rem}.world-card-desc{font-size:.85rem;color:var(--color-muted)}.filter-bar{display:flex;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap;align-items:center}.filter-bar select{width:auto}.entity-list{list-style:none;display:flex;flex-direction:column;gap:.4rem}.entity-row{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:.75rem 1rem;transition:border-color .15s}.entity-row:hover{border-color:var(--color-accent)}.entity-row a{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--color-text)}.entity-name{font-weight:500;flex:1}.entity-summary{font-size:.8rem;color:var(--color-muted);margin-top:.25rem}.entity-detail-grid{display:grid;grid-template-columns:240px 1fr 280px;gap:1.5rem;align-items:start}@media(max-width:900px){.entity-detail-grid{grid-template-columns:1fr}}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem}.panel h2{font-size:1rem;font-weight:600;margin-bottom:.75rem;color:var(--color-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem}.panel h3{font-size:.9rem;font-weight:600;margin:1rem 0 .5rem}.meta-badges{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.75rem}.attr-table{width:100%;font-size:.85rem;border-collapse:collapse}.attr-table th{text-align:left;color:var(--color-muted);font-weight:500;padding:.3rem .5rem .3rem 0;width:40%}.attr-table td{padding:.3rem 0}.attr-section-header{display:flex;align-items:center;justify-content:space-between;margin:.75rem 0 .35rem}.attr-section-header h3{margin:0}.attr-edit-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.5rem}.attr-edit-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:.4rem;padding:.5rem}.attr-edit-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}.attr-edit-card-num{font-size:.7rem;font-weight:600;color:var(--color-muted)}.attr-edit-label{display:flex;flex-direction:column;gap:.15rem;font-size:.75rem;color:var(--color-muted);margin-bottom:.35rem}.attr-edit-label:last-child{margin-bottom:0}.attr-edit-key,.attr-edit-value,.attr-edit-type{font:inherit;font-size:.8rem;background:var(--color-surface, var(--color-bg));border:1px solid var(--color-border);border-radius:.3rem;padding:.3rem .4rem;color:var(--color-text);width:100%;box-sizing:border-box}.attr-edit-value[rows]{resize:vertical}.attr-edit-type{font-size:.75rem}.attr-edit-actions{display:flex;gap:.15rem}.attr-add-btn{margin-top:.1rem;font-size:.8rem}.tag-list{display:flex;gap:.4rem;flex-wrap:wrap}.tag{display:inline-block;padding:.2rem .6rem;border-radius:99px;font-size:.75rem;font-weight:600;color:#fff}.notes-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.note-card{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius);padding:.75rem}.note-card.note-canonical{border-color:#4caf8266}.note-card.note-ai{border-color:#e0a0304d}.note-badges{display:flex;gap:.3rem;margin-bottom:.4rem}.note-body{font-size:.875rem}.note-body p{margin-bottom:.5em}.note-body p:last-child{margin-bottom:0}.note-body h1,.note-body h2,.note-body h3{margin:.75em 0 .3em;font-weight:600}.note-body code{background:var(--color-bg);padding:.1em .3em;border-radius:3px;font-size:.85em}.note-body pre{background:var(--color-bg);padding:.75rem;border-radius:var(--radius);overflow-x:auto;margin:.5em 0}.note-footer{display:flex;gap:.75rem;align-items:center;font-size:.75rem;color:var(--color-muted);margin-top:.5rem}.note-add{display:flex;flex-direction:column;gap:.5rem}.note-add textarea{resize:vertical}.note-edit-area{width:100%;resize:vertical;font:inherit;font-size:.875rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:.5rem;color:var(--color-text);box-sizing:border-box}.entity-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem}.entity-header-row h1{font-size:1.4rem;margin:0 0 .35rem}.entity-summary-text{font-size:.9rem;color:var(--color-muted);line-height:1.5}.detail-section{margin-bottom:1.25rem}.detail-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}.detail-section-header h2{margin-bottom:0}.lore-body{font-size:.9rem;line-height:1.6}.lore-body p{margin-bottom:.5em}.lore-body p:last-child{margin-bottom:0}.lore-body h1,.lore-body h2,.lore-body h3{margin:.75em 0 .3em;font-weight:600}.lore-body code{background:var(--color-bg);padding:.1em .3em;border-radius:3px;font-size:.85em}.lore-body pre{background:var(--color-bg);padding:.75rem;border-radius:var(--radius);overflow-x:auto;margin:.5em 0}.tag-picker{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}.tag-selectable{cursor:pointer;border:2px solid;transition:background .15s,color .15s}.tag-selectable:hover{opacity:.85}.open-points-list{display:flex;flex-direction:column;gap:.6rem}.open-point-card{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius);padding:.75rem}.op-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.3rem}.op-title{font-weight:500;font-size:.9rem;flex:1}.op-badges{display:flex;gap:.3rem;flex-shrink:0}.op-desc{font-size:.85rem;color:var(--color-muted);margin-bottom:.25rem}.op-resolution{font-size:.85rem;margin-bottom:.25rem}.op-footer{display:flex;gap:.75rem;align-items:center;font-size:.75rem;color:var(--color-muted);margin-top:.4rem}.open-point-add-form{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius);padding:.75rem;margin-bottom:.75rem}.open-point-add-form label{display:flex;flex-direction:column;gap:.15rem;font-size:.8rem;margin-bottom:.4rem}.form-row-inline{display:flex;gap:.75rem}.form-row-inline label{flex:1}.badge-op-critical{background:#e74c3c;color:#fff}.badge-op-high{background:#e67e22;color:#fff}.badge-op-medium{background:#f1c40f;color:#222}.badge-op-low{background:#95a5a6;color:#fff}.badge-op-open{background:var(--color-accent);color:#fff}.badge-op-in_progress{background:#3498db;color:#fff}.badge-op-resolved{background:#27ae60;color:#fff}.badge-op-wont_fix{background:#7f8c8d;color:#fff}.rel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.rel-header h2{margin-bottom:0}.rel-groups{display:flex;flex-direction:column;gap:.75rem}.rel-group h4{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted);margin-bottom:.35rem}.rel-group ul{list-style:none;display:flex;flex-direction:column;gap:.3rem}.rel-group li{display:flex;align-items:center;gap:.4rem;font-size:.85rem;flex-wrap:wrap}.rel-strength{font-size:.75rem;color:var(--color-muted)}.rel-actions{margin-left:auto;display:flex;gap:.2rem;opacity:0;transition:opacity .15s}.rel-group li:hover .rel-actions{opacity:1}.rel-edit-form{display:flex;flex-direction:column;gap:.5rem;margin:.5rem 0 .75rem;padding:.75rem;background:var(--color-surface2);border-radius:.4rem;border:1px solid var(--color-border);font-size:.85rem}.rel-edit-form label{display:flex;flex-direction:column;gap:.2rem}.rel-edit-form input,.rel-edit-form select,.rel-edit-form textarea{font:inherit;font-size:.85rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:.3rem;padding:.3rem .5rem;color:var(--color-text)}.rel-edit-form textarea{resize:vertical}.entity-search-wrapper{position:relative}.entity-search-wrapper input{width:100%;padding-right:2rem}.entity-search-clear{position:absolute;right:.4rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-muted);cursor:pointer;font-size:.8rem;padding:.1rem .25rem;line-height:1}.entity-search-results{position:absolute;z-index:50;top:100%;left:0;right:0;max-height:12rem;overflow-y:auto;margin:.15rem 0 0;padding:0;list-style:none;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:.3rem;box-shadow:0 4px 12px #0000004d}.entity-search-results li{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;cursor:pointer;font-size:.85rem;color:var(--color-text)}.entity-search-results li:hover,.entity-search-results li.selected{background:var(--color-primary);color:#fff}.entity-search-results li:hover .badge,.entity-search-results li.selected .badge{background:#fff3;color:#fff}.entity-search-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.entity-search-empty{position:absolute;z-index:50;top:100%;left:0;right:0;margin:.15rem 0 0;padding:.4rem .5rem;font-size:.8rem;color:var(--color-muted);background:var(--color-surface2);border:1px solid var(--color-border);border-radius:.3rem}.reltype-new-hint{font-size:.8rem;color:var(--color-primary);margin-top:.2rem}.rel-edit-inline{flex-direction:row!important;align-items:center;gap:.4rem!important}.btn-icon{background:none;border:none;cursor:pointer;color:var(--color-muted);font-size:.85rem;padding:.1rem .2rem;border-radius:.2rem;line-height:1}.btn-icon:hover{color:var(--color-text);background:var(--color-surface2)}.btn-icon--danger:hover{color:#ef4444}.tag-form.card{margin-bottom:1.5rem;padding:1.25rem}.tag-form h3{margin:0 0 .75rem}.tag-form__row{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap}.tag-form__row label{flex:1;min-width:150px}.tag-form__row--inline{align-items:center;flex-wrap:wrap;gap:.5rem;width:100%}.tag-form__color-label{max-width:160px}.tag-form__color-wrap{display:flex;align-items:center;gap:.5rem}.tag-color-input{width:36px;height:36px;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px;cursor:pointer;background:none}.tag-color-hex{font-family:monospace;font-size:.8rem;color:var(--color-text-muted)}.tag-form__preview{margin-top:.75rem;font-size:.85rem;color:var(--color-text-muted)}.tag-badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.8rem;font-weight:600;color:#fff;line-height:1.4}.tag-list--manage{display:flex;flex-direction:column;gap:.5rem}.tag-list--manage .tag-list__item.card{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem}.tag-entity-count{font-size:.85rem;color:var(--color-text-muted);text-decoration:none;margin-left:auto}.tag-entity-count:hover{color:var(--color-primary);text-decoration:underline}.tag-list__actions{display:flex;gap:.25rem;flex-shrink:0}.tag-edit-name{flex:1;min-width:120px;max-width:220px}.tag-dot{display:inline-block;width:10px;height:10px;border-radius:50%;vertical-align:middle;margin-right:.3rem}.graph-page{height:calc(100vh - 100px);display:flex;flex-direction:column;padding:1rem 1.5rem}.graph-page .page-header{margin-bottom:.75rem}.graph-container{flex:1;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);overflow:hidden}.graph-filters{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;margin-bottom:.75rem}.graph-filters-label{font-size:.85rem;font-weight:600;color:var(--color-text-muted);margin-right:.25rem}.graph-chip{padding:.25rem .65rem;border-radius:999px;border:2px solid var(--color-border);font-size:.8rem;font-weight:600;cursor:pointer;transition:opacity .15s,filter .15s;line-height:1.3}.graph-chip:hover{filter:brightness(1.15)}.graph-chip--off{background:transparent!important;color:var(--color-text-muted)!important;border-color:var(--color-border)!important;opacity:.5}.graph-chip--off:hover{opacity:.75}.timeline-selector{margin-bottom:1rem}.timeline-selector label{flex-direction:row;align-items:center;gap:.75rem}.timeline-selector select{width:auto}.timeline-container{border:1px solid var(--color-border);border-radius:var(--radius-lg);min-height:400px;overflow:hidden}.kanban-board{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.5rem}.kanban-col{flex:0 0 220px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:.9rem;min-height:400px}.kanban-col-header{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);font-weight:600;display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.kanban-cards{display:flex;flex-direction:column;gap:.5rem}.kanban-card{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius);padding:.65rem .75rem;cursor:grab;transition:border-color .15s,transform .1s}.kanban-card:hover{border-color:var(--color-accent)}.kanban-card:active{cursor:grabbing}.kanban-card-title{font-size:.875rem;font-weight:500;margin-bottom:.25rem}.kanban-card-logline{font-size:.775rem;color:var(--color-muted);margin-bottom:.2rem}.kanban-card-meta{font-size:.75rem;color:var(--color-muted)}.kanban-empty{font-size:.8rem;color:var(--color-muted);text-align:center;padding:1rem 0}.kanban-card-active{border-color:var(--color-accent);box-shadow:0 0 0 2px #3b82f633}.kanban-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.35rem}.kanban-card-delete{flex-shrink:0;padding:.1rem .3rem;font-size:.75rem;opacity:0;transition:opacity .15s}.kanban-card:hover .kanban-card-delete{opacity:1}.kanban-card-actions{margin-top:.35rem}.arc-form-panel,.tl-form-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.5rem}.arc-form-panel h2,.tl-form-panel h2{font-size:1.1rem;font-weight:600;margin-bottom:.75rem}.arc-form-panel h3,.tl-form-panel h3{font-size:.9rem;font-weight:600;margin-top:1rem;margin-bottom:.5rem;color:var(--color-muted)}.arc-form,.tl-form{display:flex;flex-direction:column;gap:.75rem}.arc-form-row,.tl-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.arc-entities{margin-top:0}.arc-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}@media(max-width:768px){.arc-edit-grid{grid-template-columns:1fr}}.arc-entities-col{min-width:0}.arc-entity-list{list-style:none;display:flex;flex-direction:column;gap:.35rem}.arc-entity-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.arc-entity-remove{margin-left:auto;padding:.1rem .3rem;font-size:.75rem;opacity:0;transition:opacity .15s}.arc-entity-item:hover .arc-entity-remove{opacity:1}.arc-add-entity{margin-top:.75rem}.arc-add-entity-row{display:flex;gap:.5rem;margin-bottom:.35rem}.arc-search-results{list-style:none;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius);max-height:180px;overflow-y:auto}.arc-search-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.4rem .65rem;font-size:.85rem;cursor:pointer;transition:background .1s}.arc-search-item:hover{background:var(--color-border)}.arc-entity-link{color:var(--color-accent)}.arc-entity-link:hover{text-decoration:underline}.tl-event-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.tl-event-item{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius);padding:.6rem .75rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.tl-event-item:hover{border-color:var(--color-accent)}.tl-event-info{flex:1;min-width:0}.tl-event-label{font-size:.875rem;font-weight:500}.tl-event-desc{font-size:.775rem;color:var(--color-muted);margin-top:.15rem}.tl-event-meta{display:flex;gap:.35rem;margin-top:.25rem}.tl-event-actions{display:flex;gap:.25rem;flex-shrink:0}.tl-header-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.tl-header-bar select{max-width:280px}.tl-meta{font-size:.8rem;color:var(--color-muted);display:flex;gap:1rem;margin-bottom:.75rem}.empty-state-sm{font-size:.85rem;color:var(--color-muted);padding:.5rem 0}.dashboard-section{margin-bottom:2rem}.dashboard-section h2{font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);font-weight:600;margin-bottom:.75rem}.stat-cards{display:flex;flex-wrap:wrap;gap:.75rem}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem;min-width:100px;text-align:center}.stat-card--link{text-decoration:none;cursor:pointer;transition:border-color var(--transition),box-shadow var(--transition)}.stat-card--link:hover{border-color:var(--color-accent);box-shadow:var(--shadow)}.stat-value{font-size:1.75rem;font-weight:700;color:var(--color-accent)}.stat-label{font-size:.75rem;color:var(--color-muted);margin-top:.2rem}.activity-list{list-style:none;display:flex;flex-direction:column;gap:.4rem}.activity-entry{display:flex;gap:.6rem;align-items:center;font-size:.85rem;padding:.5rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-wrap:wrap}.activity-actor{font-weight:500}.activity-action{color:var(--color-accent);font-family:monospace;font-size:.8rem}.activity-target{color:var(--color-muted);font-size:.8rem}.activity-time{color:var(--color-muted);font-size:.75rem;margin-left:auto}.audit-table{width:100%;border-collapse:collapse;font-size:.85rem}.audit-table th{text-align:left;padding:.5rem .75rem;border-bottom:1px solid var(--color-border);color:var(--color-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.audit-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-surface2)}.audit-table tr:hover td{background:var(--color-surface)}.audit-time{color:var(--color-muted);font-size:.8rem;white-space:nowrap}.audit-diff-row td{background:var(--color-bg)!important}.audit-diff{font-size:.75rem;color:var(--color-muted);white-space:pre-wrap;word-break:break-all;max-height:200px;overflow-y:auto}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:9999;max-width:380px}.toast{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem;box-shadow:var(--shadow);border:1px solid transparent}.toast-info{background:var(--color-surface2);border-color:var(--color-border)}.toast-warning{background:#e0a03026;border-color:var(--color-warning);color:var(--color-warning)}.toast-error{background:#e0525226;border-color:var(--color-danger);color:var(--color-danger)}.toast-close{background:none;border:none;cursor:pointer;color:inherit;font-size:1.1rem;line-height:1;opacity:.6}.toast-close:hover{opacity:1}.toast-enter-active,.toast-leave-active{transition:all .2s ease}.toast-enter-from,.toast-leave-to{opacity:0;transform:translate(1rem)}.pagination{display:flex;align-items:center;gap:.75rem;margin-top:1.25rem;font-size:.875rem}.pagination button{padding:.35rem .75rem}.loading{color:var(--color-muted);padding:2rem 0;text-align:center}.empty-state{color:var(--color-muted);padding:2rem 0;text-align:center;font-size:.9rem}.hint{font-size:.8rem;color:var(--color-muted)}.muted{color:var(--color-muted);font-size:.875rem}.mono{font-family:var(--font-mono);font-size:.8rem}.badge-success{background:#4caf8226;color:var(--color-success)}.badge-error{background:#e0525226;color:var(--color-danger)}.badge-warn{background:#e0a03026;color:var(--color-warning)}.ai-fab{position:fixed;bottom:1.5rem;right:1.5rem;z-index:200;width:3rem;height:3rem;border-radius:50%;background:var(--color-accent);color:#fff;border:none;cursor:pointer;font-size:1.3rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000059;transition:background .15s,transform .15s}.ai-fab:hover{background:var(--color-accent-hover, #3a7fa0);transform:scale(1.08)}.ai-fab--open{background:var(--color-surface2)}.ai-panel{position:fixed;top:0;right:0;bottom:0;width:min(480px,100vw);z-index:201;background:var(--color-surface);border-left:1px solid var(--color-border);display:flex;flex-direction:column;box-shadow:-6px 0 24px #0006}.ai-panel__header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--color-border)}.ai-panel__header h2{margin:0;font-size:1rem}.ai-panel__body{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.ai-panel__label{display:flex;flex-direction:column;gap:.3rem;font-size:.875rem;font-weight:500}.ai-panel__select,.ai-panel__textarea{font:inherit;background:var(--color-bg);border:1px solid var(--color-border);border-radius:.4rem;padding:.4rem .6rem;color:var(--color-text);resize:vertical}.ai-panel__select:focus,.ai-panel__textarea:focus{outline:2px solid var(--color-accent);outline-offset:-1px}.ai-panel__hint{font-size:.75rem;color:var(--color-muted)}.ai-panel__actions{display:flex;gap:.5rem;align-items:center}.ai-panel-enter-active,.ai-panel-leave-active{transition:transform .2s ease}.ai-panel-enter-from,.ai-panel-leave-to{transform:translate(100%)}.ai-backdrop{position:fixed;inset:0;z-index:199;background:#0006}.ai-backdrop-enter-active,.ai-backdrop-leave-active{transition:opacity .2s}.ai-backdrop-enter-from,.ai-backdrop-leave-to{opacity:0}.ai-prompt-preview{margin-top:1rem;border:1px solid var(--border);border-radius:.5rem;background:var(--bg-secondary, #1a1a2e);overflow:hidden}.ai-prompt-preview__header{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-bottom:1px solid var(--border);background:#00000026}.ai-prompt-preview__header h3{margin:0;font-size:.85rem;flex:1}.ai-prompt-preview__budget{font-size:.75rem;color:var(--text-muted)}.ai-prompt-preview__section{border-bottom:1px solid var(--border)}.ai-prompt-preview__section:last-child{border-bottom:none}.ai-prompt-preview__section summary{padding:.4rem .75rem;font-size:.8rem;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-muted)}.ai-prompt-preview__text{margin:0;padding:.5rem .75rem;font-size:.75rem;line-height:1.5;white-space:pre-wrap;word-break:break-word;max-height:20rem;overflow-y:auto;color:#e0e0e0;background:#ffffff0d}.ai-response-card{border:1px solid rgba(224,160,48,.3);border-radius:.5rem;padding:.75rem;background:#e0a0300d}.ai-response-card__meta{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.ai-response-card__tokens{font-size:.75rem;color:var(--color-muted);font-family:var(--font-mono)}.ai-response-card__body{font-size:.875rem;line-height:1.6;margin-bottom:.75rem}.ai-response-card__body p{margin:.4em 0}.ai-response-card__body h1,.ai-response-card__body h2,.ai-response-card__body h3{font-size:1rem;margin:.6em 0 .3em}.ai-response-card__body ul,.ai-response-card__body ol{padding-left:1.25em;margin:.4em 0}.ai-response-card__body pre{background:var(--color-bg);padding:.5em;border-radius:.3em;overflow-x:auto;font-size:.8rem}.ai-response-card__actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.ai-image-prompt{margin-top:1rem;padding:1rem;border-radius:var(--radius);background:var(--color-bg);border:1px solid var(--color-border)}.ai-image-prompt__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.ai-image-prompt__header h3{margin:0;font-size:.9rem;color:var(--color-text)}.ai-image-prompt__editor{width:100%;min-height:180px;padding:.75rem;font-family:var(--font-mono);font-size:.8rem;line-height:1.5;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);resize:vertical}.ai-image-prompt__editor:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #6366f140}.ai-image-prompt__hint{margin:.5rem 0;font-size:.75rem;color:var(--color-muted)}.settings-tabs{display:flex;gap:.25rem;margin-bottom:2rem;border-bottom:1px solid var(--color-border)}.settings-tab{padding:.5rem 1rem;color:var(--color-muted);text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-size:.9rem}.settings-tab.router-link-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.settings-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.settings-section:last-child{border-bottom:none}.settings-section h2{font-size:1.1rem;margin-bottom:1rem}.settings-form{display:flex;flex-direction:column;gap:.75rem;max-width:480px}.settings-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.875rem;font-weight:500}.settings-form small{font-size:.75rem;color:var(--color-muted);font-weight:400}.key-status{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.key-fingerprint{font-family:var(--font-mono);font-size:.8rem}.key-status--empty{color:var(--color-muted);font-size:.875rem;margin-bottom:1rem}.form-success{color:var(--color-success);font-size:.875rem;margin:0}.form-error--sm{font-size:.8rem}.budget-stats{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.budget-bar{height:8px;background:var(--color-surface2);border-radius:4px;overflow:hidden;margin-bottom:.4rem;max-width:480px}.budget-bar__fill{height:100%;background:var(--color-accent);transition:width .3s}.budget-bar__fill--warn{background:var(--color-warning)}.budget-bar__fill--critical{background:var(--color-danger)}.budget-bar__label{font-size:.75rem;color:var(--color-muted);margin-bottom:.75rem}.ai-test-result{display:flex;align-items:center;gap:.6rem;margin-top:.75rem;padding:.6rem .9rem;border-radius:6px;font-size:.875rem;border:1px solid}.ai-test-result--ok{background:color-mix(in srgb,var(--color-success) 12%,transparent);border-color:var(--color-success);color:var(--color-success)}.ai-test-result--fail{background:color-mix(in srgb,var(--color-danger) 12%,transparent);border-color:var(--color-danger);color:var(--color-danger)}.ai-test-result__icon{font-weight:700;flex-shrink:0}.usage-history h3{font-size:.9rem;margin-bottom:.5rem}.usage-list{list-style:none;padding:0;margin:0;font-size:.8rem}.usage-list__item{display:flex;justify-content:space-between;padding:.25rem 0;border-bottom:1px solid var(--color-border)}.usage-list__day{font-family:var(--font-mono)}.usage-list__tokens{color:var(--color-muted)}.session-detail{padding:.75rem 1rem;font-size:.875rem;background:var(--color-surface2);border-radius:.3rem}.session-detail p{margin:.25rem 0}.role-select{font:inherit;background:var(--color-bg);border:1px solid var(--color-border);border-radius:.3rem;padding:.2rem .4rem;color:var(--color-text);font-size:.8rem}.import-stats{font-size:.875rem;padding:.5rem .75rem;background:var(--color-surface2);border-radius:.4rem;border:1px solid var(--color-border)}code{font-family:JetBrains Mono,Fira Code,monospace}.import-steps{margin:.75rem 0 1rem 1.25rem;padding:0;color:var(--color-muted);font-size:.9rem;line-height:1.8}.import-steps em{color:var(--color-text);font-style:normal;font-weight:500}.import-steps code{font-size:.85em;background:var(--color-surface2);padding:.1em .35em;border-radius:.25rem}.import-prompt-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.75rem}.import-prompt-preview{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:.5rem;overflow:auto;max-height:340px}.import-prompt-preview pre{margin:0;padding:1rem;font-family:JetBrains Mono,Fira Code,monospace;font-size:.78rem;line-height:1.55;white-space:pre-wrap;color:var(--color-muted)}.form-row{display:flex;gap:.75rem;flex-wrap:wrap}.form-row label{flex:1;min-width:140px}.modal-overlay,.modal-backdrop{position:fixed;inset:0;z-index:400;background:#000000a6;display:flex;align-items:center;justify-content:center;padding:1rem}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px;overflow:hidden}.drawer-backdrop{position:fixed;inset:0;z-index:300;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;justify-content:flex-end}.drawer{position:relative;width:min(480px,100vw);height:100%;background:var(--color-surface);border-left:1px solid var(--color-border);box-shadow:var(--shadow-lg);overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;animation:drawer-in .2s ease}@keyframes drawer-in{0%{transform:translate(100%)}to{transform:none}}.drawer-close{position:absolute;top:1rem;right:1rem;background:var(--color-surface2);border:1px solid var(--color-border);color:var(--color-muted);border-radius:var(--radius);width:2rem;height:2rem;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition)}.drawer-close:hover{background:var(--color-border);color:var(--color-text)}.drawer-header{display:flex;flex-direction:column;gap:.4rem;padding-right:2.5rem}.drawer-header h2{font-size:1.1rem;font-weight:600;margin:0}.drawer-actions{display:flex;gap:.5rem;flex-wrap:wrap;padding-top:.5rem;border-top:1px solid var(--color-border);margin-top:auto}.detail-list{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1rem;font-size:.875rem;align-items:baseline}.detail-list dt{color:var(--color-muted);font-weight:500;white-space:nowrap}.detail-list dd{color:var(--color-text);margin:0}.detail-list dd a{color:var(--color-accent);word-break:break-all}.entity-link{display:inline-block;padding:.15rem .5rem;background:#2563eb1a;color:var(--color-accent);border-radius:var(--radius);font-size:.8rem;margin:.15rem .2rem .15rem 0;transition:background var(--transition)}.entity-link:hover{background:#2563eb33;text-decoration:none}.tag-chip{display:inline-block;padding:.15rem .5rem;background:var(--color-surface2);color:var(--color-muted);border:1px solid var(--color-border);border-radius:99px;font-size:.75rem;margin:.1rem .15rem .1rem 0}.confirm-box{padding:.9rem;background:#f851490f;border:1px solid rgba(248,81,73,.25);border-radius:var(--radius);display:flex;flex-direction:column;gap:.5rem;font-size:.875rem}.confirm-box p{margin:0}.ref-list{display:flex;flex-direction:column;gap:.5rem}.ref-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:.9rem 1rem;cursor:pointer;transition:border-color var(--transition),transform .15s ease}.ref-card:hover{border-color:var(--color-accent);transform:translate(2px)}.ref-card-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.25rem}.ref-card-title{font-weight:500;color:var(--color-text)}.ref-card-meta{font-size:.8rem;color:var(--color-muted);margin-bottom:.2rem}.ref-card-desc{font-size:.85rem;color:var(--color-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ref-card-url{font-size:.8rem;margin-top:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge-type-url{background:#2563eb1f;color:#60a5fa;border-color:#2563eb4d}.badge-type-book{background:#3fb9501f;color:#4ade80;border-color:#3fb9504d}.badge-type-article{background:#f973161f;color:#fb923c;border-color:#f973164d}.badge-type-film{background:#a78bfa1f;color:#a78bfa;border-color:#a78bfa4d}.badge-type-podcast{background:#f472b61f;color:#f472b6;border-color:#f472b64d}.badge-type-other{background:var(--color-surface2);color:var(--color-muted)}.op-list{display:flex;flex-direction:column;gap:.5rem}.op-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:.9rem 1rem;cursor:pointer;transition:border-color var(--transition),transform .15s ease}.op-card:hover{border-color:var(--color-accent);transform:translate(2px)}.op-card-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.25rem}.op-card-title{font-weight:500;color:var(--color-text)}.op-card-meta{font-size:.8rem;color:var(--color-muted);margin-bottom:.2rem}.op-card-desc{font-size:.85rem;color:var(--color-muted);margin-bottom:.35rem}.op-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:.8rem;color:var(--color-muted)}.op-creator{font-size:.8rem}.op-status-resolved .op-card-title,.op-status-wont_fix .op-card-title{opacity:.55;text-decoration:line-through}.badge-priority-low{background:#7d85901f;color:var(--color-muted)}.badge-priority-medium{background:#2563eb1f;color:#60a5fa;border-color:#2563eb4d}.badge-priority-high{background:#d299221f;color:var(--color-warning);border-color:#d299224d}.badge-priority-critical{background:#f8514926;color:var(--color-danger);border-color:#f851494d}.badge-status-open{background:#2563eb1f;color:#60a5fa;border-color:#2563eb4d}.badge-status-in_progress{background:#f973161f;color:#fb923c;border-color:#f973164d}.badge-status-resolved{background:#3fb9501f;color:var(--color-success);border-color:#3fb9504d}.badge-status-wont_fix{background:var(--color-surface2);color:var(--color-muted)}.world-card{transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.world-card:hover{box-shadow:0 4px 20px #2563eb26}.dashboard-nav{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;margin-bottom:2rem}.dashboard-nav-card{display:flex;flex-direction:column;gap:.3rem;padding:.9rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;color:var(--color-text);transition:border-color var(--transition),transform .15s ease,box-shadow var(--transition)}.dashboard-nav-card:hover{border-color:var(--color-accent);transform:translateY(-2px);box-shadow:0 4px 16px #2563eb1f;text-decoration:none}.dashboard-nav-card__icon{font-size:1.3rem}.dashboard-nav-card__label{font-size:.875rem;font-weight:500}.dashboard-nav-card__count{font-size:.75rem;color:var(--color-muted)}@media(max-width:768px){.page{padding:1rem}.page-header{flex-direction:column;align-items:flex-start}.drawer{width:100vw;border-left:none}.settings-form{max-width:100%}.form-row{flex-direction:column}}@media(max-width:480px){.filter-bar{flex-direction:column}.filter-bar input,.filter-bar select{max-width:100%;width:100%}}.app-nav{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 2rem;border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100}.app-nav__brand{font-size:1.1rem;font-weight:700;letter-spacing:-.01em;color:var(--color-text);text-decoration:none;display:flex;align-items:center;gap:.5rem}.app-nav__logo{height:28px;width:auto;border-radius:4px}.app-nav__brand:hover{color:var(--color-text);text-decoration:none}.app-nav__links{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.app-nav__theme{border:1px solid var(--color-border);border-radius:50%;width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;margin-left:.25rem}.world-subnav{display:flex;align-items:center;gap:.15rem;padding:.35rem 2rem;border-bottom:1px solid var(--color-border);background:var(--color-surface);position:sticky;top:58px;z-index:99;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.world-subnav::-webkit-scrollbar{display:none}.world-subnav__link{padding:.3rem .7rem;font-size:.8rem;font-weight:500;color:var(--color-text-muted);text-decoration:none;border-radius:var(--radius-sm);white-space:nowrap;transition:color .15s,background .15s;border:none;background:none;cursor:pointer;font-family:inherit}.world-subnav__link:hover{color:var(--color-text);background:var(--color-bg)}.world-subnav__link.router-link-active{color:var(--color-primary);background:var(--color-primary-light, rgba(74, 144, 164, .1));font-weight:600}@media(max-width:600px){.world-subnav{padding:.3rem 1rem;top:52px}}@media(max-width:600px){.app-nav{padding:1rem 1.25rem}}.landing{min-height:100vh;background:var(--color-bg);display:flex;flex-direction:column}.landing-nav{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 2rem;border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100}.landing-nav__brand{font-size:1.1rem;font-weight:700;letter-spacing:-.01em;color:var(--color-text);display:flex;align-items:center;gap:.5rem}.landing-nav__logo{height:28px;width:auto;border-radius:4px}.landing-nav__links{display:flex;gap:.5rem;align-items:center}.landing-hero{max-width:760px;margin:0 auto;padding:6rem 2rem 5rem;text-align:center}.landing-hero__eyebrow{font-size:.8rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);margin-bottom:1.25rem}.landing-hero__title{font-size:clamp(2rem,5vw,3.25rem);font-weight:800;line-height:1.15;letter-spacing:-.025em;color:var(--color-text);margin-bottom:1.25rem}.landing-hero__accent{color:var(--color-cta)}.landing-hero__sub{font-size:1.1rem;color:var(--color-muted);line-height:1.7;max-width:560px;margin:0 auto 2.5rem}.landing-hero__cta{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.landing-hero__cta-primary{padding:.75rem 1.75rem;font-size:1rem}.landing-hero__cta-secondary{padding:.75rem 1.5rem;font-size:1rem}.landing-features{max-width:1100px;margin:0 auto;padding:4rem 2rem;width:100%}.landing-section-title{font-size:1.6rem;font-weight:700;letter-spacing:-.02em;text-align:center;margin-bottom:2.5rem;color:var(--color-text)}.landing-features__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:1.5rem;transition:border-color var(--transition),transform .15s ease,box-shadow var(--transition)}.feature-card:hover{border-color:var(--color-accent);transform:translateY(-3px);box-shadow:0 8px 24px #2563eb1a}.feature-card__icon{font-size:1.6rem;margin-bottom:.75rem}.feature-card__title{font-size:.95rem;font-weight:600;margin-bottom:.4rem}.feature-card__desc{font-size:.85rem;color:var(--color-muted);line-height:1.6}.landing-bottom-cta{text-align:center;padding:5rem 2rem;background:linear-gradient(180deg,transparent 0%,rgba(37,99,235,.04) 100%);border-top:1px solid var(--color-border)}.landing-bottom-cta h2{font-size:1.75rem;font-weight:700;margin-bottom:.6rem}.landing-bottom-cta p{color:var(--color-muted);margin-bottom:1.75rem}.landing-bottom-cta .btn{padding:.75rem 2rem;font-size:1rem}.landing-footer{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 2rem;border-top:1px solid var(--color-border);font-size:.8rem;color:var(--color-muted);flex-wrap:wrap;gap:.75rem}.landing-footer__links{display:flex;gap:1rem}.landing-footer__links a{color:var(--color-muted)}.landing-footer__links a:hover{color:var(--color-text)}@media(max-width:600px){.landing-hero{padding:3.5rem 1.25rem 3rem}.landing-features{padding:2.5rem 1.25rem}.landing-bottom-cta{padding:3rem 1.25rem}.landing-nav{padding:1rem 1.25rem}}.tut-layout{display:flex;min-height:100vh;background:var(--color-bg)}.tut-sidebar{width:220px;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid var(--color-border);background:var(--color-surface);display:flex;flex-direction:column;padding:1.25rem 0}.tut-sidebar__brand{display:flex;flex-direction:column;gap:.15rem;padding:0 1.25rem 1rem;border-bottom:1px solid var(--color-border);margin-bottom:.5rem}.tut-sidebar__logo{font-size:1rem;font-weight:700;color:var(--color-text);text-decoration:none}.tut-sidebar__logo:hover{color:var(--color-accent);text-decoration:none}.tut-sidebar__label{font-size:.72rem;color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em}.tut-nav{flex:1;display:flex;flex-direction:column;padding:0 .5rem}.tut-nav__item{background:none;border:none;text-align:left;padding:.45rem .75rem;border-radius:var(--radius);font-size:.825rem;color:var(--color-muted);cursor:pointer;transition:background var(--transition),color var(--transition);line-height:1.4}.tut-nav__item:hover{background:var(--color-surface2);color:var(--color-text)}.tut-nav__item--active{background:#2563eb1f;color:var(--color-accent);font-weight:500}.tut-sidebar__back{padding:1rem 1.25rem 0;border-top:1px solid var(--color-border);margin-top:.5rem}.tut-content{flex:1;overflow-y:auto;padding:3rem 4rem 5rem;max-width:780px}.tut-hero{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--color-border)}.tut-hero h1{font-size:2rem;font-weight:800;letter-spacing:-.025em;margin-bottom:.5rem}.tut-hero p{color:var(--color-muted);font-size:1rem}.tut-section{margin-bottom:3.5rem;scroll-margin-top:2rem}.tut-section h2{font-size:1.3rem;font-weight:700;letter-spacing:-.015em;margin-bottom:1rem;padding-bottom:.6rem;border-bottom:1px solid var(--color-border);color:var(--color-text)}.tut-section h3{font-size:.95rem;font-weight:600;margin:1.25rem 0 .5rem;color:var(--color-text)}.tut-section p{color:var(--color-muted);font-size:.9rem;line-height:1.75;margin-bottom:.75rem}.tut-steps{padding-left:1.25rem;display:flex;flex-direction:column;gap:.5rem;font-size:.875rem;color:var(--color-muted);line-height:1.65;margin-bottom:.75rem}.tut-steps li strong{color:var(--color-text)}.tut-steps li em{color:var(--color-accent);font-style:normal}.tut-list{padding-left:1.25rem;display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;color:var(--color-muted);line-height:1.6;margin-bottom:.75rem}.tut-list li strong{color:var(--color-text)}.tut-tip{background:#2563eb12;border:1px solid rgba(37,99,235,.2);border-left:3px solid var(--color-accent);border-radius:var(--radius);padding:.7rem 1rem;font-size:.85rem;color:var(--color-muted);line-height:1.65;margin-top:.75rem}.tut-tip strong{color:var(--color-accent)}.tut-type-grid{display:flex;flex-wrap:wrap;gap:.4rem;margin:.75rem 0 1rem}.tut-type-pill{display:inline-block;padding:.25rem .65rem;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:99px;font-size:.8rem;font-weight:500;color:var(--color-text)}.tut-table{width:100%;border-collapse:collapse;font-size:.85rem;margin:.75rem 0}.tut-table th{text-align:left;padding:.5rem .75rem;border-bottom:2px solid var(--color-border);color:var(--color-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.tut-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-surface2);color:var(--color-muted)}.tut-table td:first-child{color:var(--color-text);font-weight:500}.tut-table tr:hover td{background:var(--color-surface)}.tut-code{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:6px;padding:.75rem 1rem;font-family:monospace;font-size:.85rem;line-height:1.6;white-space:pre-wrap;word-break:break-all;color:var(--color-text);margin:.5rem 0 1rem}kbd{display:inline-block;padding:.1em .4em;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:4px;font-family:inherit;font-size:.8em;color:var(--color-text)}@media(max-width:768px){.tut-layout{flex-direction:column}.tut-sidebar{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;padding:.75rem 1rem;gap:.4rem;border-right:none;border-bottom:1px solid var(--color-border)}.tut-sidebar__brand{padding:0;border-bottom:none;margin-bottom:0;flex-direction:row;align-items:baseline;gap:.5rem}.tut-sidebar__label{display:none}.tut-nav{flex-direction:row;flex-wrap:wrap;padding:0}.tut-nav__item{padding:.3rem .6rem;font-size:.78rem}.tut-sidebar__back{padding:0;border-top:none;margin-top:0}.tut-content{padding:1.5rem 1.25rem 3rem}}.notes-feed{display:flex;flex-direction:column;gap:.5rem}.note-feed-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:.9rem 1rem;transition:border-color var(--transition)}.note-feed-card:hover{border-color:var(--color-accent)}.note-feed-card__header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.35rem}.note-feed-card__entity{font-size:.8rem;font-weight:500;color:var(--color-accent)}.note-feed-card__entity--world{color:var(--color-muted)}.note-feed-card__meta{font-size:.75rem;color:var(--color-muted);margin-left:auto}.note-feed-card__excerpt{font-size:.875rem;color:var(--color-muted);line-height:1.6;margin-bottom:.35rem}.note-feed-card__link{font-size:.8rem;color:var(--color-accent)}.totp-status{display:flex;align-items:center;gap:.5rem;padding:.6rem .9rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;margin-bottom:1rem}.totp-status--on{background:#3fb9501a;border:1px solid rgba(63,185,80,.3);color:var(--color-success)}.totp-status--off{background:#7d859014;border:1px solid var(--color-border);color:var(--color-muted)}.totp-status__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:currentColor}.totp-qr{display:flex;justify-content:center;margin:1rem 0;padding:1rem;background:#fff;border-radius:var(--radius);width:fit-content}.totp-qr img{display:block}.totp-manual{font-size:.8rem;color:var(--color-muted);margin-bottom:.5rem}.totp-manual summary{cursor:pointer}.totp-secret{display:block;font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem;letter-spacing:.1em;word-break:break-all;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius);padding:.5rem .75rem;margin-top:.4rem;color:var(--color-text);-webkit-user-select:all;user-select:all}:root[data-theme=light]{--color-bg: #ffffff;--color-surface: #f6f8fa;--color-surface2: #eaeef2;--color-border: #d0d7de;--color-text: #1f2328;--color-muted: #57606a;--color-accent: #1d4ed8;--color-accent-h: #1847c4;--color-cta: #ea580c;--color-cta-h: #c2410c;--color-danger: #b91c1c;--color-success: #0a6b2d;--color-warning: #855a08;--shadow: 0 2px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12)}@media(prefers-color-scheme:light){:root:not([data-theme=dark]){--color-bg: #ffffff;--color-surface: #f6f8fa;--color-surface2: #eaeef2;--color-border: #d0d7de;--color-text: #1f2328;--color-muted: #57606a;--color-accent: #1d4ed8;--color-accent-h: #1847c4;--color-cta: #ea580c;--color-cta-h: #c2410c;--color-danger: #b91c1c;--color-success: #0a6b2d;--color-warning: #855a08;--shadow: 0 2px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12)}}.theme-toggle{position:fixed;bottom:1.25rem;left:1.25rem;z-index:100;background:var(--color-surface);border:1px solid var(--color-border);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;transition:background var(--transition),border-color var(--transition);box-shadow:var(--shadow)}.theme-toggle:hover{background:var(--color-surface2);border-color:var(--color-muted)}.story-board{display:flex;flex-direction:column;height:calc(100vh - 7rem);overflow:hidden}.story-board__header{padding:.75rem 1.5rem;border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0}.story-board__title-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.story-board__title{font-size:1.25rem;margin:0;cursor:pointer}.story-board__title:hover{color:var(--color-accent)}.story-board__meta-form{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.story-board__meta-title-input{flex:1;min-width:200px}.story-board__meta-synopsis{flex:2;min-width:200px}.story-board__error{margin:0 1.5rem;flex-shrink:0}.story-board__panes{display:flex;flex:1;min-height:0;overflow:hidden}.story-board__editor-pane{flex:1;min-width:0;overflow:auto;border-right:1px solid var(--color-border)}.story-board__context-pane{width:340px;min-width:260px;max-width:420px;overflow-y:auto;background:var(--color-surface)}.story-board__footer{display:flex;align-items:center;gap:1rem;padding:.5rem 1.5rem;border-top:1px solid var(--color-border);background:var(--color-surface);font-size:.85rem;flex-shrink:0}.story-board__word-count{color:var(--color-muted)}.story-board__unsaved{color:var(--color-warning, #e6a817);font-weight:500}.story-board__saving{color:var(--color-accent)}.story-board__saved{color:var(--color-muted)}.story-editor{height:100%;display:flex;flex-direction:column}.story-editor__toolbar{display:flex;flex-wrap:wrap;gap:2px;padding:6px 8px;border-bottom:1px solid var(--color-border);background:var(--color-surface);align-items:center;position:sticky;top:0;z-index:10}.story-editor__toolbar-btn{background:none;border:1px solid transparent;border-radius:4px;padding:4px 8px;font-size:.8rem;font-weight:600;cursor:pointer;color:var(--color-text);line-height:1;min-width:28px;text-align:center}.story-editor__toolbar-btn:hover{background:var(--color-surface2);border-color:var(--color-border)}.story-editor__toolbar-btn:active{background:var(--color-accent);color:#fff}.story-editor__toolbar-btn--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.story-editor__toolbar-btn--active:hover{background:var(--color-accent-h);border-color:var(--color-accent-h)}.story-editor__toolbar-btn:disabled{opacity:.4;cursor:default}.story-editor__toolbar-sep{width:1px;height:20px;background:var(--color-border);margin:0 4px}.story-editor .milkdown{flex:1;overflow-y:auto}.story-editor .milkdown .editor{min-height:100%;padding:1.5rem 2rem;outline:none;font-size:1rem;line-height:1.75}.story-editor .milkdown .editor p{margin:0 0 .75rem}.story-editor .milkdown .editor h1,.story-editor .milkdown .editor h2,.story-editor .milkdown .editor h3,.story-editor .milkdown .editor h4{margin:1.5rem 0 .75rem}.story-editor .milkdown .editor blockquote{border-left:3px solid var(--color-accent);padding-left:1rem;color:var(--color-muted);margin:1rem 0}.story-editor .milkdown .editor code{background:var(--color-surface2);padding:.125rem .375rem;border-radius:3px;font-size:.9em}.story-editor .milkdown .editor pre{background:var(--color-surface2);padding:1rem;border-radius:6px;overflow-x:auto}.story-editor .milkdown .editor hr{border:none;border-top:1px solid var(--color-border);margin:1.5rem 0}.story-editor__loading{padding:2rem;text-align:center;color:var(--color-muted)}.story-context{display:flex;flex-direction:column}.story-context__section{border-bottom:1px solid var(--color-border)}.story-context__heading{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.625rem 1rem;background:none;border:none;color:var(--color-text);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.04em;cursor:pointer}.story-context__heading:hover{background:var(--color-surface2)}.story-context__chevron{font-size:.75rem;color:var(--color-muted)}.story-context__body{padding:.5rem 1rem 1rem}.story-entities__list{list-style:none;padding:0;margin:0 0 .75rem}.story-entities__item{display:flex;align-items:center;gap:.375rem;padding:.25rem 0;font-size:.875rem}.story-entities__link{color:var(--color-accent);text-decoration:none}.story-entities__link:hover{text-decoration:underline}.story-entities__add{margin-bottom:.75rem}.story-entities__search-row{display:flex;gap:.375rem}.story-entities__search-row input{font-size:.85rem;padding:.375rem .5rem}.story-entities__scan,.story-entities__scan-results{margin-top:.5rem}.story-entities__scan-label{font-size:.8rem;font-weight:600;color:var(--color-muted);margin:.5rem 0 .25rem}.story-entities__create-hint{display:flex;align-items:center;gap:.25rem;margin-top:.25rem}.story-entities__create-form{display:flex;align-items:center;gap:.4rem;margin-top:.4rem;flex-wrap:wrap}.story-entities__type-select{flex:1;min-width:0}.story-notes__list{list-style:none;padding:0;margin:0 0 .75rem}.story-notes__item{padding:.375rem 0;border-bottom:1px solid var(--color-surface2);font-size:.85rem}.story-notes__header{display:flex;align-items:center;gap:.375rem;margin-bottom:.125rem}.story-notes__excerpt{color:var(--color-muted);margin:0;font-size:.8rem;line-height:1.4}.story-notes__add{margin-top:.5rem}.story-notes__add input{font-size:.85rem;padding:.375rem .5rem;width:100%}.story-notes__new-label{display:block;margin:.65rem 0 .35rem;font-size:.8rem;font-weight:600;color:var(--color-muted)}.story-notes__add textarea{width:100%;resize:vertical;min-height:5.5rem;font-size:.85rem;padding:.45rem .55rem}.story-notes__new-actions{display:flex;justify-content:flex-end;margin-top:.4rem}.story-arc-ref__info{display:flex;align-items:center;gap:.5rem}.story-arc-ref__name{color:var(--color-accent);text-decoration:none;font-weight:500}.story-arc-ref__name:hover{text-decoration:underline}.story-arc-ref__logline{color:var(--color-muted);font-size:.85rem;margin:.375rem 0 0}.story-arc-ref__picker{display:flex;flex-direction:column;gap:.4rem}.story-arc-ref__pick-list{display:flex;flex-direction:column;gap:2px;max-height:200px;overflow-y:auto}.story-arc-ref__pick-item{display:flex;align-items:center;gap:.5rem;background:none;border:1px solid var(--color-border);border-radius:4px;padding:.3rem .6rem;cursor:pointer;text-align:left;color:var(--color-text);font-size:.875rem;transition:background .1s}.story-arc-ref__pick-item:hover:not(:disabled){background:var(--color-surface2);border-color:var(--color-accent)}.story-board__title-arc{font-weight:400;color:var(--color-muted);font-size:.9em}.story-ai__label{display:block;font-size:.8rem;font-weight:600;color:var(--color-muted);margin-bottom:.5rem}.story-ai__label select,.story-ai__label textarea{display:block;width:100%;margin-top:.25rem;font-size:.85rem}.story-ai__hint{font-size:.75rem;color:var(--color-muted)}.story-ai__actions{display:flex;gap:.5rem;margin:.5rem 0}.story-ai__result{margin-top:.75rem;padding:.75rem;background:var(--color-surface2);border-radius:6px}.story-ai__result-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.story-ai__tokens{font-size:.75rem;color:var(--color-muted)}.story-ai__result-text{font-size:.85rem;line-height:1.6;white-space:pre-wrap}.story-ai__result-actions{margin-top:.65rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.story-ai__note-info{font-size:.8rem;color:var(--color-muted)}.story-table{width:100%;border-collapse:collapse}.story-table thead th{text-align:left;padding:.5rem .75rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted);border-bottom:2px solid var(--color-border)}.story-table__sortable{cursor:pointer}.story-table__sortable:hover{color:var(--color-accent)}.story-table__row{cursor:pointer;transition:background var(--transition)}.story-table__row:hover{background:var(--color-surface2)}.story-table__row td{padding:.625rem .75rem;border-bottom:1px solid var(--color-border);font-size:.9rem}.story-table__title{font-weight:500}.story-table__num{text-align:right}.story-table__date{color:var(--color-muted);font-size:.85rem}.story-table__actions{text-align:right}.badge-status-draft{background:var(--color-surface2);color:var(--color-muted)}.badge-status-in_progress{background:#1a3a5c;color:#6cb4ee}.badge-status-review{background:#3d2e0f;color:#e6a817}.badge-status-final{background:#0f3d1a;color:#4caf50}.badge-status-abandoned{background:#3d0f0f;color:#e57373}@media(max-width:900px){.story-board__panes{flex-direction:column}.story-board__context-pane{width:100%;max-width:none;max-height:300px;border-top:1px solid var(--color-border)}.story-board__editor-pane{border-right:none}}@media(max-width:600px){.story-board__meta-form{flex-direction:column}.story-board__footer{flex-wrap:wrap;gap:.5rem}.story-table thead{display:none}.story-table__row{display:block;padding:.75rem;margin-bottom:.5rem;border:1px solid var(--color-border);border-radius:6px}.story-table__row td{display:block;border:none;padding:.125rem 0}}.admin-toolbar{margin-bottom:1rem}.admin-search{width:100%;max-width:420px}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th{text-align:left;padding:.5rem .75rem;border-bottom:2px solid var(--color-border);color:var(--color-muted);font-weight:600;white-space:nowrap}.admin-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-border);vertical-align:middle}.admin-table__row--inactive td{opacity:.55}.admin-table__id{color:var(--color-muted);font-size:.8rem}.admin-table__username{font-weight:600;margin-right:.35rem}.admin-table__num{text-align:center}.admin-table__date{white-space:nowrap;color:var(--color-muted);font-size:.8rem}.admin-table__actions{display:flex;gap:.25rem;flex-wrap:wrap}.admin-table__delete{color:var(--color-danger)}.admin-pagination{display:flex;align-items:center;gap:1rem;padding:1rem 0;font-size:.875rem;color:var(--color-muted)}.search-overlay[data-v-e09b50b4]{position:fixed;inset:0;z-index:9999;background:#0009;display:flex;align-items:flex-start;justify-content:center;padding-top:12vh;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.search-modal[data-v-e09b50b4]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:600px;box-shadow:var(--shadow-lg);overflow:hidden}.search-input-wrap[data-v-e09b50b4]{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--color-border)}.search-input[data-v-e09b50b4]{flex:1;background:transparent;border:none;color:var(--color-text);font-size:1rem;outline:none}.search-kbd[data-v-e09b50b4]{font-size:.7rem;padding:.15rem .4rem;border:1px solid var(--color-border);border-radius:4px;color:var(--color-muted);background:var(--color-surface2);cursor:pointer;white-space:nowrap}.search-hint[data-v-e09b50b4]{font-size:.8rem;color:var(--color-muted);padding:.4rem 1rem 0;margin:0}.search-results[data-v-e09b50b4]{max-height:480px;overflow-y:auto;padding-bottom:.5rem}.search-status[data-v-e09b50b4]{padding:1.25rem 1rem;text-align:center;color:var(--color-muted);font-size:.875rem;margin:0}.search-group[data-v-e09b50b4]{padding:.5rem 0 0}.search-group__label[data-v-e09b50b4]{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted);padding:.25rem 1rem;margin:0}.search-list[data-v-e09b50b4]{list-style:none;margin:0;padding:0}.search-item[data-v-e09b50b4]{padding:.55rem 1rem;cursor:pointer;transition:background var(--transition)}.search-item[data-v-e09b50b4]:hover{background:var(--color-surface2)}.search-item__header[data-v-e09b50b4]{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.search-item__title[data-v-e09b50b4]{font-weight:500;font-size:.9rem}.search-item__meta[data-v-e09b50b4]{font-size:.75rem;color:var(--color-muted)}.search-item__snippet[data-v-e09b50b4]{font-size:.8rem;color:var(--color-muted);margin:.2rem 0 0;line-height:1.5}.search-item__snippet[data-v-e09b50b4] mark{background:color-mix(in srgb,var(--color-accent) 25%,transparent);color:inherit;border-radius:2px;padding:0 1px}.search-see-all[data-v-e09b50b4]{display:block;padding:.35rem 1rem .5rem;font-size:.8rem;color:var(--color-accent);text-decoration:none;border-top:1px solid var(--color-border);margin-top:.25rem}.search-see-all[data-v-e09b50b4]:hover{text-decoration:underline}.badge--sm[data-v-e09b50b4]{font-size:.65rem;padding:.1rem .35rem}
